德州阿里云代理商:asp短信接口代码

以下是一个使用ASP语言调用阿里云短信接口的简单示例代码:

<%
' 引入必要的组件
Set xmlhttp = Server.CreateObject("Msxml2.ServerXMLHTTP")
Set xmlDoc = Server.CreateObject("Msxml2.DOMDocument")
Set xmlElem = Server.CreateObject("MSXML2.XMLDOM")
xmlDoc.async = False

' 设置阿里云短信接口的请求参数
accessKeyId = "你的阿里云AccessKey ID"
accessKeySecret = "你的阿里云AccessKey Secret"
signatureMethod = "HMAC-SHA1"
signatureNonce = CStr(Int(Rnd * 10000000))
signatureVersion = "1.0"
timestamp = URLEncode(FormatDateTime(Now, vbGeneralDate))

' 构建签名字符串
canonicalizedQueryString = "AccessKeyId=" & accessKeyId & "&Format=XML&" & _
                           "SignatureMethod=" & URLEncode(signatureMethod) & "&" & _
                           "SignatureNonce=" & URLEncode(signatureNonce) & "&" & _
                           "SignatureVersion=" & URLEncode(signatureVersion) & "&" & _
                           "Timestamp=" & timestamp & "&" & _
                           "Version=2017-05-25"

stringToSign = "GET" & "&" & URLEncode("/") & "&" & URLEncode(canonicalizedQueryString)

' 使用AccessKey Secret生成签名
signature = URLEncode(Base64Encode(HmacSHA1(accessKeySecret & "&", stringToSign)))

' 构建请求URL
requestURL = "http://dysmsapi.aliyuncs.com/?" & canonicalizedQueryString & "&" & "Signature=" & signature

' 发起GET请求,获取短信发送结果
xmlhttp.open "GET", requestURL, False
xmlhttp.send ""

responseXML = xmlhttp.responseText

' 解析XML响应结果,提取短信发送状态码
xmlDoc.loadXML responseXML
Set nodeList = xmlDoc.documentElement.getElementsByTagName("Code")

If nodeList.Length > 0 Then
    statusCode = nodeList.Item(0).Text
    If statusCode = "OK" Then
        ' 短信发送成功
        Response.Write "短信发送成功!"
    Else
        ' 短信发送失败
        Response.Write "短信发送失败,错误码:" & statusCode
    End If
Else
    Response.Write "解析短信发送结果失败。"
End If

' 函数:将字符串进行URL编码
Function URLEncode(ByVal str)
    Dim i, c, strResult
    strResult = ""
    For i = 1 To Len(str)
        c = Mid(str, i, 1)
        If Asc(c) >= 48 And Asc(c) <= 57 Or Asc(c) >= 65 And Asc(c) <= 90 Or Asc(c) >= 97 And Asc(c) <= 122 Then
            strResult = strResult & c
        Else
            strResult = strResult & "%" & Right("0" & Hex(Asc(c)), 2)
        End If
    Next
    URLEncode = strResult
End Function

' 函数:使用HMAC-SHA1算法进行加密
Function HmacSHA1(ByVal key, ByVal data)
    Set typeobj = Server.CreateObject("System.Text.UTF8Encoding")
    Set hmacsha1 = Server.CreateObject("System.Security.Cryptography.HMACSHA1")
    Set keyBytes = typeobj.GetBytes_4(key)
    hmacsha1.Key = keyBytes
    Set dataBytes = typeobj.GetBytes_4(data)
    Set hashBytes = hmacsha1.ComputeHash_2(dataBytes)
    HmacSHA1 = ByteArrayToHexString(hashBytes)
End Function

' 函数:将字节数组转换为十六进制字符串
Function ByteArrayToHexString(ByVal bytes)
    Dim hexstr, i
    hexstr = ""
    For i = 1 To LenB(bytes)
        hexstr = hexstr & Right("0" & Hex(Ascb(Midb(bytes, i, 1))), 2)
    Next
    ByteArrayToHexString = hexstr
End Function

' 函数:将字符串进行Base64编码
Function Base64Encode(ByVal data)
    Set base64Encode = Server.CreateObject("System.Text.UTF8Encoding")
    Set base64Encode = Server.CreateObject("System.Convert")
    Set bytes = base64Encode.FromBase64String_2(data)
    Base64Encode = base64Encode.GetString_4(bytes)
End Function
%>

请将上述代码中的accessKeyIdaccessKeySecret替换为你自己的阿里云AccessKey ID和AccessKey Secret。

这里仅提供了一个简单的示例代码,实际使用时可能需要根据自己的需求调整和完善代码。同时,为了确保代码的安全性和稳定性,建议在生产环境中使用HTTPS协议进行请求。

德州阿里云代理商提供了ASP短信接口代码,你可以参考以下示例代码:

  1. 发送短信接口:
<%
' 导入必要的命名空间
Imports System.Security.Cryptography
Imports System.Text
Imports System.Web
Imports System.IO
Imports System.Net
Imports System.Net.Http
Imports System.Net.Http.Headers

' 发送短信函数
Function SendSMS(ByVal mobile As String, ByVal message As String) As String
    Dim res As String = ""
    Dim param As String = ""
    Dim code As String = ""
    Dim postDataStr As String = ""
    Dim accountSid As String = "your_account_sid" ' 替换为你的账号SID
    Dim authToken As String = "your_auth_token" ' 替换为你的授权令牌
    Dim url As String = "https://dysmsapi.aliyuncs.com/2017-05-25/SendSms"

    ' 构建时间戳
    Dim epoch As DateTime = New DateTime(1970, 1, 1, 0, 0, 0, DateTimeKind.Utc)
    Dim timestamp As Long = (DateTime.UtcNow - epoch).TotalMilliseconds

    ' 构建签名
    Dim sign As String = AccountSign(accountSid, authToken, timestamp)

    ' 构建请求参数
    param = "{""PhoneNumbers"":""" & mobile & """,""SignName"":""your_sign_name"",""TemplateCode"":""your_template_code"",""TemplateParam"":""{""message"":""" & message & """}""}"
    postDataStr = "SignatureMethod=HMAC-SHA1&SignatureNonce=1234567890&SignatureVersion=1.0&AccessKeyId=" & accountSid & "&Timestamp=" & timestamp & "&Format=JSON&Signature=" & HttpUtility.UrlEncode(sign) & "&Action=SendSms&Version=2017-05-25" & "&RegionId=cn-hangzhou&" & param
    
    ' 发送请求
    Dim result As String = HttpPost(url, postDataStr)

    ' 处理返回结果
    If result.Contains("""Code"":""OK""") Then
        res = "短信发送成功"
    Else
        ' 解析错误信息
        Dim start As Integer = result.IndexOf("""Code"":""") + 9
        Dim [end] As Integer = result.IndexOf("""", start)
        code = result.Substring(start, [end] - start)
        res = "短信发送失败,错误码:" & code
    End If

    Return res
End Function

' 构建请求签名的函数
Function AccountSign(ByVal accountSid As String, ByVal authToken As String, ByVal timestamp As Long) As String
    Dim signRef As String = accountSid & authToken & timestamp.ToString()
    ' 使用SHA1哈希算法进行散列计算
    Dim sha As SHA1 = New SHA1CryptoServiceProvider()
    Dim signBytes As Byte() = sha.ComputeHash(Encoding.UTF8.GetBytes(signRef))
    ' 将字节数组转换为Base64字符串
    Dim sign As String = Convert.ToBase64String(signBytes)
    Return sign
End Function

' 发送HTTP POST请求的函数
Function HttpPost(ByVal url As String, ByVal postDataStr As String) As String
    Dim request As WebRequest = WebRequest.Create(url)
    request.Method = "POST"
    request.ContentType = "application/x-www-form-urlencoded"
    Dim parameterBytes As Byte() = Encoding.UTF8.GetBytes(postDataStr)
    request.ContentLength = parameterBytes.Length
    Dim requestStream As Stream = request.GetRequestStream()
    requestStream.Write(parameterBytes, 0, parameterBytes.Length)
    requestStream.Close()
    Dim response As WebResponse = request.GetResponse()
    Dim responseStream As Stream = response.GetResponseStream()
    Dim streamReader As StreamReader = New StreamReader(responseStream, Encoding.GetEncoding("utf-8"))
    Dim result As String = streamReader.ReadToEnd()
    streamReader.Close()
    responseStream.Close()
    response.Close()
    Return result
End Function

' 测试短信发送
Dim mobile As String = "18012345678" ' 接收短信的手机号码
Dim message As String = "您的验证码是:123456" ' 短信内容
Dim result As String = SendSMS(mobile, message)
Response.Write("发送结果:" & result)
%>

请注意替换代码中的your_account_sidyour_auth_tokenyour_sign_nameyour_template_code为你的阿里云账号对应的信息。

德州阿里云代理商:asp短信接口代码
  1. 查询短信发送记录接口:
<%
' 导入必要的命名空间
Imports System.Security.Cryptography
Imports System.Text
Imports System.Web
Imports System.IO
Imports System.Net
Imports System.Net.Http
Imports System.Net.Http.Headers

' 查询短信发送记录函数
Function QuerySMS(ByVal mobile As String, ByVal date As Date) As String
    Dim res As String = ""
    Dim param As String = ""
    Dim postDataStr As String = ""
    Dim accountSid As String = "your_account_sid" ' 替换为你的账号SID
    Dim authToken As String = "your_auth_token" ' 替换为你的授权令牌
    Dim url As String = "https://dysmsapi.aliyuncs.com/2017-05-25/QuerySendDetails"

    ' 构建时间戳
    Dim epoch As DateTime = New DateTime(1970, 1, 1, 0, 0, 0, DateTimeKind.Utc)
    Dim timestamp As Long = (DateTime.UtcNow - epoch).TotalMilliseconds

    ' 构建签名
    Dim sign As String = AccountSign(accountSid, authToken, timestamp)

    ' 构建请求参数
    param = "{""PhoneNumber"":""" & mobile & """,""SendDate"":""" & date.ToString("yyyyMMdd") & """,""PageSize"":""10"",""CurrentPage"":""1""}"
    postDataStr = "SignatureMethod=HMAC-SHA1&SignatureNonce=1234567890&SignatureVersion=1.0&AccessKeyId=" & accountSid & "&Timestamp=" & timestamp & "&Format=JSON&Signature=" & HttpUtility.UrlEncode(sign) & "&Action=QuerySendDetails&Version=2017-05-25&RegionId=cn-hangzhou&" & param
    
    ' 发送请求
    Dim result As String = HttpPost(url, postDataStr)

    ' 处理返回结果
    If result.Contains("""Code"":""OK""") Then
        res = "查询成功"
    Else
        ' 解析错误信息
        Dim start As Integer = result.IndexOf("""Code"":""") + 9
        Dim [end] As Integer = result.IndexOf("""", start)
        code = result.Substring(start, [end] - start)
        res = "查询失败,错误码:" & code
    End If

    Return res
End Function

' 测试短信发送记录查询
Dim mobile As String = "18012345678" ' 查询短信记录的手机号码
Dim date As Date = DateTime.Now.Date ' 查询的日期
Dim result As String = QuerySMS(mobile, date)
Response.Write("查询结果:" & result)
%>

同样需要替换代码中的your_account_sidyour_auth_token为你的阿里云账号对应的信息。

以上代码可以帮助你在ASP中使用阿里云短信接口发送短信和查询短信发送记录。

发布者:luotuoemo,转转请注明出处:https://www.jintuiyun.com/110273.html

(0)
luotuoemo的头像luotuoemo
上一篇 2023年12月13日 14:58
下一篇 2023年12月13日 15:11

相关推荐

  • 中山阿里云代理商:asp.net 数据库 写入xml

    您可以使用以下代码将ASP.NET应用程序中的数据写入XML文件中的数据库: 首先,创建数据库连接对象和数据适配器对象: SqlConnection conn = new SqlConnection("<your_connection_string>"); SqlDataAdapter da = new SqlDataAdap…

    2024年3月7日
    1.0K00
  • 阿里云国际站:android 调试api模拟

    阿里云国际站的 Android 应用程序通常需要在开发过程中进行 API 调试和模拟。通常的做法是使用一些工具来模拟 API 的响应,以便在没有实际服务器响应时进行开发和测试。 以下是一些常用的工具和方法: Postman:Postman 是一个流行的 API 测试工具,可以创建和发送 HTTP 请求,并查看响应。你可以使用 Postman 来模拟阿里云的 …

    2024年7月12日
    72500
  • 阿里云企业邮箱代理商:我能通过阿里云企业邮箱提高多账号管理效率吗?

    阿里云企业邮箱代理商:我能通过阿里云企业邮箱提高多账号管理效率吗? 在当今数字化办公环境中,企业邮箱不仅是沟通工具,更是团队协作和业务管理的重要平台。对于拥有多个部门或分支机构的企业来说,如何高效管理多个邮箱账号成为一大挑战。作为阿里云企业邮箱代理商,我们经常被客户问到:“阿里云企业邮箱能帮助我提高多账号管理效率吗?”答案是肯定的!下面我们将详细介绍阿里云企…

    2025年10月6日
    43500
  • 阿里云os操作界面

    小米3刷阿里云os怎么操作? 第一步、在电脑上下载安装“刷机大师”,安装完毕后打开,此时将小米3连接电脑,连接到刷机大师会自动安装手机端驱动,使手机保持正常的开机状态。第二步、进行ROOT点击“更多工具”,选择“ROOT大师”对小米3一键ROOT ,等待ROOT成功后自动重启。第三步、数据刷机前,建议您备份您的重要资料,点击“更多工具”,选择“备…

    2023年8月27日
    73700
  • 阿里巴巴云计算中心规划

    IDC会被云计算数据中心完全取代么 从现有资源分布分析,目前,以北京地区为例,是以传统的IDC机房为主。预计2015年,仅北京地区现有8.65万个机柜的存量,将趋于饱和。接下来,新建的云计算数据中心,随着落地时间的临近,将会吸引更多的企业入住。如北京超算计算中心、中国移动的兴业云、小鸟云的山东云计算中心、婺源云计算数据中心、浪潮的公安云计算中心。未来2-3年…

    2023年8月28日
    64500

发表回复

登录后才能评论

联系我们

4000-747-360

在线咨询: QQ交谈

邮件:ixuntao@qq.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信
购买阿里云服务器请访问:https://www.4526.cn/