PHP 僞靜態及參數隱藏傳遞的幾種方法

最新PHP 僞靜態及參數隱藏傳遞的幾種方法php

如下是三零網爲你們整理的最新PHP 僞靜態及參數隱藏傳遞的幾種方法的文章,但願你們可以喜歡!html

如下介紹4種在僞靜態下傳遞參數的方法:
僞靜態方法一:ide


<?phpurl

// 僞靜態方法一
// localhost/php100/test.php?id|1@action|2
$Php2Html_FileUrl = $_SERVER["REQUEST_URI"];spa

echo $Php2Html_FileUrl . "<br>";code

// /php100/test.php?id|1@action|2
$Php2Html_UrlString = str_replace("?", "", str_replace("/", "", strrchr(strrchr($Php2Html_FileUrl, "/"), "?")));orm

echo $Php2Html_UrlString . "<br>";server

// id|1@action|2
$Php2Html_UrlQueryStrList = explode("@", $Php2Html_UrlString);htm

print_r($Php2Html_UrlQueryStrList);ip

// 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!');

?>


轉載來自:http://www.q3060.com/list3/list117/277.html

相關文章
相關標籤/搜索