【VB6至VB.Net的进步】字符串转UTF-8的URL

    'VB.Net代码继承VB6写法
    Function StringToURLUTF8(ByVal Target As String) As String
        If Target = "" Then Return ""
        Dim Resault As String = ""
        For i = 1 To Target.Length
            Dim Text As String = Mid(Target, i, 1)
            Dim Asc As Integer = AscW(Text)
            If Asc < 0 Then Asc += 65536
            Dim Resault_Part As String = ""
            If (Asc And &HFF80) = 0 Then
                Resault_Part = Text
            Else
                If (Asc And &HF000) = 0 Then
                    Resault_Part = "%" & Hex((Asc \ 64) Or &HC0) & Hex(Asc And &H3F Or &H80)
                Else
                    Resault_Part = "%" & Hex((Asc \ 4096) Or &HE0) & "%" & Hex((Asc \ 64) And &H3F Or &H80) & "%" & Hex(Asc And &H3F Or &H80)
                End If
            End If
            Resault &= Resault_Part
        Next i
        Return Resault
    End Function

    'VB.Net代码.Net写法
    Function StringToURLUTF8(ByVal Target As String) As String
        If Target = "" Then Return ""
        Dim Resault As String = ""
        For Each b As Byte In Encoding.UTF8.GetBytes(Target)
            Resault &= "%" & b.ToString("X")
        Next
        Return Resault
    End Function
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值