PHP伪静态的四种方法总结
创始人
2024-06-12 10:41:01
0

PHP伪静态的使用主要是为了隐藏传递的参数名。今天我们向大家介绍的PHP伪静态的方法总共有四种,希望大家能够通过这四种方法进一步加深对PHP伪静态的了解。

#t#以下就是全部方法代码:

  1.  
  2. //伪静态方法一  
  3.  
  4. // localhost/php100/test.php?id|1@action|2  
  5. $Php2Html_FileUrl = $_SERVER["REQUEST_URI"];  
  6. echo $Php2Html_FileUrl."
    ";// /php100/test.php?id|1@action|2  
  7. $Php2Html_UrlString = str_replace("?","",str_replace("/", "", strrchr(strrchr($Php2Html_FileUrl, "/"),"?")));  
  8. echo $Php2Html_UrlString."
    ";// id|1@action|2  
  9. $Php2Html_UrlQueryStrList = explode("@", $Php2Html_UrlString);  
  10. print_r($Php2Html_UrlQueryStrList);// Array ( [0] => id|1 [1] => action|2 )  
  11. echo "
    ";  
  12. foreach($Php2Html_UrlQueryStrList as $Php2Html_UrlQueryStr)  
  13. {  
  14. $Php2Html_TmpArray = explode("|", $Php2Html_UrlQueryStr);  
  15. print_r($Php2Html_TmpArray);// Array ( [0] => id [1] => 1 ) ; Array ( [0] => action [1] => 2 )  
  16. echo "
    ";  
  17. $_GET[$Php2Html_TmpArray[0]] = $Php2Html_TmpArray[1];  
  18. }  
  19. //echo '假静态:$_GET变量 />';  
  20. print_r($_GET); // Array ( [id|1@action|2] => [id] => 1 [action] => 2 )  
  21. echo "
    ";  
  22. echo "
    ";  
  23. echo $_GET[id]."
    ";// 1  
  24. echo $_GET[action];// 2  
  25. ?> 

 

  1.  
  2. //伪静态方法二  
  3.  
  4. // localhost/php100/test.php/1/2  
  5. $filename = basename($_SERVER['SCRIPT_NAME']);  
  6. echo $_SERVER['SCRIPT_NAME']."
    ";// /php100/test.php  
  7. echo $filename."
    ";// test.php  
  8.  
  9. if(strtolower($filename)=='test.php'){  
  10.  if(!empty($_GET[id])){  
  11.   $id=intval($_GET[id]);  
  12.   echo $id."
    ";  
  13.   $action=intval($_GET[action]);  
  14.   echo $action."
    ";  
  15.  }else{  
  16.   $nav=$_SERVER['REQUEST_URI'];  
  17.   echo "1:".$nav."
    ";// /php100/test.php/1/2  
  18.   $script=$_SERVER['SCRIPT_NAME'];  
  19.   echo "2:".$script."
    ";// /php100/test.php  
  20.   $nav=ereg_replace("^$script","",urldecode($nav));  
  21.   echo $nav."
    "; // /1/2  
  22.   $vars=explode("/",$nav);  
  23.   print_r($vars);// Array ( [0] => [1] => 1 [2] => 2 )  
  24.   echo "
    ";  
  25.   $id=intval($vars[1]);  
  26.   $action=intval($vars[2]);  
  27.  }  
  28.  echo $id.'&'.$action;  
  29. }  
  30. ?> 

 

  1.  
  2. //伪静态方法三  
  3.  
  4.  
  5. function mod_rewrite(){  
  6. global $_GET;  
  7. $nav=$_SERVER["REQUEST_URI"];  
  8. echo $nav."
    ";  
  9. $script_name=$_SERVER["SCRIPT_NAME"];  
  10. echo $script_name."
    ";  
  11. $nav=substr(ereg_replace("^$script_name","",urldecode($nav)),1);  
  12. echo $nav."
    ";  
  13. $nav=preg_replace("/^.ht(m){1}(l){0,1}$/","",$nav);//这句是去掉尾部的.html或.htm  
  14. echo $nav."
    ";  
  15. $vars = explode("/",$nav);  
  16. print_r($vars);  
  17. echo "
    ";  
  18. for($i=0;$i($vars);$i+=2){  
  19. $_GET["$vars[$i]"]=$vars[$i+1];  
  20. }  
  21. return $_GET;  
  22. }  
  23. mod_rewrite();  
  24. $year=$_GET["year"];//结果为'2006'  
  25. echo $year."
    ";  
  26. $action=$_GET["action"];//结果为'_add'  
  27. echo $action;  
  28. ?> 

  1.  
  2. //伪静态方法四  
  3.  
  4. //利用server变量 取得PATH_INFO信息 该例中为 /1,100,8630.html   也就是执行脚本名后面的部分  
  5. if(@$path_info =$_SERVER["PATH_INFO"]){  
  6. //正则匹配一下参数  
  7. if(preg_match("/\/(\d+),(\d+),(\d+)\.html/si",$path_info,$arr_path)){  
  8. $gid     =intval($arr_path[1]); //取得值 1  
  9. $sid     =intval($arr_path[2]);   //取得值100  
  10. $softid   =intval($arr_path[3]);   //取得值8630  
  11. }else die("Path:Error!");  
  12. //相当于soft.php?gid=1&sid=100&softid=8630 
  13. }else die('Path:Nothing!');  
  14. ?> 

以上就是本文介绍的四种PHP伪静态的方法,希望对大家有所帮助。

文章来源:http://blog.sina.com.cn/s/blog_4a657b6b0100gdnk.html

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...
2012年第四季度互联网状况报... [[71653]]  北京时间4月25日消息,据国外媒体报道,全球知名的云平台公司Akamai Te...