ASP中汉字与UTF-8的互相转换

时间:2009-06-24 11:15:00 

function chinese2unicode(Str)
        for i=1 to len(Str)
                Str_one=Mid(Str,i,1)
                Str_unicode=Str_unicode&chr(38)
                Str_unicode=Str_unicode&chr(35)
                Str_unicode=Str_unicode&chr(120)
                Str_unicode=Str_unicode& Hex(ascw(Str_one))
                Str_unicode=Str_unicode&chr(59)
        next
        chinese2unicode = Str_unicode
end function

=============UTF-8转换为汉字==================

function UTF2GB(UTFStr)
        for Dig=1 to len(UTFStr)
                if mid(UTFStr,Dig,1)="%" then
                        if len(UTFStr) >= Dig+8 then
                                GBStr=GBStr & ConvChinese(mid(UTFStr,Dig,9))
                                Dig=Dig+8
                        else
                                GBStr=GBStr & mid(UTFStr,Dig,1)
                        end if
                else
                        GBStr=GBStr & mid(UTFStr,Dig,1)
                end if
        next
        UTF2GB=GBStr
end function


function ConvChinese(x)
        A=split(mid(x,2),"%")
        i=0
        j=0

        for i=0 to ubound(A)
                A(i)=c16to2(A(i))
        next

        for i=0 to ubound(A)-1
                DigS=instr(A(i),"0")
                 Unicode=""
                for j=1 to DigS-1
                        if j=1 then
                                A(i)=right(A(i),len(A(i))-DigS)
                                Unicode=Unicode & A(i)
                        else
                                 i=i+1
                                A(i)=right(A(i),len(A(i))-2)
                                Unicode=Unicode & A(i)
                        end if
                next

                if len(c2to16(Unicode))=4 then
                        ConvChinese=ConvChinese & chrw(int("&H" & c2to16(Unicode)))
                else
                        ConvChinese=ConvChinese & chr(int("&H" & c2to16(Unicode)))
                end if
        next
end function

function c2to16(x)
        i=1
        for i=1 to len(x) step 4
                c2to16=c2to16 & hex(c2to10(mid(x,i,4)))
        next
end function

function c2to10(x)
        c2to10=0
        if x="0" then exit function
        i=0
        for i= 0 to len(x) -1
                 if mid(x,len(x)-i,1)="1" then c2to10=c2to10+2^(i)
        next
end function

function c16to2(x)
        i=0
        for i=1 to len(trim(x))
                tempstr= c10to2(cint(int("&h" & mid(x,i,1))))
                do while len(tempstr)<4
                        tempstr="0" & tempstr
                loop
     &nbsp;          c16to2=c16to2 & tempstr
        next
end function

function c10to2(x)
        mysign=sgn(x)
        x=abs(x)
        DigS=1
        do
                if x<2^DigS then
                        exit do
                else
                        DigS=DigS+1
                end if
        loop
        tempnum=x

        i=0
        for i=DigS to 1 step-1
                if tempnum>=2^(i-1) then
                        tempnum=tempnum-2^(i-1)
                        c10to2=c10to2 & "1"
                else
                        c10to2=c10to2 & "0"
                end if
        next
        if mysign=-1 then c10to2="-" & c10to2
end function

标签:编码,UTF-8,汉字,asp
0
投稿

猜你喜欢

  • Javascript fso操作文件

    2008-07-30 12:51:00
  • SQL Server中两种修改对象所有者的方法

    2009-01-15 13:10:00
  • 实现MySQL远程访问办法

    2010-11-25 17:17:00
  • SQL学习笔记四 聚合函数、排序方法

    2011-09-30 11:33:29
  • SQL Server服务器内存升级后的烦恼

    2008-12-22 10:55:00
  • ASP 生成静态新闻列表

    2009-03-03 12:25:00
  • 清除浮动的最简写法

    2009-03-30 15:58:00
  • Adobe AIR beta 2震撼发布!

    2007-10-07 11:57:00
  • 如何用ASP创建日志文件

    2008-03-10 17:27:00
  • 关于JS中变量的显式声明和隐式声明

    2008-10-06 13:22:00
  • 讨论闭包传入参数:window & undefined

    2010-05-19 12:55:00
  • 长文章自动分页asp实例-支持HTML

    2007-10-10 21:29:00
  • 常用ASCII 码对照表

    2007-08-21 14:35:00
  • Design IT.(2),关于好设计

    2008-09-08 12:44:00
  • CSS实现DIV完美垂直居中(支持多浏览器)

    2007-08-13 09:21:00
  • JavaScript Table行定位效果

    2009-05-25 10:47:00
  • SQL Server 2000数据库FOR XML查询概述

    2008-12-09 14:49:00
  • 如何使用ASP来读写注册表

    2007-09-20 13:08:00
  • 瞬间的快感之细节提升用户满意度

    2010-11-17 19:19:00
  • 服务器响应HTTP的类型ContentType大全

    2007-10-23 10:21:00
  • asp之家 网络编程 m.aspxhome.com