让简单的事情回归简单的本质。 SMS4J为短信聚合框架,帮您轻松集成多家短信服务,解决接入多个短信SDK的繁琐流程。 目前已接入数家常见的短信服务商,后续将会继续集成。后续的版本中我们还将推出更多的相关功能 你的 ️Star️,是我的动力!如果你觉得还不错,请点上一颗小星星
Go to file
wind 298e7c48e5 3.3.3升级
1. https://gitee.com/dromara/sms4j/issues/IAN87I
2. 解决腾讯云多参数发送报错问题
修复异常执行器再未进行自定义的情况下,会将异常堆栈吞掉的问题
3. 天翼云eop-date参数实际生产少8小时
2024-09-07 17:55:58 +08:00
public 修改父模块artifactId为sms4j 2023-04-12 22:31:51 +08:00
sms4j-api 修复异常执行器再未进行自定义的情况下,会将异常堆栈吞掉的问题 2024-08-28 17:38:39 +08:00
sms4j-comm 3.3.3升级 2024-09-07 17:55:58 +08:00
sms4j-core 修复 开启拦截器后导致短信发送失败的问题 2024-08-08 19:19:28 +08:00
sms4j-email-jakarta 常量使用大写 2024-04-22 10:36:06 +08:00
sms4j-Email-plugin 常量使用大写 2024-04-22 10:36:06 +08:00
sms4j-javase-plugin 修复 开启拦截器后导致短信发送失败的问题 2024-08-08 19:19:28 +08:00
sms4j-oa-plugin 常量使用大写 2024-04-22 10:36:06 +08:00
sms4j-provider fix 天翼云eop-date参数实际生产少8小时 bug #IAKMPG 2024-08-19 19:10:33 +08:00
sms4j-solon-plugin 修复 开启拦截器后导致短信发送失败的问题 2024-08-08 19:19:28 +08:00
sms4j-solon-plugin-example !180 add 添加螺丝帽短信接入 并添加时间日期工具类 2024-06-24 07:53:49 +00:00
sms4j-spring-boot-example !180 add 添加螺丝帽短信接入 并添加时间日期工具类 2024-06-24 07:53:49 +00:00
sms4j-spring-boot-starter 修复 开启拦截器后导致短信发送失败的问题 2024-08-08 19:19:28 +08:00
.gitignore update 忽略mac下文件Ds_Store 2023-12-18 17:39:59 +08:00
LICENSE Initial commit 2023-03-23 14:58:26 +00:00
pom.xml 3.3.3升级 2024-09-07 17:55:58 +08:00
README.md 3.3.3升级 2024-09-07 17:55:58 +08:00

sms4j v3.3.3

sms4j -- 让发送短信变的更简单

前言

在日常的开发过程中,短信的发送经常使用(尤其是中小型的外包公司),毕竟不是每个公司都有阿里腾讯一样的实力, 也不是每个都像银行联通等公司一样有内部的短信规程。第三方的短信往往是最常见的解决方案,但是市面上第三方短信服务商众多, 各家都有不同的方式和标准,每次需要使用时候,都需要花费时间去阅读文档和编写相应的工具,为一个短信浪费了太多的精力和时间。 这个工具的目的就是为了统一下各个厂商的短信发送工具的标准甚至于更换短信厂商只需要更改yml配置文件即可。
如果我们的项目对你产生了帮助或者你觉得还算值得鼓励请用你发财的小手帮助点上一个start
gitee github gitcode

官方文档

JavaDoc文档

支持厂商一览

在SpringBoot环境集成

  1. maven引入

    <dependency>
     <groupId>org.dromara.sms4j</groupId>
     <artifactId>sms4j-spring-boot-starter</artifactId>
     <version>最新版本</version>
    </dependency>
    
  2. 设置配置文件

    sms:
       config-type: yaml
       blends:
           自定义标识1:
             #阿里云的accessKey
             accessKeyId: 您的accessKey
             #阿里云的accessKeySecret
             accessKeySecret: 您的accessKeySecret
             #短信签名
             signature: 测试签名
             #模板ID 用于发送固定模板短信使用
             templateId: SMS_215125134
             #模板变量 上述模板的变量
             templateName: code
             #请求地址 默认为dysmsapi.aliyuncs.com 如无特殊改变可以不用设置
             requestUrl: dysmsapi.aliyuncs.com
           自定义标识2:
             #华为短信appKey
             appKey: 5N6fvXXXX920HaWhVXXXXXX7fYa
             #华为短信appSecret
             app-secret: Wujt7EYzZTBXXXXXXEhSP6XXXX
             #短信签名
             signature: 华为短信测试
              #通道号
             sender: 8823040504797
             #模板ID 如果使用自定义模板发送方法可不设定
             template-id: acXXXXXXXXc274b2a8263479b954c1ab5
             #华为回调地址,如不需要可不设置或为空
             statusCallBack:
             #华为分配的app请求地址
             url: https://XXXXX.cn-north-4.XXXXXXXX.com:443
           自定义标识3:
             #助通短信
             #助通终端用户管理的用户名 username 必填非登录账号密码请登录后台管理地址进行查看https://mix2.zthysms.com/login
             accessKeyId: tusxxxxxxXXX
             #助通终端用户管理的用户名 passwrod 必填;
             accessKeySecret: UbXXXxxx
             #短信签名,可选;可选的时候,只能使用自定义短信不能使用模板短信; 具体在这里查看审核过的短信签名https://mix2.zthysms.com/index.html#/SignatureManagement
             signature: 上海千XXXX
    
  3. 方法使用

@RestController
@RequestMapping("/test/")
public class DemoController {

    // 测试发送固定模板短信
    @RequestMapping("/")
    public void send() {
         //阿里云向此手机号发送短信
        SmsFactory.getSmsBlend("自定义标识1").sendMessage("18888888888","123456");
        //华为短信向此手机号发送短信
        SmsFactory.getSmsBlend("自定义标识2").sendMessage("16666666666","000000");
    }
}

配置详解

线程池配置

每一家厂商都对于异步短信有不同的支持,有些甚至没有,为了统一存在一个异步短信,我们配置了一个线程池用于执行异步短信任务,线程池默认配置如下:

sms:
  #核心线程池大小
  corePoolSize: 10
  #最大线程数
  maxPoolSize: 30
  #队列容量
  queueCapacity: 50
  #活跃时间
  keepAliveSeconds: 60
  # 线程名字前缀
  threadNamePrefix: sms-executor-
  #设置线程池关闭的时候等待所有任务都完成再继续销毁其他的Bean
  shutdownStrategy: true

以上线程池为默认的配置如果有需要可以跟随自己的需求在yml文件进行配置

参与贡献

1.  Fork 本仓库
2.  新建 Feat_xxx 分支
3.  提交代码
4.  新建 Pull Request 到 dev-3.0.x 分支

贡献原则

  • 我们原则上欢迎任何人为sms4j添加加瓦贡献代码
  • 贡献代码应注释完备按照javaDoc标准对 类,方法,变量,参数,返回值等信息说明
  • 新增的方法模块不能破坏原有结构和兼容性
  • 如果我们关闭了你的issues或者pr请查看回复内容我们会在回复中做出解释

分支介绍

  1. master 正式版分支最终发布到maven中央仓库的版本
  2. dev 开发分支贡献的代码将合并到这里无误后合并至preview