首页   注册   登录
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
拉勾
V2EX  ›  程序员

设计与封装第三方短信接口的问题

  •  
  •   doggg · 2017-11-07 20:31:43 +08:00 · 1798 次点击
    这是一个创建于 496 天前的主题,其中的信息可能已经有所发展或是发生改变。

    最近在工作中,公司( Java 系)使用的某一短信平台偶有问题。而且短信的代码有很久的历史包袱,上司叫我重构短信部分的代码。

    现在接入的短信平台典型有阿里云,云片,互亿无线,还有一些不准备充钱但还有余额的就不列出来了。

    上司希望我能处理好短信发送失败能切换渠道尽力尝试,国际短信,以及发送结果回调的处理。

    这几天最烧脑袋的还是软件设计的问题。

    不同的短信渠道处理方式不太一样,比如阿里只能通过 templateCode (模板代码)与模板参数发短信,而互亿无线则需要把短信全部拼接成字符串上传(对方会根据内容识别已审核的模板),而云片则支持两种方式。

    而不同渠道所需要的方法参数也是不一样的。

    所以简单设计一个 interface 再实现是行不通的。

    public interface SendSms {
        void send(xxx);
    }
    

    在这里问各位 v 友怎么优雅地抽象封装国内大部分短信 API 接口。

    谢谢

    7 回复  |  直到 2017-11-08 11:45:42 +08:00
        1
    xem   2017-11-07 23:02:37 +08:00
    不管渠道怎么要求,你一律使用短信模板,做好各个渠道映射就 ok 了
        2
    m939594960   2017-11-07 23:07:42 +08:00
    php 实现
        3
    m939594960   2017-11-07 23:11:37 +08:00
    sendSms(13010000000,'reg',['code'=>'123456','name'=>'赵 XX'])


    配置文件
    return [
    yupian => [
    type=> 'template'
    template=>[reg=>'SMS_001'],

    ],
    aliyun => [
    type => 'content',
    template => [reg=>'恭喜{name}你注册成功注册码{code}']
    ]
    ]
        4
    xjp   2017-11-08 00:24:01 +08:00 via iPhone
    不要统一封装了 每种渠道写一个 再外层把所有渠道包裹起来对外提供一个接口就可以了
        5
    dorothyREN   2017-11-08 09:10:07 +08:00
    老哥。还需要短信接口吗
        6
    doggg   2017-11-08 09:21:04 +08:00
    @xem 这个真不行。

    @m939594960 @xjp 谢谢

    @dorothyREN 不用哦

    所以看起来还是把登录和注册的验证码独立抽成两个方法,其他营销短信另说。方法入参只提供手机号和验证码。具体的实现由另外写了。想不出其他更好的办法
        7
    danielmiao   2017-11-08 11:45:42 +08:00
    创建内部短信模板,给内部服务调用
    针对每个渠道商建立不同的 adapt,做好映射关系
    关于   ·   FAQ   ·   API   ·   我们的愿景   ·   广告投放   ·   感谢   ·   实用小工具   ·   1959 人在线   最高记录 4385   ·  
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.3 · 18ms · UTC 00:17 · PVG 08:17 · LAX 17:17 · JFK 20:17
    ♥ Do have faith in what you're doing.
    沪ICP备16043287号-1