?
Solved

Convert links for to querystring

Posted on 2010-11-15
3
Medium Priority
?
326 Views
Last Modified: 2012-08-13
I am trying to write a mobile version of a website, but am having problems passign the href tags and staying within my mobile version.

To make this successful, I need to rewrite all the href tags to pass through a querystring, so href=/mylink.asp now goes to href=/m/?r=mylink.asp.  Any URL has to be adjusted.  I tried this in the simple way by just finding any href tag, and adding the query id to it, but this does not account for root relative links vs page relative links.  See code below.  

I am sure I am not the first to try and do this, so any help would be very much appreciated.
<cfoutput>
    <!--- PASSES CURRENT PAGE URL, SET TO ABOUT FOR THIS SAMPLE--->
    <cfset url.r = 'aboutus.cfm'>
    <!---GET CONTENTS OF URL--->
    <cfset tempURL = "http://"&#CGI.SERVER_NAME#&#url.r#>
    <cfhttp url=#tempURL#></cfhttp>
    <cfset tempInfo = #cfhttp.filecontent#>
    
    <cfscript>
    //FIND STRING TO STRIP
    startPos = find('<h1 class', tempInfo);
    endPos = find('contentPrimary -->', tempInfo);
    cutLength = endPos - startPos;
    tempInfo = Mid(tempInfo, startPos, cutLength);
    
    //REPLACE any HREF that does not start with http
    
    //THIS IS WHERE I AM NOT SURE HOW TO PROCEED
    tempInfo = replace(tempInfo, 'href="/', 'href="/m/?r=/', 'all');		//REPLACES ALL HREF TAGS INTO QUERY STRING
	tempInfo = replace(tempInfo, 'href="/m/?r=http', 'href="http', 'all');	//REMOVES WHAT I JUST DID IF URL BEGINS WITH HTTP
    
    //STILL TO SOLVE
    //IF URL IS DOCUMENT RELATIVE
    //IF URL ALREADY CONTAINS A QUERYSTRING (CONVERT EXISTING ? to &)
    
    writeOutput(tempInfo);
	
    </cfscript>
</cfoutput>

Open in new window

0
Comment
Question by:mopar003
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 2
3 Comments
 

Expert Comment

by:macrem
ID: 34144116
Have you tired ReplaceNoCase() ?
You'll find it is safer when you don't know the incoming case.
CGI.SERVER_NAME generally returns uppercase.

0
 
LVL 1

Accepted Solution

by:
mopar003 earned 0 total points
ID: 34146788
Found my own solution.  Searching through all href tags on the page, then checking to see if they were root or document relative.
0
 
LVL 1

Author Closing Comment

by:mopar003
ID: 34182414
Alternate solution found
0

Featured Post

Give Your Engineering Team a Productivity Boost

Learn why container technology is so powerful and how it can provide your team with productivity gains and other benefits.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Hi, I will be creating today a basic tutorial on how we can create a Mail Custom Function and use it where ever we want. The main advantage about creating a custom function is that we can accommodate a range of arguments to pass to the Function and …
PROBLEM: How to add your own buttons to the bottom toolbar with paging info ( result count ). While creating a cfgrid, I ran into an issue where I wanted to embed my own custom buttons where the default ones ( insert / delete / etc… ) are for aes…
Add bar graphs to Access queries using Unicode block characters. Graphs appear on every record in the color you want. Give life to numbers. Hopes this gives you ideas on visualizing your data in new ways ~ Create a calculated field in a query: …
Do you want to know how to make a graph with Microsoft Access? First, create a query with the data for the chart. Then make a blank form and add a chart control. This video also shows how to change what data is displayed on the graph as well as form…
Suggested Courses

719 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question