国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > ASP > 正文

ASP中實現的URLEncode、URLDecode自定義函數

2024-05-04 11:09:56
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了ASP中實現的URLEncode、URLDecode自定義函數,和ASP自帶的server.urlencode是不一樣的哦,需要的朋友可以參考下

在做ajax中的post時,發現在服務器端取得數據時總是亂碼,網上看了些解決方法也搞不定,我post過去時是xml形式,由于亂碼服務器端xml也解析不了或出錯。于是在post前先把它編碼,到服務器端再解碼,這樣問題解決了,但是要是數據很大時估計會很影響速度。

雖然ASP中的request會自動解碼經過url編碼的字符串,但是Request.BinaryRead(Request.TotalBytes)取得post數據時卻不會解碼,所以要進行解碼。

下面是我找到的一個ASP中server.urlencode函數的解碼函數

復制代碼 代碼如下:


Function URLDecode(enStr)
  dim deStr,strSpecial
  dim c,i,v
    deStr=""
    strSpecial="!""#$%&'()*+,.-_/:;< =>?@[/]^`{|}~%"
    for i=1 to len(enStr)
      c=Mid(enStr,i,1)
      if c="%" then
        v=eval("&h"+Mid(enStr,i+1,2))
        if inStr(strSpecial,chr(v))>0 then
          deStr=deStr&chr(v)
          i=i+2
        else
          v=eval("&h"+ Mid(enStr,i+1,2) + Mid(enStr,i+4,2))
          deStr=deStr & chr(v)
          i=i+5
        end if
      else
        if c="+" then
          deStr=deStr&" "
        else
          deStr=deStr&c
        end if
      end if
    next
    URLDecode=deStr
End function

再附一個編碼函數,這個與server.urlencode不一樣之處是:server.urlencode會將html或xml等標簽,如
也會進行編碼,而下面這個函數不會。我是用下面的進行編碼,再解碼,因為我用post時用xml的。

復制代碼 代碼如下:


private Function URLEncoding(vstrIn)
    strReturn = ""
    For i = 1 To Len(vstrIn)
    ThisChr = Mid(vStrIn,i,1)
    If Abs(Asc(ThisChr)) < &HFF Then
    strReturn = strReturn & ThisChr
    Else
    innerCode = Asc(ThisChr)
    If innerCode < 0 Then
    innerCode = innerCode + &H10000
    End If
    Hight8 = (innerCode And &HFF00)/ &HFF
    Low8 = innerCode And &HFF
    strReturn = strReturn & "%" & Hex(Hight8) & "%" & Hex(Low8)
    End If
    Next
    URLEncoding = strReturn
  End Function

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 齐齐哈尔市| 苏尼特左旗| 环江| 礼泉县| 临沧市| 宜丰县| 泰来县| 长兴县| 东光县| 罗定市| 新丰县| 景宁| 高陵县| 普陀区| 濮阳市| 河北省| 库尔勒市| 会东县| 台北市| 康乐县| 怀柔区| 化隆| 金阳县| 商水县| 九台市| 阳山县| 民和| 南昌县| 高密市| 台南县| 美姑县| 岗巴县| 明水县| 永仁县| 昌吉市| 陇南市| 开封市| 化隆| 济宁市| 浏阳市| 二连浩特市|