伪静态方法一:
代码如下:
PHP
//伪静态方法一
// localhost/PHP100/test.PHP?id|1@action|2
$PHP2Html_FileUrl = $_SERVER["REQUEST_URI"];
echo $PHP2Html_FileUrl."
";
// /PHP100/test.PHP?id|1@action|2
$PHP2Html_UrlString = str_replace("?","",str_replace("/",strrchr(strrchr($PHP2Html_FileUrl,"/"),"?")));
echo $PHP2Html_UrlString."
";
// id|1@action|2
$PHP2Html_UrlQueryStrList = explode("@",$PHP2Html_UrlString);
print_r($PHP2Html_UrlQueryStrList);
// Array ( [0] => id|1 [1] => action|2 ) echo "
";
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 "
";
$_GET[$PHP2Html_TmpArray[0]] = $PHP2Html_TmpArray[1];
}
//echo '假静态:$_GET变量
';
print_r($_GET);
// Array ( [id|1@action|2] => [id] => 1 [action] => 2 ) echo "
";
echo "";
echo $_GET[id]."
";
// 1 echo $_GET[action];
// 2
?>
//伪静态方法一
// localhost/PHP100/test.PHP?id|1@action|2
$PHP2Html_FileUrl = $_SERVER["REQUEST_URI"];
echo $PHP2Html_FileUrl."
";
// /PHP100/test.PHP?id|1@action|2
$PHP2Html_UrlString = str_replace("?","",str_replace("/",strrchr(strrchr($PHP2Html_FileUrl,"/"),"?")));
echo $PHP2Html_UrlString."
";
// id|1@action|2
$PHP2Html_UrlQueryStrList = explode("@",$PHP2Html_UrlString);
print_r($PHP2Html_UrlQueryStrList);
// Array ( [0] => id|1 [1] => action|2 ) echo "
";
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 "
";
$_GET[$PHP2Html_TmpArray[0]] = $PHP2Html_TmpArray[1];
}
//echo '假静态:$_GET变量
';
print_r($_GET);
// Array ( [id|1@action|2] => [id] => 1 [action] => 2 ) echo "
";
echo "";
echo $_GET[id]."
";
// 1 echo $_GET[action];
// 2
?>
代码如下:
伪静态方法二:
PHP //伪静态方法二
// localhost/PHP100/test.PHP/1/2
$filename = basename($_SERVER['SCRIPT_NAME']);
echo $_SERVER['SCRIPT_NAME']."
";// /PHP100/test.PHP
echo $filename."
";// test.PHP
if(strtolower($filename)=='test.PHP'){
if(!empty($_GET[id])){
$id=intval($_GET[id]);
echo $id."
";
$action=intval($_GET[action]);
echo $action."
";
}else{
$nav=$_SERVER['REQUEST_URI'];
echo "1:".$nav."
";// /PHP100/test.PHP/1/2
$script=$_SERVER['SCRIPT_NAME'];
echo "2:".$script."
";// /PHP100/test.PHP
$nav=ereg_replace("^$script",urldecode($nav));
echo $nav."
"; // /1/2
$vars=explode("/",$nav);
print_r($vars);// Array ( [0] => [1] => 1 [2] => 2 )
echo "
";
$id=intval($vars[1]);
$action=intval($vars[2]);
}
echo $id.'&'.$action;
}
?>
伪静态方法三:
代码如下:
PHP
//伪静态方法三
function mod_rewrite(){
global $_GET;
$nav=$_SERVER["REQUEST_URI"];
echo $nav."
";
$script_name=$_SERVER["SCRIPT_NAME"];
echo $script_name."
";
$nav=substr(ereg_replace("^$script_name",urldecode($nav)),1);
echo $nav."
";
$nav=preg_replace("/^.ht(m){1}(l){0,1}$/",$nav);//这句是去掉尾部的.html或.htm
echo $nav."
";
$vars = explode("/",$nav);
print_r($vars);
echo "
";
for($i=0;$i$_GET["$vars[$i]"]=$vars[$i+1];
}
return $_GET;
}
mod_rewrite();
$year=$_GET["year"];//结果为'2006'
echo $year."
";
$action=$_GET["action"];//结果为'_add'
echo $action;
?>
//伪静态方法三
function mod_rewrite(){
global $_GET;
$nav=$_SERVER["REQUEST_URI"];
echo $nav."
";
$script_name=$_SERVER["SCRIPT_NAME"];
echo $script_name."
";
$nav=substr(ereg_replace("^$script_name",urldecode($nav)),1);
echo $nav."
";
$nav=preg_replace("/^.ht(m){1}(l){0,1}$/",$nav);//这句是去掉尾部的.html或.htm
echo $nav."
";
$vars = explode("/",$nav);
print_r($vars);
echo "
";
for($i=0;$i
}
return $_GET;
}
mod_rewrite();
$year=$_GET["year"];//结果为'2006'
echo $year."
";
$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!');
?>
//伪静态方法四
//利用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!');
?>
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。