伪静态php隐藏后缀名,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

?>

伪静态方法二:<?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;

}

?>

伪静态方法三:

//伪静态方法三

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;

?>

伪静态方法四:

//伪静态方法四

//利用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、付费专栏及课程。

余额充值