一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

php中url傳遞中文字符,特殊危險(xiǎn)字符的解決方法

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

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

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

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

現(xiàn)在,我們需要這些危險(xiǎn)字符,該這么辦?

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

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


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

用戶提交加密:

tPK9tNPNyKUsuse6xyYjNDY7JiM0NjsufMavwcEhfMyrxq/BwcHLLMjDztLO3tPvLNXmz+vI69ehsKEhfHw=


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

tPK9tNPNyKUsuse6xyYjNDY7JiM0NjsufMavwcEhfMyrxq/BwcHLLMjDztLO3tPvLNXmz vI69ehsKEhfHw=

對比找到少了一個(gè)加號,不知道是什么原因?qū)е频?猜想可能是get時(shí),+字符可能不能得到吧!).還請高手指點(diǎn).

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

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


解決方法:

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

復(fù)制代碼 代碼如下:
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實(shí)例方法很簡單

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

Example #1 urldecode() 例子

復(fù)制代碼 代碼如下:
<?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技術(shù)php中url傳遞中文字符,特殊危險(xiǎn)字符的解決方法,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 亚洲欧美一级久久精品 | 一区二区视频在线观看免费的 | 国产精品免费看久久久麻豆 | 久久精品亚洲精品国产色婷 | 黄色wwwcom | 亚洲黄色免费 | 亚洲精品tv久久久久 | 国内精品久久久久久久亚洲 | 热久久国产欧美一区二区精品 | 一区二区三区亚洲视频 | 免费成人小视频 | 韩国三级久久网 | 国内精品视频在线播放 | 久久福利国产 | 日本美女视频韩国视频网站免费 | 色欧美在线视频 | 久久精品国产无限资源 | 国产免费久久精品99久久 | 韩国一级做a爰片性色毛片 韩国一区二区三区 | 欧美成人午夜视频免看 | 亚洲国产精品久久久久秋霞小 | 婷婷亚洲国产成人精品性色 | 5151hh四虎国产精品 | 在线看的黄色网址 | 色老板在线免费 | 日本一区二区三区四区公司 | 国产精品亚洲国产 | 精品久久久久久久久免费影院 | 欧美日韩色视频在线观看 | 大胸国产精品视频 | 亚洲精品网站在线 | 91短视频在线 | 欧美专区一区 | 欧美激情免费a视频 | 日本精品久久久久久久久免费 | 精品日本亚洲一区二区三区 | 国产剧情在线视频 | 成人国产激情福利久久精品 | 爱搞逼综合 | 在线观看免费视频网站色 | 亚欧三级 |