德州阿里云代理商: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

相关推荐

  • 阿里云国际站注册教程:ad域服务器型号

    要在阿里云国际站注册并选择适合AD域服务器的型号,可以按照以下步骤操作: 访问阿里云国际站:首先,你需要访问 阿里云国际官网。 创建账户:在阿里云国际站点上,你需要创建一个新账户或登录已有账户。 选择云服务器产品:在产品列表中选择“云服务器 ECS”或其他虚拟主机服务。 配置服务器: 地域选择:选择一个离你用户群近的地区,这样可以减少网络延迟。 实例类型:选…

    2024年7月5日
    28600
  • 定制化阿里云企业邮箱的功能测试用例设计的重点、难点和覆盖范围分析及实践?

    定制化阿里云企业邮箱的功能测试用例设计的重点、难点和覆盖范围分析及实践 一、阿里云企业邮箱的优势 阿里云企业邮箱以其稳定性、安全性和强大的功能备受青睐。首先,它支持大容量存储,用户可以方便地管理大量邮件。同时,阿里云企业邮箱具备高效的反垃圾邮件技术,能够有效过滤无用邮件,提升工作效率。此外,强大的协作功能,如日历共享、任务管理等,使团队成员之间的沟通更加顺畅…

    2024年11月1日
    49200
  • 阿里云应用案例

    阿里云ECS(Elastic Compute Service):阿里云ECS提供了灵活的计算能力,用户可以通过阿里云控制台或API创建和管理云服务器实例。许多企业和开发者在阿里云上部署他们的应用程序和网站,利用阿里云ECS提供的高性能和弹性扩展来支持其业务需求。 阿里云RDS(Relational Database Service):阿里云RDS是一种完全托…

    2023年8月11日
    32500
  • 青岛阿里云代理商:android短信发送图片

    在青岛,你可以找到阿里云的代理商来帮助你发送包含图片的Android短信。阿里云的短信服务可以通过API接口来发送短信,其中包括发送图片的功能。下面是一个发送图片短信的示例代码: import com.aliyuncs.DefaultAcsClient; import com.aliyuncs.exceptions.ClientException; impo…

    2024年2月5日
    32100
  • 南通阿里云代理商:阿里云自动化运营

    南通阿里云代理商是指在南通地区代理阿里云产品和服务的公司或个人。阿里云自动化运营是指利用阿里云的自动化工具和平台,对云计算和云服务进行自动化运营和管理。 阿里云自动化运营可以提供以下功能和服务: 自动化部署和扩展:通过自动化工具和平台,可以快速部署和扩展云服务,提高运维效率。 自动化监控和报警:实时监控云服务的运行状态,当出现异常时,自动报警并采取相应措施。…

    2024年1月8日
    31600

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

4000-747-360

在线咨询: QQ交谈

邮件:ixuntao@qq.com

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

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