php伪静态的几种实现代码的例子

发布时间:2020-09-15编辑:脚本学堂
本文介绍下php中实现伪静态的几种方法与代码,条条大路通罗马啊,大家可以参考一下,举一返三,写出更优秀的伪静态规则哦。

代码3,
 

复制代码 代码示例:
<?php  
//伪静态方法三
//http://www.jb200.com
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;  
?>  

 
 
代码4,
 

复制代码 代码示例:
<?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!');  
?>  
 

 
下面这个算是赠送大家的,哈哈,不是讲伪静态的,讲php防注入的,估计作者也是喝多了,哈哈!!
php防止恶意写入后台数据库;  
 

复制代码 代码示例:
<?php
//防注入函数  
function inject_check($sql_str){  
 $check=eregi('select|insert|update|delete|'|/*|*|../|./|union|into|load_file 
|outfile', $sql_str);  
if($check){  
 echo "输入非法内容";  
 exit();  
 }else{  
  return $sql_str;  
 }  
}  
//接收传递参数后进行转换  
$_GET[type]=inject_check($_GET[type]);  
//之后再使用转换后的参数
?>