SpringBoot基于配置实现短信服务策略的动态切换

 更新时间:2025年04月25日 14:57:53   作者:颇有几分姿色  
这篇文章主要为大家详细介绍了SpringBoot在接入多个短信服务商(如阿里云、腾讯云、华为云)后,如何根据配置或环境切换使用不同的服务商,需要的小伙伴可以了解下

目标功能

多短信服务商(策略)接入

支持配置启用/禁用服务商

可配置默认短信服务商

支持动态切换(如按业务类型、环境等)

可扩展更多服务商/通道

示例配置(application.yml)

sms:
  default-provider: aliyun
  providers:
    aliyun:
      enabled: true
      app-id: xxx
      app-secret: yyy
    tencent:
      enabled: true
      app-id: aaa
      app-secret: bbb
    huawei:
      enabled: false
      app-id: 123
      app-secret: 456

配置类绑定

@Component
@ConfigurationProperties(prefix = "sms")
@Data
public class SmsProperties {

    private String defaultProvider;

    private Map<String, ProviderConfig> providers;

    @Data
    public static class ProviderConfig {
        private boolean enabled;
        private String appId;
        private String appSecret;
    }
}

短信发送策略接口

public interface SmsProvider {
    String getProviderKey(); // aliyun / tencent / huawei
    boolean isEnabled();     // 是否启用(可从配置读取)
    void sendSms(String phone, String message);
}

示例:阿里云 & 腾讯云 实现类

@Component
public class AliyunSmsProvider implements SmsProvider {

    private final SmsProperties smsProperties;

    public AliyunSmsProvider(SmsProperties smsProperties) {
        this.smsProperties = smsProperties;
    }

    @Override
    public String getProviderKey() {
        return "aliyun";
    }

    @Override
    public boolean isEnabled() {
        SmsProperties.ProviderConfig config = smsProperties.getProviders().get(getProviderKey());
        return config != null && config.isEnabled();
    }

    @Override
    public void sendSms(String phone, String message) {
        System.out.println("【阿里云】发送短信:" + phone + " - " + message);
        // 实际调用 SDK
    }
}

@Component
public class TencentSmsProvider implements SmsProvider {

    private final SmsProperties smsProperties;

    public TencentSmsProvider(SmsProperties smsProperties) {
        this.smsProperties = smsProperties;
    }

    @Override
    public String getProviderKey() {
        return "tencent";
    }

    @Override
    public boolean isEnabled() {
        SmsProperties.ProviderConfig config = smsProperties.getProviders().get(getProviderKey());
        return config != null && config.isEnabled();
    }

    @Override
    public void sendSms(String phone, String message) {
        System.out.println("【腾讯云】发送短信:" + phone + " - " + message);
        // 实际调用 SDK
    }
}

动态选择器(默认服务商 + 指定服务商)

@Component
public class SmsProviderRouter {

    private final SmsProperties smsProperties;
    private final Map<String, SmsProvider> providerMap;

    public SmsProviderRouter(List<SmsProvider> providers, SmsProperties smsProperties) {
        this.smsProperties = smsProperties;
        this.providerMap = providers.stream()
        .collect(Collectors.toMap(SmsProvider::getProviderKey, p -> p));
    }

    public void sendSms(String phone, String message, @Nullable String providerKey) {
        String key = (providerKey != null) ? providerKey : smsProperties.getDefaultProvider();
        SmsProvider provider = providerMap.get(key);

        if (provider == null || !provider.isEnabled()) {
            throw new IllegalStateException("短信服务商不可用: " + key);
        }

        provider.sendSms(phone, message);
    }
}

接口测试

@RestController
@RequestMapping("/sms")
public class SmsController {

    private final SmsProviderRouter router;

    public SmsController(SmsProviderRouter router) {
        this.router = router;
    }

    @PostMapping("/send")
    public String send(@RequestParam String phone,
                       @RequestParam String msg,
                       @RequestParam(required = false) String provider) {
        router.sendSms(phone, msg, provider);
        return "发送成功";
    }
}

测试效果

默认发送(配置的是 aliyun)

POST /sms/send?phone=13800138000&msg=测试一波

输出:

【阿里云】发送短信:13800138000 - 测试一波

指定腾讯云发送:

POST /sms/send?phone=13800138000&msg=测试一波&provider=tencent

输出:

【腾讯云】发送短信:13800138000 - 测试一波

总结

通过配置驱动 + 策略模式的组合,短信服务切换更灵活,具备:

  • 高扩展性(支持无限短信服务商)
  • 高可维护性(配置即策略)
  • 高可控性(启用、禁用、默认、切换快速搞定)

不仅适用于短信服务,还可拓展到:

  • 第三方支付(支付宝 / 微信 / Stripe)
  • 文件存储(阿里 OSS / 腾讯 COS)
  • 消息通知(钉钉 / 企业微信 / 飞书)

到此这篇关于SpringBoot基于配置实现短信服务策略的动态切换的文章就介绍到这了,更多相关SpringBoot动态切换短信服务内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • J2ME 程序开发注意要点

    J2ME 程序开发注意要点

    讲Java基础的书籍中都是以J2SE来讲基础,这就给学习造成了一些不必要的麻烦,下面将J2ME中用到的和不需要的Java基础知识做一个简单的说明
    2016-07-07
  • Java父线程(或是主线程)等待所有子线程退出的实例

    Java父线程(或是主线程)等待所有子线程退出的实例

    下面小编就为大家分享一篇Java父线程(或是主线程)等待所有子线程退出的实例,具有很好的参考价值,希望对大家有所帮助
    2017-11-11
  • java线程之线程的生命周期的使用

    java线程之线程的生命周期的使用

    本篇文章介绍了,java线程之线程的生命周期的使用。需要的朋友参考下
    2013-05-05
  • Java(Springboot)项目调用第三方WebService接口实现代码

    Java(Springboot)项目调用第三方WebService接口实现代码

    这篇文章主要介绍了如何使用Java调用WebService接口,传递XML参数,获取XML响应,并将其解析为JSON格式,文中详细描述了WSDL文档的使用、HttpClientBuilder和Apache Axis两种调用方式的具体实现步骤,需要的朋友可以参考下
    2025-02-02
  • Java实现单词倒序输出

    Java实现单词倒序输出

    这篇文章主要介绍了Java实现单词倒序输出,帮助大家更好的理解和学习Java,感兴趣的朋友可以了解下
    2020-08-08
  • Elasticsearch 在 Java 中的使用示例教程

    Elasticsearch 在 Java 中的使用示例教程

    本文介绍了如何在Java中使用Elasticsearch,涵盖了连接、基本CRUD 操作、复杂查询、索引管理和聚合操作等方面的内容,通过示例,开发者可以一步步地掌握如何在 Java 项目中集成 Elasticsearch,并利用其强大的搜索和分析功能来构建高效的应用程序,感兴趣的朋友一起看看吧
    2024-08-08
  • JAVA实现连接本地打印机并打印文件的实现代码

    JAVA实现连接本地打印机并打印文件的实现代码

    这篇文章主要介绍了JAVA实现连接本地打印机并打印文件的实现代码,需要的朋友可以参考下
    2019-10-10
  • SpringBoot bean的多种加载方式示例详解

    SpringBoot bean的多种加载方式示例详解

    本文详细介绍了在SpringBoot中加载Bean的多种方式,包括通过xml配置文件、注解定义、特殊方式如FactoryBean、@ImportResource、ApplicationContext以及使用@Import注解导入bean的方法,感兴趣的朋友跟随小编一起看看吧
    2024-10-10
  • Java自定义Enum的实现示例

    Java自定义Enum的实现示例

    Java中的自定义Enum类型是一种特殊的类,用于表示固定数量的常量值,本文主要介绍了Java自定义Enum的实现示例,具有一定的参考价值,感兴趣的可以了解一下
    2023-12-12
  • Spring基于注解配置事务的属性

    Spring基于注解配置事务的属性

    这篇文章主要为大家详细介绍了Spring基于注解配置事务的属性,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-08-08

最新评论