bl双性强迫侵犯h_国产在线观看人成激情视频_蜜芽188_被诱拐的少孩全彩啪啪漫画

php中如何解決url傳遞中文字符,特殊危險字符-創新互聯

這篇文章主要介紹php中如何解決url傳遞中文字符,特殊危險字符,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

創新互聯公司堅持“要么做到,要么別承諾”的工作理念,服務領域包括:成都做網站、網站建設、外貿營銷網站建設、企業官網、英文網站、手機端網站、網站推廣等服務,滿足客戶于互聯網時代的七里河網站設計、移動媒體設計的需求,幫助企業找到有效的互聯網解決方案。努力成為您成熟可靠的網絡建設合作伙伴!

我們需要在url中傳遞中文字符或是其它的html等特殊字符,似乎總會有各種亂,不同的瀏覽器對他們的編碼又不一樣,

對于中文,一般的做法是:

把這些文本字符串傳給url之前,先進行urlencode($text)一下;

但是對于一些很“危險”的字符,比如說html字符,甚至是SQL注入相關的字符,如果很明顯的傳給系統,出于安全考慮,系統一般都會把它們過濾掉的。

現在,我們需要這些危險字符,該這么辦?

我想到的辦法是 先給它們 base64_encode($text) 編碼,到服務端時,又給它們 base64_decode($text) 解碼,

貌似很完美,但是在使用的過程中又遇到一個問題,base64_encode 編碼后的字符串中含有 "/", "+", "=" 等字符,


base64_encode()函數由于要在url中傳用戶輸入觀點(少量的內容),當用戶提交(post提交)過來的是一個數組.所以我把觀點用bse64_encode()函數給加密.當跳轉到處理頁面時,我再給get接收,這時出現兩邊加密的數據不對.少了一個+字符.

用戶提交加密:

tPK9tNPNyKUsuse6xyYjNDY7JiM0NjsufMavwcEhfMyrxq/BwcHLLMjDztLO3tPvLNXmz+vI69ehsKEhfHw=


在處理頁面用get接收到的:

tPK9tNPNyKUsuse6xyYjNDY7JiM0NjsufMavwcEhfMyrxq/BwcHLLMjDztLO3tPvLNXmz vI69ehsKEhfHw=

對比找到少了一個加號,不知道是什么原因導制的(猜想可能是get時,+字符可能不能得到吧!).還請高手指點.

這些字符在url編碼中又是特殊字符,比如 "+" ,它就表示 “空格”,但是不同的瀏覽器對“空格”的編碼又不一樣,有的是用“+”表示,有的是用“20%”表示,也就是說,讓這些base64_encode編碼后的字符串在url中傳遞,用不同的瀏覽器去瀏覽時,服務端得到值不一樣。

于是乎,想到了一個折中辦法,先將這些base64編碼后的特殊字符替換掉,到服務端后,又替換回來:


解決方法:

一.在用戶提交加密串的時間,我把+字符給換成別的字字符.如:str_replace('+', '_', $content);
二.在處理頁面再次轉換一次:如:str_replace('_', '+', $content);

復制代碼 代碼如下:


function base_encode($str) {
        $src  = array("/","+","=");
        $dist = array("_a","_b","_c");
        $old  = base64_encode($str);
        $new  = str_replace($src,$dist,$old);
        return $new;
}

function base_decode($str) {
        $src = array("_a","_b","_c");
        $dist  = array("/","+","=");
        $old  = str_replace($src,$dist,$str);
        $new = base64_decode($old);
        return $new;
}



下面是在瀏覽器中得到的效果

xOO6w6Osuf65_aiy_atL_b00Ke5_b8jnus6ho6GjoaM_c

urldecode實例方法很簡單

urldecode ( string $str )
解碼給出的已編碼字符串中的任何 %##。返回解碼后的字符串。

Example #1 urldecode() 例子

復制代碼 代碼如下:


<?php
$a = explode('&', $QUERY_STRING);
$i = 0;
while ($i < count($a)) {
    $b = split('=', $a[$i]);
    echo 'Value for parameter ', htmlspecialchars(urldecode($b[0])),
         ' is ', htmlspecialchars(urldecode($b[1])), "<br /> ";
    $i++;
}
?>


以上是“php中如何解決url傳遞中文字符,特殊危險字符”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注創新互聯行業資訊頻道!

網站名稱:php中如何解決url傳遞中文字符,特殊危險字符-創新互聯
網站URL:http://vcdvsql.cn/article2/ddjdoc.html

成都網站建設公司_創新互聯,為您提供網站排名云服務器網站改版靜態網站自適應網站網站制作

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

成都網頁設計公司