您好,登錄后才能下訂單哦!
這篇“php如何隱藏傳參”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內容,內容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“php如何隱藏傳參”文章吧。
php隱藏傳參的方法:1、創建一個PHP示例文件;2、通過“$_SERVER["REQUEST_URI"];”獲取URI;3、通過“foreach($Php2Html_UrlQueryStrList as $Php2Html_UrlQueryStr) {...}”等方法實現偽靜態隱藏傳參即可。
php 怎么隱藏傳參?
PHP 偽靜態 隱藏傳參 PHP 偽靜態隱藏傳遞參數名的四種方法
想了解PHP 偽靜態隱藏傳遞參數名的四種方法的相關內容嗎,在本文為您仔細講解PHP 偽靜態 隱藏傳參的相關知識和一些Code實例,歡迎閱讀和指正,我們先劃重點: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!'); ?>
以上就是關于“php如何隱藏傳參”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。