腾讯 : https://github.com/qcloudsms/qcloudsms_csharphtml
安装nuget包:git
using qcloudsms_csharp; using System.Collections.Generic; namespace Own.Common { public class Utils { /// <summary> /// 腾讯云发短信 /// </summary> public static void TencentSmsMethod() { //地址:https://console.cloud.tencent.com/sms/smsContent // 短信应用SDK AppID const int appid = 111; // 短信应用SDK AppKey const string appkey = "111"; //模板Id int templateId = 269006; // 签名 NOTE: 这里的签名只是示例,请使用真实的已申请的签名, 签名参数使用的是`签名内容`,而不是`签名ID` string smsSign = "程序源于生活"; // 须要发送短信的手机号码 var phoneNumbers = new List<string> { "12", "12" }; #region 指定模板单发短信 //var ssender = new SmsSingleSender(appid, appkey); //var result = ssender.sendWithParam("86", phoneNumbers[0], // templateId, new[] { "5678","2" }, smsSign, "", ""); // 签名参数未提供或者为空时,会使用默认签名发送短信 #endregion #region 指定模板群发 var ssender = new SmsMultiSender(appid, appkey); var sresult = ssender.sendWithParam("86", phoneNumbers, templateId, new List<string> { "5678", "2" }, null, "", ""); // 签名参数未提供或者为空时,会使用默认签名发送短信 #endregion } } }
阿里:官方说明文档
github
1.在github下载sdk api
https://github.com/aliyun/aliyun-openapi-net-sdkapp
在线调试:https://api.aliyun.com/new?spm=a2c4g.11186623.2.13.5c1619d9AB95cl#/?product=Dysmsapi&api=SendSmsdom
2.下载sdk和demo阿里云
using Aliyun.Acs.Core; using Aliyun.Acs.Core.Exceptions; using Aliyun.Acs.Core.Profile; using Aliyun.Acs.Dysmsapi.Model.V20170525; using System; namespace Own.Common { public class Utils { /// <summary> /// 阿里云发短信 /// </summary> public static SendSmsResponse SendSms() { //产品名称:云通讯短信API产品,开发者无需替换 const String product = "Dysmsapi"; //产品域名,开发者无需替换 const String domain = "dysmsapi.aliyuncs.com"; // TODO 此处须要替换成开发者本身的AK(在阿里云访问控制台寻找) const String accessKeyId = "yourAccessKeyId"; const String accessKeySecret = "yourAccessKeySecret"; IClientProfile profile = DefaultProfile.GetProfile("cn-hangzhou", accessKeyId, accessKeySecret); DefaultProfile.AddEndpoint("cn-hangzhou", "cn-hangzhou", product, domain); IAcsClient acsClient = new DefaultAcsClient(profile); SendSmsRequest request = new SendSmsRequest(); SendSmsResponse response = null; try { //必填:待发送手机号。支持以逗号分隔的形式进行批量调用,批量上限为1000个手机号码,批量调用相对于单条调用及时性稍有延迟,验证码类型的短信推荐使用单条调用的方式 request.PhoneNumbers = "15000000000"; //必填:短信签名-可在短信控制台中找到 request.SignName = "云通讯"; //必填:短信模板-可在短信控制台中找到 request.TemplateCode = "SMS_1000000"; //可选:模板中的变量替换JSON串,如模板内容为"亲爱的${name},您的验证码为${code}"时,此处的值为 request.TemplateParam = "{\"customer\":\"123\"}"; //可选:outId为提供给业务方扩展字段,最终在短信回执消息中将此值带回给调用者 request.OutId = "yourOutId"; //请求失败这里会抛ClientException异常 response = acsClient.GetAcsResponse(request); } catch (ServerException e) { Console.WriteLine(e.ErrorCode); } catch (ClientException e) { Console.WriteLine(e.ErrorCode); } return response; } /// <summary> /// 批量 /// </summary> /// <returns></returns> public static SendBatchSmsResponse BatchSendSms() { //产品名称:云通讯短信API产品,开发者无需替换 const String product = "Dysmsapi"; //产品域名,开发者无需替换 const String domain = "dysmsapi.aliyuncs.com"; // TODO 此处须要替换成开发者本身的AK(在阿里云访问控制台寻找) const String accessKeyId = "yourAccessKeyId"; const String accessKeySecret = "yourAccessKeySecret"; IClientProfile profile = DefaultProfile.GetProfile("cn-hangzhou", accessKeyId, accessKeySecret); DefaultProfile.AddEndpoint("cn-hangzhou", "cn-hangzhou", product, domain); IAcsClient acsClient = new DefaultAcsClient(profile); SendBatchSmsRequest request = new SendBatchSmsRequest(); //request.Protocol = ProtocolType.HTTPS; //request.TimeoutInMilliSeconds = 1; SendBatchSmsResponse response = null; try { //必填:待发送手机号。支持JSON格式的批量调用,批量上限为100个手机号码,批量调用相对于单条调用及时性稍有延迟,验证码类型的短信推荐使用单条调用的方式 request.PhoneNumberJson = "[\"1500000000\",\"1500000001\"]"; //必填:短信签名-支持不一样的号码发送不一样的短信签名 request.SignNameJson = "[\"云通讯\",\"云通讯\"]"; //必填:短信模板-可在短信控制台中找到 request.TemplateCode = "SMS_1000000"; //必填:模板中的变量替换JSON串,如模板内容为"亲爱的${name},您的验证码为${code}"时,此处的值为 //友情提示:若是JSON中须要带换行符,请参照标准的JSON协议对换行符的要求,好比短信内容中包含\r\n的状况在JSON中须要表示成\\r\\n,不然会致使JSON在服务端解析失败 request.TemplateParamJson = "[{\"name\":\"Tom\", \"code\":\"123\"},{\"name\":\"Jack\", \"code\":\"456\"}]"; //可选-上行短信扩展码(扩展码字段控制在7位或如下,无特殊需求用户请忽略此字段) //request.SmsUpExtendCodeJson = "[\"90997\",\"90998\"]"; //请求失败这里会抛ClientException异常 response = acsClient.GetAcsResponse(request); } catch (ServerException e) { Console.Write(e.ErrorCode); } catch (ClientException e) { Console.Write(e.ErrorCode); Console.Write(e.Message); } return response; } /// <summary> /// 查询发送详情 /// </summary> public static QuerySendDetailsResponse QuerySendDetails(String bizId) { //产品名称:云通讯短信API产品,开发者无需替换 const String product = "Dysmsapi"; //产品域名,开发者无需替换 const String domain = "dysmsapi.aliyuncs.com"; // TODO 此处须要替换成开发者本身的AK(在阿里云访问控制台寻找) const String accessKeyId = "yourAccessKeyId"; const String accessKeySecret = "yourAccessKeySecret"; //初始化acsClient,暂不支持region化 IClientProfile profile = DefaultProfile.GetProfile("cn-hangzhou", accessKeyId, accessKeySecret); DefaultProfile.AddEndpoint("cn-hangzhou", "cn-hangzhou", product, domain); IAcsClient acsClient = new DefaultAcsClient(profile); //组装请求对象 QuerySendDetailsRequest request = new QuerySendDetailsRequest(); //必填-号码 request.PhoneNumber = "15000000000"; //可选-流水号 request.BizId = bizId; //必填-发送日期 支持30天内记录查询,格式yyyyMMdd request.SendDate = DateTime.Now.ToString("yyyyMMdd"); //必填-页大小 request.PageSize = 10; //必填-当前页码从1开始计数 request.CurrentPage = 1; QuerySendDetailsResponse querySendDetailsResponse = null; try { querySendDetailsResponse = acsClient.GetAcsResponse(request); } catch (ServerException e) { Console.WriteLine(e.ErrorCode); } catch (ClientException e) { Console.WriteLine(e.ErrorCode); } return querySendDetailsResponse; } } }