对Query字段进行Encode操作的一点看法
文章类别:
asp | 发表日期:2008-10-5 20:55:00
对Query字段进行Encode操作:
利用一个Query字段在不同主页间传递信息时必须进行Encode操作(注意是在进行不同页面传递),因为如果不这样做,你很可能使得接受信息的那边接受到一些你所不期望的奇怪字串。
注:其实如果Query字段中没有一些特殊字符,例如空格和标点符号等,那么也可以不进行Encode操作。
其实,这种Encode操作是十分容易的,有一个特定的方法来执行这种操作:那就是Server.URLEncode()方法,看下面这个例子:
<a href=“response.asp?Message=<%=Server.URLEncode(“This Query String has been URL encoded.”)%>“>点击这里</a>
请注意:不要对Query字段的名称以及等号进行Encode操作,只需要将其值进行Encode操作就可以了。
进行了encode操作后,Query字段如下:
Message=This+Query+String+has+been+URL+encoded%2E
不需要考虑对上面的字串再进行解码,Active Server Page会自动进行这样的处理。例如,假设response.asp中有这样的脚本:
<%=Request.QueryString(“message”)%>
这时,显示结果为:
This Query String has been URL encoded.