| 编程中国 | 业界新闻 | 技术文章 | 视频教程 | 下载频道 | 程序源码 | 个人空间 | 编程论坛
全能ASP/PHP/ASP.NET主机,支持月付专业 MSSQL 数据库空间,支持月付专业 MySQL 数据库空间,支持月付买域名,送MP3、MP4
高端软件开发 = 年薪十万不是梦赛孚耐:软件保护加密专家身份认证令牌USB KEY买空间,免费送域名(厦门中资源)
共有 159 人关注过本帖
标题:帮忙解释这段代码
收藏  订阅  推荐  打印 
vip99
Rank: 1
等级:新手上路
帖子:6
积分:174
注册:2008-8-31
帮忙解释这段代码

Private Sub Command1_Click()
Text1.Text = UnEnscape(Text2.Text)
End Sub

Private Sub Command2_Click()
Text2.Text = Enscape(Text1.Text)

End Sub

Private Sub Form_Load()
Command1.Enabled = False
Command2.Enabled = False

End Sub

Private Sub Form_MouseMove(Button As Integer, Shift As Integer, X As Single, Y As Single)
Label3.ForeColor = RGB(255, 255, 255)

End Sub

Private Sub Label3_Click()
MsgBox "版权所有:黑蚂蚁" + vbCrLf + "2008-9-12 17:22", vbOKOnly, "关于"
End Sub


Private Sub Label3_MouseMove(Button As Integer, Shift As Integer, X As Single, Y As Single)
Label3.ForeColor = RGB(100, 200, 20)
End Sub

Private Sub Label3_MouseUp(Button As Integer, Shift As Integer, X As Single, Y As Single)
Label3.ForeColor = RGB(255, 255, 255)

End Sub

Private Sub Text1_Change()
Command1.Enabled = False
Command2.Enabled = True

End Sub


Private Sub Text2_Change()
Command1.Enabled = True
Command2.Enabled = False
End Sub
Function ChangeToChar(CharAsc As Long)
On Error GoTo OnError
       ChangeToChar = ChrW(CharAsc)
       Exit Function
OnError:
       Exit Function
End Function
Function UnEnscape(enstr As String) As String
Dim DataLen As Long
Dim TempData As String
Dim filepoint As Long
Dim ChinaText As Long
DataLen = Len(enstr)
filepoint = 1
Do While (filepoint <= DataLen)
    If Mid(enstr, filepoint, 1) = "%" Then
       If Mid(enstr, filepoint + 1, 1) = "u" Then
       On Error Resume Next
       ChinaText = CLng("&H" + Mid(enstr, filepoint + 2, 4))
       TempData = TempData + ChangeToChar(ChinaText)
       filepoint = filepoint + 6
       Else
       TempData = TempData + ChrW(CLng("&H" + Mid(enstr, filepoint + 1, 2)))
       filepoint = filepoint + 3
       End If
     Else
       TempData = TempData + Mid(enstr, filepoint, 1)
       filepoint = filepoint + 1
    End If
Loop
UnEnscape = TempData
End Function

Function Enscape(enstr As String) As String
Dim OutPutStr As String
Dim TmpStr As String
Dim DataLen As Long
TmpStr = ""
DataLen = Len(enstr)
Dim TempNum As Long
For i = 1 To DataLen
TempNum = AscW(Mid(enstr, i, 1))
   Debug.Print TempNum
   If TempNum < 16 And TempNum > 0 Then
      TmpStr = TmpStr + "%0" + Hex(TempNum)
   
   ElseIf 48 <= TempNum And TempNum <= 57 Then
      
      TmpStr = TmpStr + Mid(enstr, i, 1)
      
    ElseIf 65 <= TempNum And TempNum <= 90 Then
      
      TmpStr = TmpStr + Mid(enstr, i, 1)
      
    ElseIf 97 <= TempNum And TempNum <= 122 Then
      
      TmpStr = TmpStr + Mid(enstr, i, 1)
      
   
    ElseIf 16 <= TempNum And TempNum < 256 Then
      TmpStr = TmpStr + "%" + Hex(TempNum)

    ElseIf 4096 > TempNum And TempNum >= 256 Then
            If TempNum > 0 Then
      TmpStr = TmpStr + "%u0" + Hex(TempNum)
      Else
      TmpStr = TmpStr + "%u0" + Hex(CLng(&H10000) + TempNum)
      End If
    ElseIf Abs(TempNum) >= 4096 Then
      If TempNum > 0 Then
      TmpStr = TmpStr + "%u" + Hex(TempNum)
      Else
      TmpStr = TmpStr + "%u" + Hex(CLng(&H10000) + TempNum)
      End If
      
    End If

Next
Enscape = TmpStr
End Function


这个是HTML  16进制加码解码谁帮我把每句代码意思给我解释下
搜索更多相关主题的帖子: 代码  解释  
2008-9-12 14:11
三断笛
Rank: 12Rank: 12Rank: 12
等级:版主
威望:9
帖子:923
积分:10211
注册:2007-5-24

url_decode

滚滚红尘中的白痴..........
2008-9-12 14:27
关于我们 | 广告合作 | 编程中国 | 清除Cookies | Archiver | WAP | TOP

编程中国 版权所有,并保留所有权利。鲁ICP备08000592号
Powered by Discuz, Processed in 0.050702 second(s), 9 queries.
Copyright©2004-2008, BCCN.NET, All Rights Reserved