Re: [WebDNA] behavior of [thisurl] in the context of 'mod_rewrite'

This WebDNA talk-list message is from

2012


It keeps the original formatting.
numero = 108156
interpreted = N
texte = > I have question, ideas, possible solutions... >=20 > but meanwhile, I really want to answer this one simple question: >=20 > * WHY, on my local Apache setup on MacOS 10.6 / Webdna 7, is = [thisurl] reflecting the *pre-RewriteRule* URL? * >=20 > I need to emulate this. >=20 > What do you advise for trying to accomplish this? Can you point in = the direction of an example line in .htaccess, if that is what we are = talking about? >=20 > And/Or, I might understand this better, if I could see an example: > "...send a 301 (permanently moved) in response to the rewrite.." Bill, (or anyone) you said,=20 > [snip] "Otherwise the rewrite is invisible to the browser" [snip] But AFAIK "invisible to the browser", does not necessarily mean = "invisible to webdna" (who knows what all really goes on server side? = Do we really know _for sure_?). =20 Please consider this: a (remote) URL loaded in the browser: http://myDomain.com/by_country/India/pgName/123/ffff/ddd This ^^^ is a PHP-built site which I am working on ... and I am using = the 'Code-Igniter' framework for only everything in the 'by_country/' = directory of that site. =20 The Code-Igniter framework depends on a mode_rewrite = .htaccess/RewriteRule to direct ALL traffic of a site (or directory, = like in my case) through the front controller that you tell it to use. = Here is the relevant part of my .htaccess file in the 'by_country/' = directory: RewriteEngine On [snip] RewriteBase /by_country/ [snip] # Checks to see if the user is attempting to access a valid file, # such as an image or css document, if this isn't true it sends the # request to index.php RewriteCond %{REQUEST_FILENAME} !-f RewriteCond %{REQUEST_FILENAME} !-d RewriteRule ^(.*)$ index.php?/$1 [L] # If we don't have mod_rewrite installed, all 404's # can be sent to index.php, and everything works as normal. # Submitted by: ElliotHaughin ErrorDocument 404 /index.php =20 Everything works perfectly; The logic in my controller (and so PHP too, = in general) knows very well what was the original URL that was typed in = the browser, before the RewriteRule kicked in. So I speculate, "how?". In the PHP code I use to generate the HTML output for the browser, in my = controller-->View file, I added this code: echo 'SCRIPT_FILENAME=3D'.$_SERVER['SCRIPT_FILENAME'].'
'; echo 'PHP_SELF=3D'.$_SERVER['PHP_SELF'].'
'; echo 'REQUEST_URI=3D'.$_SERVER['REQUEST_URI'].'
'; ...which outputs this: = SCRIPT_FILENAME=3D/usr/home/myAcct/public_html/myDomain.com/by_country/ind= ex.php PHP_SELF=3D/by_country/index.php REQUEST_URI=3D/by_country/India/pgName/123/ffff/ddd So I think that perhaps that '$_SERVER['REQUEST_URI']' is how PHP = demonstrates to us that it knows what the URL was *before* the = RewriteRule, ... ...meanwhile I think perhaps webdna's '[thisurl]' (on the 2 remote = webdna 6 servers I tested today) is analogous to PHP's = '$_SERVER['PHP_SELF']', i.e. the result *after* the RewriteRule. =20 So then I think, "Can we have a webdna tag that is analogous to PHP's = '$_SERVER['REQUEST_URI']' ... which can output the URL as it was before = any RewriteRule, like PHP's '$_SERVER['REQUEST_URI']' does? But then I think, "Wait ! , we still have not addressed HOW, on my local = webdna 7 setup, [thisurl] is already behaving like PHP's = '$_SERVER['REQUEST_URI']' ! " How?! (I mean if the the RewriteRule is = supposed to be opaque to webdna, then how is my local webdna 7 seeing = the *original* URL?) Something is not consistent here. =20 I am totally guessing when I propose that it is because of the way = apache is configured (the mysterious black hole known as apache, that = even the server admins seem hesitant to mess with, let alone master). Clearly, PHP (running remotely and locally) can figure out what the URL = was before a RewriteRule.. and so can my local webdna 7 install. So = there must be a way to get the same behavior on webdna v.6 / v.7 ... = running on a remote server. I have a really sweet webdna framework that I just wrote which is = hinging on this... and would love to trade anything if I could get some = help to solve this. Thanks -Govinda= Associated Messages, from the most recent to the oldest:

    
  1. Re: [WebDNA] behavior of [thisurl] in the context of 'mod_rewrite' (Tom Duke 2012)
  2. Re: [WebDNA] behavior of [thisurl] in the context of 'mod_rewrite' (Govinda 2012)
  3. Re: [WebDNA] behavior of [thisurl] in the context of 'mod_rewrite' (Tom Duke 2012)
  4. Re: [WebDNA] behavior of [thisurl] in the context of 'mod_rewrite' (Govinda 2012)
  5. Re: [WebDNA] behavior of [thisurl] in the context of 'mod_rewrite' (William DeVaul 2012)
  6. Re: [WebDNA] behavior of [thisurl] in the context of 'mod_rewrite' (Tom Duke 2012)
  7. Re: [WebDNA] behavior of [thisurl] in the context of 'mod_rewrite' (Govinda 2012)
  8. Re: [WebDNA] behavior of [thisurl] in the context of 'mod_rewrite' (William DeVaul 2012)
  9. Re: [WebDNA] behavior of [thisurl] in the context of 'mod_rewrite' (Govinda 2012)
  10. Re: [WebDNA] behavior of [thisurl] in the context of 'mod_rewrite' (Govinda 2012)
  11. Re: [WebDNA] behavior of [thisurl] in the context of 'mod_rewrite' (William DeVaul 2012)
  12. Re: [WebDNA] behavior of [thisurl] in the context of 'mod_rewrite' (Govinda 2012)
  13. Re: [WebDNA] behavior of [thisurl] in the context of 'mod_rewrite' (Tom Duke 2012)
  14. Re: [WebDNA] behavior of [thisurl] in the context of 'mod_rewrite' (Govinda 2012)
  15. Re: [WebDNA] behavior of [thisurl] in the context of 'mod_rewrite' (William DeVaul 2012)
  16. Re: [WebDNA] behavior of [thisurl] in the context of 'mod_rewrite' (William DeVaul 2012)
  17. Re: [WebDNA] behavior of [thisurl] in the context of 'mod_rewrite' (Donovan Brooke 2012)
  18. Re: [WebDNA] behavior of [thisurl] in the context of 'mod_rewrite' (Govinda 2012)
  19. Re: [WebDNA] behavior of [thisurl] in the context of 'mod_rewrite' (Donovan Brooke 2012)
  20. Re: [WebDNA] behavior of [thisurl] in the context of 'mod_rewrite' (William DeVaul 2012)
  21. Re: [WebDNA] behavior of [thisurl] in the context of 'mod_rewrite' (Govinda 2012)
  22. Re: [WebDNA] behavior of [thisurl] in the context of 'mod_rewrite' (Donovan Brooke 2012)
  23. Re: [WebDNA] behavior of [thisurl] in the context of 'mod_rewrite' (Govinda 2012)
  24. Re: [WebDNA] behavior of [thisurl] in the context of 'mod_rewrite' (Govinda 2012)
  25. Re: [WebDNA] behavior of [thisurl] in the context of 'mod_rewrite' (William DeVaul 2012)
  26. Re: [WebDNA] behavior of [thisurl] in the context of 'mod_rewrite' (Govinda 2012)
  27. Re: [WebDNA] behavior of [thisurl] in the context of 'mod_rewrite' (christophe.billiottet@webdna.us 2012)
  28. [WebDNA] behavior of [thisurl] in the context of 'mod_rewrite' (Govinda 2012)
> I have question, ideas, possible solutions... >=20 > but meanwhile, I really want to answer this one simple question: >=20 > * WHY, on my local Apache setup on MacOS 10.6 / Webdna 7, is = [thisurl] reflecting the *pre-RewriteRule* URL? * >=20 > I need to emulate this. >=20 > What do you advise for trying to accomplish this? Can you point in = the direction of an example line in .htaccess, if that is what we are = talking about? >=20 > And/Or, I might understand this better, if I could see an example: > "...send a 301 (permanently moved) in response to the rewrite.." Bill, (or anyone) you said,=20 > [snip] "Otherwise the rewrite is invisible to the browser" [snip] But AFAIK "invisible to the browser", does not necessarily mean = "invisible to webdna" (who knows what all really goes on server side? = Do we really know _for sure_?). =20 Please consider this: a (remote) URL loaded in the browser: http://myDomain.com/by_country/India/pgName/123/ffff/ddd This ^^^ is a PHP-built site which I am working on ... and I am using = the 'Code-Igniter' framework for only everything in the 'by_country/' = directory of that site. =20 The Code-Igniter framework depends on a mode_rewrite = .htaccess/RewriteRule to direct ALL traffic of a site (or directory, = like in my case) through the front controller that you tell it to use. = Here is the relevant part of my .htaccess file in the 'by_country/' = directory: RewriteEngine On [snip] RewriteBase /by_country/ [snip] # Checks to see if the user is attempting to access a valid file, # such as an image or css document, if this isn't true it sends the # request to index.php RewriteCond %{REQUEST_FILENAME} !-f RewriteCond %{REQUEST_FILENAME} !-d RewriteRule ^(.*)$ index.php?/$1 [L] # If we don't have mod_rewrite installed, all 404's # can be sent to index.php, and everything works as normal. # Submitted by: ElliotHaughin ErrorDocument 404 /index.php =20 Everything works perfectly; The logic in my controller (and so PHP too, = in general) knows very well what was the original URL that was typed in = the browser, before the RewriteRule kicked in. So I speculate, "how?". In the PHP code I use to generate the HTML output for the browser, in my = controller-->View file, I added this code: echo 'SCRIPT_FILENAME=3D'.$_SERVER['SCRIPT_FILENAME'].'
'; echo 'PHP_SELF=3D'.$_SERVER['PHP_SELF'].'
'; echo 'REQUEST_URI=3D'.$_SERVER['REQUEST_URI'].'
'; ...which outputs this: = SCRIPT_FILENAME=3D/usr/home/myAcct/public_html/myDomain.com/by_country/ind= ex.php PHP_SELF=3D/by_country/index.php REQUEST_URI=3D/by_country/India/pgName/123/ffff/ddd So I think that perhaps that '$_SERVER['REQUEST_URI']' is how PHP = demonstrates to us that it knows what the URL was *before* the = RewriteRule, ... ...meanwhile I think perhaps webdna's '[thisurl]' (on the 2 remote = webdna 6 servers I tested today) is analogous to PHP's = '$_SERVER['PHP_SELF']', i.e. the result *after* the RewriteRule. =20 So then I think, "Can we have a webdna tag that is analogous to PHP's = '$_SERVER['REQUEST_URI']' ... which can output the URL as it was before = any RewriteRule, like PHP's '$_SERVER['REQUEST_URI']' does? But then I think, "Wait ! , we still have not addressed HOW, on my local = webdna 7 setup, [thisurl] is already behaving like PHP's = '$_SERVER['REQUEST_URI']' ! " How?! (I mean if the the RewriteRule is = supposed to be opaque to webdna, then how is my local webdna 7 seeing = the *original* URL?) Something is not consistent here. =20 I am totally guessing when I propose that it is because of the way = apache is configured (the mysterious black hole known as apache, that = even the server admins seem hesitant to mess with, let alone master). Clearly, PHP (running remotely and locally) can figure out what the URL = was before a RewriteRule.. and so can my local webdna 7 install. So = there must be a way to get the same behavior on webdna v.6 / v.7 ... = running on a remote server. I have a really sweet webdna framework that I just wrote which is = hinging on this... and would love to trade anything if I could get some = help to solve this. Thanks -Govinda= Govinda

DOWNLOAD WEBDNA NOW!

Top Articles:

Talk List

The WebDNA community talk-list is the best place to get some help: several hundred extremely proficient programmers with an excellent knowledge of WebDNA and an excellent spirit will deliver all the tips and tricks you can imagine...

Related Readings:

categories and subcategories (2004) Nested tags count question (1997) What am I missing (1997) [WriteFile] problems (1997) SendMail context not working on CentOS 4 (2007) CMS (2003) Questions To Answer (1997) Questions To Answer (1997) WebCat2 - Getting to the browser's username/password data (1997) Instructions for Digest (1997) RE: Major Security Hole IIS NT (1998) NewCart+Search with one click ? (1997) Not really WebCat - need HTML Grider (1997) WCS Newbie question (1997) help with duplicate records posted (1998) Search in 2 or more catalogs (1997) Draft Manual, Tutorial, and more (1997) Getting total number of items ordered (1997) Line items in table cells (1997) 2nd WebCatalog2 Feature Request (1996)