|
学习编程得第N天,发现一个超简单验证码短信接口对接DEMO示例
<%@LANGUAGE=&#34;VBSCRIPT&#34; CODEPAGE=&#34;936&#34;%>
<%
Response.Charset = &#34;gb2312&#34;
&#39;asp UTF转GB2312 将UTF8编码文字转换为GB编码文字的asp代码
function UTF2GB(UTFStr)
for Dig=1 to len(UTFStr)
&#39;如果UTF8编码文字以%开头则进行转换
if mid(UTFStr,Dig,1)=&#34;%&#34; then
&#39;UTF8编码文字大于8则转换为汉字
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
&#39;GB2312转UTF8的asp代码 将GB编码文字转换为UTF8编码文字
Function toUTF8(szInput)
Dim wch, uch, szRet
Dim x
Dim nAsc, nAsc2, nAsc3
&#39;如果输入参数为空,则退出函数
If szInput = &#34;&#34; Then
toUTF8 = szInput
Exit Function
End If
&#39;开始转换
For x = 1 To Len(szInput)
&#39;利用mid函数分拆GB编码文字
wch = Mid(szInput, x, 1)
&#39;利用ascW函数返回每一个GB编码文字的Unicode字符代码
&#39;注:asc函数返回的是ANSI 字符代码,注意区别
nAsc = AscW(wch)
If nAsc < 0 Then nAsc = nAsc + 65536
If (nAsc And &HFF80) = 0 Then
szRet = szRet & wch
Else
If (nAsc And &HF000) = 0 Then
uch = &#34;%&#34; & Hex(((nAsc \ 2 ^ 6)) Or &HC0) & Hex(nAsc And &H3F Or &H80)
szRet = szRet & uch
Else
&#39;GB编码文字的Unicode字符代码在0800 - FFFF之间采用三字节模版
uch = &#34;%&#34; & Hex((nAsc \ 2 ^ 12) Or &HE0) & &#34;%&#34; & _
Hex((nAsc \ 2 ^ 6) And &H3F Or &H80) & &#34;%&#34; & _
Hex(nAsc And &H3F Or &H80)
szRet = szRet & uch
End If
End If
Next
toUTF8 = szRet
End Function
&#39;二进制转换为十六进制的asp代码
function c2to16(x)
i=1
for i=1 to len(x) step 4
c2to16=c2to16 & hex(c2to10(mid(x,i,4)))
next
end function
&#39;二进制转换为十进制的asp代码
function c2to10(x)
c2to10=0
if x=&#34;0&#34; then exit function
i=0
for i= 0 to len(x) -1
if mid(x,len(x)-i,1)=&#34;1&#34; then c2to10=c2to10+2^(i)
next
end function
&#39;十六进制转换为二进制的asp代码
function c16to2(x)
i=0
for i=1 to len(trim(x))
tempstr= c10to2(cint(int(&#34;&h&#34; & mid(x,i,1))))
do while len(tempstr)<4
tempstr=&#34;0&#34; & tempstr
loop
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 & &#34;1&#34;
else
c10to2=c10to2 & &#34;0&#34;
end if
next
if mysign=-1 then c10to2=&#34;-&#34; & c10to2
end function
&#39;UTF8编码文字将转换为汉字
function ConvChinese(x)
A=split(mid(x,2),&#34;%&#34;)
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),&#34;0&#34;)
Unicode=&#34;&#34;
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(&#34;&H&#34; & c2to16(Unicode)))
else
ConvChinese=ConvChinese & chr(int(&#34;&H&#34; & c2to16(Unicode)))
end if
next
end function
&#39;GB2312中文转unicode(&#)的asp代码 将GB编码文字转换为unicode编码文字
function chinese2unicode(Str)
dim i
dim Str_one
dim Str_unicode
if(isnull(Str)) then
exit function
end if
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
&#39;URL地址编码解码函数
Function URLDecode(enStr)
dim deStr
dim c,i,v
deStr=&#34;&#34;
for i=1 to len(enStr)
c=Mid(enStr,i,1)
if c=&#34;%&#34; then
v=eval(&#34;&h&#34;+Mid(enStr,i+1,2))
if v<128 then
deStr=deStr&chr(v)
i=i+2
else
if isvalidhex(mid(enstr,i,3)) then
if isvalidhex(mid(enstr,i+3,3)) then
v=eval(&#34;&h&#34;+Mid(enStr,i+1,2)+Mid(enStr,i+4,2))
deStr=deStr&chr(v)
i=i+5
else
v=eval(&#34;&h&#34;+Mid(enStr,i+1,2)+cstr(hex(asc(Mid(enStr,i+3,1)))))
deStr=deStr&chr(v)
i=i+3
end if
else
destr=destr&c
end if
end if
else
if c=&#34;+&#34; then
deStr=deStr&&#34; &#34;
else
deStr=deStr&c
end if
end if
next
URLDecode=deStr
end function
&#39;判断是否为有效的十六进制代码
function isvalidhex(str)
dim c
isvalidhex=true
str=ucase(str)
if len(str)<>3 then isvalidhex=false:exit function
if left(str,1)<>&#34;%&#34; then isvalidhex=false:exit function
c=mid(str,2,1)
if not (((c>=&#34;0&#34;) and (c<=&#34;9&#34;)) or ((c>=&#34;A&#34;) and (c<=&#34;Z&#34;))) then isvalidhex=false:exit function
c=mid(str,3,1)
if not (((c>=&#34;0&#34;) and (c<=&#34;9&#34;)) or ((c>=&#34;A&#34;) and (c<=&#34;Z&#34;))) then isvalidhex=false:exit function
end function
&#39;请求数据到短信接口
Function Post(url,data)
dim Https
set Https=server.createobject(&#34;MSXML2.XMLHTTP&#34;)
Https.open &#34;POST&#34;,url,false
Https.setRequestHeader &#34;Content-Type&#34;,&#34;application/x-www-form-urlencoded&#34;
Https.send data
if Https.readystate=4 then
dim objstream
set objstream = Server.CreateObject(&#34;adodb.stream&#34;)
objstream.Type = 1
objstream.Mode =3
objstream.Open
objstream.Write Https.responseBody
objstream.Position = 0
objstream.Type = 2
objstream.Charset = &#34;utf-8&#34;
Post = objstream.ReadText
objstream.Close
set objstream = nothing
set https=nothing
end if
End Function
&#39;函数返回随机整数。
Function gen_key(digits)
&#39;Create and define array
dim char_array(50)
char_array(0) = &#34;0&#34;
char_array(1) = &#34;1&#34;
char_array(2) = &#34;2&#34;
char_array(3) = &#34;3&#34;
char_array(4) = &#34;4&#34;
char_array(5) = &#34;5&#34;
char_array(6) = &#34;6&#34;
char_array(7) = &#34;7&#34;
char_array(8) = &#34;8&#34;
char_array(9) = &#34;9&#34;
&#39;Initiate randomize method for default seeding
randomize
&#39;Loop through and create the output based on the the variable passed to
&#39;the function for the length of the key.
do while len(output) < digits
num = char_array(Int((9 - 0 + 1) * Rnd + 0))
output = output + num
loop
&#39;Set return
gen_key = output
End Function
Dim mobile
mobile = request(&#34;mobile&#34;) &#39;手机号码
if mobile=&#34;&#34; then
response.Write(&#34;手机号码不能为空&#34;)
else
if request.Form(&#34;send_code&#34;) = &#34;&#34; or Session(&#34;send_code&#34;)<>request.Form(&#34;send_code&#34;) then
&#39;防用户恶意请求
response.Write(&#34;请求超时,请刷新页面后重试&#34;)
else
dim target,post_data,content,res,mobile_code
mobile_code = gen_key(4)
Session(&#34;mobile_code&#34;) = mobile_code
&#39;Response.Cookies(&#34;mobile_code&#34;) = mobile_code
Session(&#34;mobile&#34;) = mobile
&#39;Response.Cookies(&#34;mobile&#34;) = mobile
target = &#34;http://106.ihuyi.com/webservice/sms.php?method=Submit&#34;
content = toUTF8(&#34;您的验证码是:&#34;&mobile_code&&#34;。请不要把验证码泄露给其他人。&#34;)
post_data = &#34;account=用户名&password=密码&mobile=&#34;&mobile&&#34;&content=&#34;&content
&#39;查看用户名 登录用户中心->验证码通知短信>产品总览->API接口信息->APIID
&#39;查看密码 登录用户中心->验证码通知短信>产品总览->API接口信息->APIKEY
&#39;Response.write toUTF8(&#34;短信测试&#34;)
&#39;response.Write(UTF2GB(Post(target,post_data)))
tempstr = UTF2GB(Post(target,post_data))
&#39;if instr(tempstr,&#34;提交成功&#34;)>0 Then
&#39;response.Write(&#34;true&#34;)
&#39;else
&#39;response.Write(&#34;error&#34;)
&#39;end if
Dim len1,len2
len1 = instr(1,tempstr,&#34;</code>&#34;,1)-1
len2 = instr(1,tempstr,&#34;<code>&#34;,1)
&#39;response.Write(len2)
code=left(tempstr,len1)
code=right(code,(len1-len2-5))
&#39;response.Write(code)
Dim len3,len4
len3 = instr(1,tempstr,&#34;</msg>&#34;,1)-1
len4 = instr(1,tempstr,&#34;<msg>&#34;,1)
&#39;response.Write(len2)
msg=left(tempstr,len3)
msg=right(msg,(len3-len4-4))
response.Write(msg)
end if
end If
%>
&#39;账户注册:请通过该地址开通账户 http://user.ihuyi.com/?JA9Ewr
&#39;注意事项:
&#39;(1)调试期间,请使用用系统默认的短信内容:您的验证码是:【变量】。请不要把验证码泄露给其他人。
&#39;(2)请使用 APIID 及 APIKEY来调用接口,可在会员中心获取; |
|