【管理】4、ABPZero体系教程之拼多多卖家工具 集成短信发送模块

  ABPZero并没有手机短信发送成效,现在我们来集成一个,为后边注册、登录作铺垫。

  实业首部字段

阿里云短信服务

第一须要在阿里云开通短信服务,连年地址

开通后,在签署管理中添加一个签署

管理 1

在模板管理中添加一个模板,如下图所示

管理 2

说到底索要动用阿里云提供的.NET发送短信类库,上面可以一向下载作者上传的类库,也可以去官方下载,然后提取本身所说的2个类库(aliyun-net-sdk-core.dll、aliyun-net-sdk-dysmsapi.dll)

一直下载文件:https://files.cnblogs.com/files/shensigzs/aliyun-net-sdk.zip (里面包罗2个类库,把那2个类库引用到Core项目)

.NET发送短信SDK:https://help.aliyun.com/document\_detail/59836.html?spm=5176.doc55284.6.573.GaNxg6

  实体首部字段是富含在呼吁报文和响应报文中的实体部分所使用的首部,而且请求和响应双方的HTTP报文中都带有与实业相关的首部字段,用于补充内容的换代时间等与实业相关的信息。

安装类库

如下图所示

行使的模块是Abp.Net.Sms,源码地址:https://github.com/berkaroad/Abp.Net.Sms

管理 3

 

  Allow

Core项目增加落成

添加AliDayuSmsSender类,达成2个点子(一个手拉手、一个异步)

文件路径:D:\abp
version\aspnet-zero-3.4.0\aspnet-zero-3.4.0\src\MyCompanyName.AbpZeroTemplate.Core\Authorization\Users\AliDayuSmsSender.cs

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Abp.Dependency;
using Abp.Net.Sms;
using Abp.UI;
using Aliyun.Acs.Core;
using Aliyun.Acs.Core.Exceptions;
using Aliyun.Acs.Core.Profile;
using Aliyun.Acs.Dysmsapi.Model.V20170525;
using Castle.Core.Logging;

namespace MyCompanyName.AbpZeroTemplate.Authorization.Users
{
    public class AliDayuSmsSender : SmsSenderBase, ITransientDependency
    {
        private IClientProfile profile = null;
        public ILogger Logger { get; set; }
        public AliDayuSmsSender(ISmsSenderConfiguration configuration) : base(configuration)
        {
            Logger = NullLogger.Instance;
            profile = DefaultProfile.GetProfile("cn-hangzhou", configuration.GetAppKey(), configuration.GetAppSecret());
        }

        protected override void SendSms(SmsMessage sms)
        {

            DefaultProfile.AddEndpoint("cn-hangzhou", "cn-hangzhou", "Dysmsapi", "dysmsapi.aliyuncs.com");
            IAcsClient acsClient = new DefaultAcsClient(profile);
            SendSmsRequest request = new SendSmsRequest();
            try
            {
                //必填:待发送手机号。支持以逗号分隔的形式进行批量调用,批量上限为1000个手机号码,批量调用相对于单条调用及时性稍有延迟,验证码类型的短信推荐使用单条调用的方式
                request.PhoneNumbers = sms.To;
                //必填:短信签名-可在短信控制台中找到
                request.SignName = sms.FreeSignName;
                //必填:短信模板-可在短信控制台中找到
                request.TemplateCode = string.IsNullOrEmpty(sms.TemplateCode)
                    ? _configuration.GetDefaultSmsTemplateCode()
                    : sms.TemplateCode;
                //可选:模板中的变量替换JSON串,如模板内容为"亲爱的${name},您的验证码为${code}"时,此处的值为
                request.TemplateParam = sms.TemplateParams;
                //可选:outId为提供给业务方扩展字段,最终在短信回执消息中将此值带回给调用者
                //request.OutId = "yourOutId";
                //请求失败这里会抛ClientException异常
                SendSmsResponse sendSmsResponse = acsClient.GetAcsResponse(request);
                Logger.Info("发送返回:" + sendSmsResponse.Message);
            }
            catch (ServerException e)
            {
                throw new UserFriendlyException("短信发送失败",
                    new Exception(string.Format("to:{0},errCode:{1},errMsg:{2}",
                        sms.To,
                        e.ErrorCode,
                        e.Message)));
            }
            catch (ClientException e)
            {
                throw new UserFriendlyException("短信发送失败",
                    new Exception(string.Format("to:{0},errCode:{1},errMsg:{2}",
                        sms.To,
                        e.ErrorCode,
                        e.Message)));
            }

        }

        protected override Task SendSmsAsync(SmsMessage sms)
        {
            DefaultProfile.AddEndpoint("cn-hangzhou", "cn-hangzhou", "Dysmsapi", "dysmsapi.aliyuncs.com");
            var task = new Task(() =>
            {
                IAcsClient acsClient = new DefaultAcsClient(profile);
                SendSmsRequest request = new SendSmsRequest();
                try
                {
                    //必填:待发送手机号。支持以逗号分隔的形式进行批量调用,批量上限为1000个手机号码,批量调用相对于单条调用及时性稍有延迟,验证码类型的短信推荐使用单条调用的方式
                    request.PhoneNumbers = sms.To;
                    //必填:短信签名-可在短信控制台中找到
                    request.SignName = sms.FreeSignName;
                    //必填:短信模板-可在短信控制台中找到
                    request.TemplateCode = string.IsNullOrEmpty(sms.TemplateCode)
                        ? _configuration.GetDefaultSmsTemplateCode()
                        : sms.TemplateCode;
                    //可选:模板中的变量替换JSON串,如模板内容为"亲爱的${name},您的验证码为${code}"时,此处的值为
                    request.TemplateParam = sms.TemplateParams;
                    //可选:outId为提供给业务方扩展字段,最终在短信回执消息中将此值带回给调用者
                    //request.OutId = "yourOutId";
                    //请求失败这里会抛ClientException异常
                    SendSmsResponse sendSmsResponse = acsClient.GetAcsResponse(request);
                    Logger.Info("发送返回:" + sendSmsResponse.Message);
                }
                catch (ServerException e)
                {
                    throw new UserFriendlyException("短信发送失败",
                        new Exception(string.Format("to:{0},errCode:{1},errMsg:{2}",
                            sms.To,
                            e.ErrorCode,
                            e.Message)));
                }
                catch (ClientException e)
                {
                    throw new UserFriendlyException("短信发送失败",
                        new Exception(string.Format("to:{0},errCode:{1},errMsg:{2}",
                            sms.To,
                            e.ErrorCode,
                            e.Message)));
                }
            });


            task.Start();
            return task;
        }
    }
}

 

 

修改AppSettingProvider.cs,在return new[]里头添加如下代码

文本路径:D:\abpweb\PddSellerAssistant\PddSellerAssistant.Core\Configuration\AppSettingProvider.cs

return new[]
                   {
                        // Sms config
                        new SettingDefinition(SmsSettingNames.ServiceUrl,
                            ConfigurationManager.AppSettings[SmsSettingNames.ServiceUrl] ?? ""),
                        new SettingDefinition(SmsSettingNames.AppKey,
                            ConfigurationManager.AppSettings[SmsSettingNames.AppKey] ?? ""),
                        new SettingDefinition(SmsSettingNames.AppSecret,
                            ConfigurationManager.AppSettings[SmsSettingNames.AppSecret] ?? ""),
                        new SettingDefinition(SmsSettingNames.DefaultFreeSignName,
                            ConfigurationManager.AppSettings[SmsSettingNames.DefaultFreeSignName] ?? ""),
                        new SettingDefinition(SmsSettingNames.DefaultSmsTemplateCode,
                            ConfigurationManager.AppSettings[SmsSettingNames.DefaultSmsTemplateCode] ?? ""),
                       //Host settings

 

 修改web.config,添加如下配置节点

 <!-- 短信api配置开始-->
    <add key="Abp.Net.Sms.AppKey" value="" />
    <add key="Abp.Net.Sms.AppSecret" value="" />
    <add key="Abp.Net.Sms.DefaultFreeSignName" value="填写签名名称" />
    <add key="Abp.Net.Sms.DefaultSmsTemplateCode" value="填写模板ID" />
    <add key="Abp.Net.Sms.ServiceUrl" value="" />
    <!-- 短信api配置结束-->

 

 AppKey、AppSecret都得以在阿里云后台获取

 

 修改AbpZeroTemplateCoreModule,代码修改如下

 文件路径:D:\abp
version\aspnet-zero-3.4.0\aspnet-zero-3.4.0\src\MyCompanyName.AbpZeroTemplate.Core\AbpZeroTemplateCoreModule.cs

 

if (DebugHelper.IsDebug)
            {
                //调试模式禁用邮件发送
                //IocManager.Register<IEmailSender, NullEmailSender>(DependencyLifeStyle.Transient);
                //调试模式禁用手机短信发送
                //IocManager.Register<ISmsSender, NullSmsSender>(DependencyLifeStyle.Transient);
            }

 

 可以看到自家都备注掉,因为本身不怕要在调试形式下测试邮件、短信是还是不是可以发送。

 

[DependsOn(typeof(AbpZeroCoreModule),
       typeof(AbpZeroLdapModule),
       typeof(AbpAutoMapperModule),
       typeof(AbpNetSmsModule)
       )]

 

 此处是加上短信模块依赖

  该首部字段用于通告客户端能可以帮忙Request-UTiggoI指定资源的兼具HTTP方法。当服务器收到到不协理的HTTP方法时,会以状态码405当作响应再次来到。与此同时,还会把拥有能协理的HTTP方法写入首部字段Allow后回去。

Application项目

增长文书ISmsMessageService.cs

 文件路径:D:\abp
version\aspnet-zero-3.4.0\aspnet-zero-3.4.0\src\MyCompanyName.AbpZeroTemplate.Application\Authorization\Users\ISmsMessageService.cs

 

public interface ISmsMessageService : IApplicationService
    {
        void Send(string to, string templateCode, string templateParams);
        Task SendAsync(string to, string templateCode, string templateParams);
    }

 

 

再添加落成公文SmsMessageService.cs

文件路径:D:\abp
version\aspnet-zero-3.4.0\aspnet-zero-3.4.0\src\MyCompanyName.AbpZeroTemplate.Application\Authorization\Users\SmsMessageService.cs

public class SmsMessageService: ISmsMessageService
    {
        private readonly ISmsSender _smsSender;

        public SmsMessageService(ISmsSender smsSender)
        {
            _smsSender = smsSender;
        }

        public void Send(string to, string templateCode, string templateParams)
        {
            _smsSender.Send(to, templateCode, templateParams);
        }

        public async Task SendAsync(string to, string templateCode, string templateParams)
        {
            await _smsSender.SendAsync(to, templateCode, templateParams);
        }
    }

 

  Content-Encoding

 测试短信发送

终极,生成项目

浏览器打开:http://localhost:8088/swagger/ui/index(8088是IIS配置的端口)

找到app_smsMessageService服务开展测试

管理 4

 

管理 5

 

一起、分外都测试通过,至此手机短信发送模块集成已毕。

 

归来总目录

 

  该首部字段会告诉客户端服务器对实业的关键性部分采用内容编码格局,而内容编码是指不丢掉实体音信的前提下所开展的滑坡。而内容编码形式唯有五种,就是gzip、compress、deflate、identity。

  Content-Language

  该首部字段会报告客户端,实体中央行使的自然语言。

  Content-Length

  该首部字段评释了实体主旨部分的尺寸,但是对实业中央开展内容编码传输时,就不可以再选用Content-Length首部字,因为实体中央大小的揣度方法会依照故事情节编码的不一样而有所改变且计量办法略复杂。

  Content-Location

  该首部字段给出与报文主体部分相呼应的UKugaI,而且是报文主体再次来到资源对应的U奔驰G级I。

  Content-MD5

  该首部字段是一串由MD5算法生成的值,其目的是在与反省报文主体在传输进程中是或不是维持总体,以及确认传输到达。Content-MD5字段值的变化进度如下:

 管理 6

  为保证报文的可行,作为接收方的客户端会对报文主体再实施五遍相同的MD5算法。总计出的值与字段值作相比后,即可判断出报文主体的准确性。

  Content-Range

  该字段可以针对范围请求重返响应,能告诉客户端作为响应重临的实体的哪个部分符合范围请求,字段值以字节为单位,表示如今发送部分及所有实体大小。

  Content-Type

  该字段表明了实体中央内相应的媒体类型。

  Expires

  该首部字段会将资源失效的日期告知客户端,缓存服务器在接受到含有首部字段Expires的响应后,会以缓存来答复请求,在Expires字段值指定的小运从前,响应的副本会平昔被保存。当跨越指定的年月后,缓存服务器在伸手发送过来时,会转向源服务器请求资源。

  Last-Modified

  该首部字段指明资源最后修改的时日,一般的话,这些值就是Request-ULacrosseI指定资源被涂改的光阴。

  为Cookie服务的首部字段

  库克ie的工作体制是用户识别及气象管理。Web网站为了管住用户的气象会透过Web浏览器,把一部分数码临时写入用户的处理器内,当用户访问该Web网站时,可通过通讯格局取回此前存放的Cookie,调用Cookie时,由于可校验Cookie的有效期以及发送方的域、路径、协议等音信,所以正规发表的Cookie内的数额不会因来自其他Web站点和攻击者的口诛笔伐而走漏。

  在此介绍七个最广泛的Cookie的首部字段:

  

首部字段名

说明

首部类型

Set-Cookie

开始状态管理所使用的的Cookie信息

响应首部字段

Cookie

服务器接收到的Cookie信息

请求首部字段

  Set-Cookie

  当服务器准备上马管制客户端的气象时,会预先告知各个新闻。上面罗列Set-Cookie的字段值:

属性

说明

NAME=VALUE

赋予Cookie的名称和其值(必需项)

expires=DATE

Cookie的有效期(若不明确指定则默认为浏览器关闭前为止)

path-PATH

将服务器上的文件目录作为Cookie的适用对象(若不指定则默认为文档所在的文件目录)

domain=域名

作为Cookie适用对象的域名(若不指定则默认为创建Cookie的服务器的域名)

Secure

仅在HTTPS安全通行时才会发送Cookie

HttpOnly

加以限制,使Cookie不能被JavaScript脚本访问,目的是为防止跨站脚本攻击对Cookie信息的获取

  Cookie

  该首部字段会告诉服务器,当客户端想博得HTTP状态管理协理时,就会在呼吁中含有从服务器收到到的库克ie。接收到三个Cookie时,同样可以以八个Cookie形式发送。

  其余首部字段

  HTTP首部字段是足以自行增加的。所以Web服务器和浏览器的利用上,会晤世种种非标你准的首部字段。

  X-Frame-Options

  该首部字段属于HTTP响应首部,用于控制网站内容在其他Web网站的Frame标签内的实际题材,主要目的是为了防备点击恐吓攻击。该字段有多少个可指定的字段值:

字段值

含义

DENY

拒绝

SAMEORIGIN

仅同源域名下的匹配时许可

  X-XSS-Protection

  该首部字段属于HTTP响应首部,它是针对性跨站脚本攻击(XSS)的一种对策,用于控制浏览器XSS防护机制的开关。该字段有多个可指定的字段值:

字段值

含义

0

将XSS过滤设置成无效状态

1

将XSS过滤设置成有效状态

  DNT

  该首部字段属于HTTP请求首部,DNT首部自担是不容个人音讯被采访,是意味拒绝被精准广告追踪的一种艺术。该字段有几个可以指定的值:

字段值

含义

0

同意被追踪

1

不同意被追踪

  P3P

  该首部字段属于HTTP响应首部,通过拔取P3P技术,可以让Web网站上的个人隐秘贬称过一种仅供程序可见道的花样,以达到爱护用户隐秘的目标。

  要举行P3P的设定,需求这么做:

  管理 7

 

Post Author: admin

发表评论

电子邮件地址不会被公开。 必填项已用*标注