直播中
特殊特殊字符的含義
————————————————————————————
字符 特殊字符的含義 URL編碼
# 用來標(biāo)志特定的文檔位置 %23
% 對特殊字符進行編碼 %25
& 分隔不同的變量值對 %26
+ 在變量值中表示空格 %2B
\ 表示目錄路徑 %2F
= 用來連接鍵和值 %3D
? 表示查詢字符串的開始 %3F
當(dāng)鍵值中含有以上列表中的一些字符時就無法準(zhǔn)確的接收其中的值。
<!--文件名為01.asp-->
<%
'定義含有特殊字符的字符串
str="parameter=#%&+\=?value</html>"
'用URLEncode方法進行編碼
strurlencode=server.URLEncode(str)
'用HTMLEncode方法進行編碼
strhtmlencode=server.HTMLEncode (str)
'顯示所有的querysting字符
Response.Write "<b>QueryString:<b>"
Response.Write Request.QueryString
'顯示傳遞的參數(shù)
Response.Write "<br><b>Parameter is:</b>" & str &"<br>"
Response.Write "<b>QueryParameter=</b>"
Response.Write Request.QueryString ("str")
%>
<HTML>
<HEAD>
<META NAME="GENERATOR" Content="Microsoft Visual Studio 6.0">
<TITLE></TITLE>
</HEAD>
<BODY>
<P><a href="01.asp?str=<%=strurlencode%>">Str UrlEncode Method</a></P>
<P> </P>
<P><a href="01.asp?str=<%=strhtmlencode%>">Str HtmlEncode Method</a></P>
</BODY>
</HTML>
顯示結(jié)果
QueryString:
Parameter is:parameter=#%&+\=?value
QueryParameter=
Str UrlEncode Method
Str HtmlEncode Method
點擊連接1,結(jié)果
QueryString:str=parameter%3D%23%25%26%2B%5C%3D%3Fvalue%3C%2Fhtml%3E
Parameter is:parameter=#%&+\=?value
QueryParameter=parameter=#%&+\=?value
Str UrlEncode Method
Str HtmlEncode Method
此時我們發(fā)現(xiàn)好象參數(shù)值中的</html>沒有能正確接收到,當(dāng)我們查看原代碼的時候就會發(fā)現(xiàn)其實已經(jīng)準(zhǔn)確的接收到了,原因是“</html>”是標(biāo)準(zhǔn)html tag ,經(jīng)過瀏覽器解釋后就不會顯示出來了。
點擊連接2,結(jié)果
QueryString:str=parameter=
Parameter is:parameter=#%&+\=?value
QueryParameter=parameter=
Str UrlEncode Method
Str HtmlEncode Method
此時就會發(fā)現(xiàn)在#后面沒有能正確接收到,而是被解釋為錨點的開始,在"#"后面的為錨的名稱。
結(jié)論:在含有以上列表中具有特殊功能的特殊字符的字符串,作為參數(shù)用GET方式傳遞時,只需要用URLENCODE方法處理一下就可以拉。如果不想讓瀏覽者看到含后HTML TAG的字符串的具體值值是,我們可以用HTMLENCODE處理一下。
PHP中用函數(shù)urlencode()就可以拉,這里就不在舉例了。