php伪静态设置

<?php 
//伪静态方法一  
 
// localhost/php100/test.php?id|1@action|2  
$Php2Html_FileUrl = $_SERVER["REQUEST_URI"];  
echo $Php2Html_FileUrl."<br>";// /php100/test.php?id|1@action|2  
$Php2Html_UrlString = str_replace("?","",str_replace("/", "", strrchr(strrchr($Php2Html_FileUrl, "/"),"?")));  
echo $Php2Html_UrlString."<br>";// id|1@action|2  
$Php2Html_UrlQueryStrList = explode("@", $Php2Html_UrlString);  
print_r($Php2Html_UrlQueryStrList);// Array ( [0] => id|1 [1] => action|2 )  
echo "<br>";  
foreach($Php2Html_UrlQueryStrList as $Php2Html_UrlQueryStr)  
{  
$Php2Html_TmpArray = explode("|", $Php2Html_UrlQueryStr);  
print_r($Php2Html_TmpArray);// Array ( [0] => id [1] => 1 ) ; Array ( [0] => action [1] => 2 )  
echo "<br>";  
$_GET[$Php2Html_TmpArray[0]] = $Php2Html_TmpArray[1];  
}  
//echo '假静态:$_GET变量<br />';  
print_r($_GET); // Array ( [id|1@action|2] => [id] => 1 [action] => 2 )  
echo "<br>";  
echo "<hr>";  
echo $_GET[id]."<br>";// 1  
echo $_GET[action];// 2  
?> 


<?php 
//伪静态方法二  
 
// localhost/php100/test.php/1/2  
$filename = basename($_SERVER['SCRIPT_NAME']);  
echo $_SERVER['SCRIPT_NAME']."<br>";// /php100/test.php  
echo $filename."<br>";// test.php  
 
if(strtolower($filename)=='test.php'){  
 if(!empty($_GET[id])){  
  $id=intval($_GET[id]);  
  echo $id."<br>";  
  $action=intval($_GET[action]);  
  echo $action."<br>";  
 }else{  
  $nav=$_SERVER['REQUEST_URI'];  
  echo "1:".$nav."<br>";// /php100/test.php/1/2  
  $script=$_SERVER['SCRIPT_NAME'];  
  echo "2:".$script."<br>";// /php100/test.php  
  $nav=ereg_replace("^$script","",urldecode($nav));  
  echo $nav."<br>"; // /1/2  
  $vars=explode("/",$nav);  
  print_r($vars);// Array ( [0] => [1] => 1 [2] => 2 )  
  echo "<br>";  
  $id=intval($vars[1]);  
  $action=intval($vars[2]);  
 }  
 echo $id.'&'.$action;  
}  
?> 


<?php 
//伪静态方法三  
 
 
function mod_rewrite(){  
global $_GET;  
$nav=$_SERVER["REQUEST_URI"];  
echo $nav."<br>";  
$script_name=$_SERVER["SCRIPT_NAME"];  
echo $script_name."<br>";  
$nav=substr(ereg_replace("^$script_name","",urldecode($nav)),1);  
echo $nav."<br>";  
$nav=preg_replace("/^.ht(m){1}(l){0,1}$/","",$nav);//这句是去掉尾部的.html或.htm  
echo $nav."<br>";  
$vars = explode("/",$nav);  
print_r($vars);  
echo "<br>";  
for($i=0;$i<Count($vars);$i+=2){  
$_GET["$vars[$i]"]=$vars[$i+1];  
}  
return $_GET;  
}  
mod_rewrite();  
$year=$_GET["year"];//结果为'2006'  
echo $year."<br>";  
$action=$_GET["action"];//结果为'_add'  
echo $action;  
?> 


<?php 
//伪静态方法四  
 
//利用server变量 取得PATH_INFO信息 该例中为 /1,100,8630.html   也就是执行脚本名后面的部分  
if(@$path_info =$_SERVER["PATH_INFO"]){  
//正则匹配一下参数  
if(preg_match("/\/(\d+),(\d+),(\d+)\.html/si",$path_info,$arr_path)){  
$gid     =intval($arr_path[1]); //取得值 1  
$sid     =intval($arr_path[2]);   //取得值100  
$softid   =intval($arr_path[3]);   //取得值8630  
}else die("Path:Error!");  
//相当于soft.php?gid=1&sid=100&softid=8630 
}else die('Path:Nothing!');  
?> 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值