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

本文主要是介绍SpringBoot基于配置实现短信服务策略的动态切换,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《SpringBoot基于配置实现短信服务策略的动态切换》这篇文章主要为大家详细介绍了SpringBoot在接入多个短信服务商(如阿里云、腾讯云、华为云)后,如何根据配置或环境切换使用不同的服务商,需...

目标功能

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

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

可配置默认短信服务商

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

可扩展更多服务商/通道

示例配置(application.yml)

sms:
  default-provider: aliyun
  providers:
    aliyun:
      enabled: true
      app-id: xxx
      jsapp-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 cwww.chinasem.cnlass TencentSmsProvider implements SmsProvider {

   android 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 - 测试一波

总结

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

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

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

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

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

这篇关于SpringBoot基于配置实现短信服务策略的动态切换的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1154377

相关文章

Java+AI驱动实现PDF文件数据提取与解析

《Java+AI驱动实现PDF文件数据提取与解析》本文将和大家分享一套基于AI的体检报告智能评估方案,详细介绍从PDF上传、内容提取到AI分析、数据存储的全流程自动化实现方法,感兴趣的可以了解下... 目录一、核心流程:从上传到评估的完整链路二、第一步:解析 PDF,提取体检报告内容1. 引入依赖2. 封装

使用Spring Cache本地缓存示例代码

《使用SpringCache本地缓存示例代码》缓存是提高应用程序性能的重要手段,通过将频繁访问的数据存储在内存中,可以减少数据库访问次数,从而加速数据读取,:本文主要介绍使用SpringCac... 目录一、Spring Cache简介核心特点:二、基础配置1. 添加依赖2. 启用缓存3. 缓存配置方案方案

Java实现复杂查询优化的7个技巧小结

《Java实现复杂查询优化的7个技巧小结》在Java项目中,复杂查询是开发者面临的“硬骨头”,本文将通过7个实战技巧,结合代码示例和性能对比,手把手教你如何让复杂查询变得优雅,大家可以根据需求进行选择... 目录一、复杂查询的痛点:为何你的代码“又臭又长”1.1冗余变量与中间状态1.2重复查询与性能陷阱1.

深度剖析SpringBoot日志性能提升的原因与解决

《深度剖析SpringBoot日志性能提升的原因与解决》日志记录本该是辅助工具,却为何成了性能瓶颈,SpringBoot如何用代码彻底破解日志导致的高延迟问题,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言第一章:日志性能陷阱的底层原理1.1 日志级别的“双刃剑”效应1.2 同步日志的“吞吐量杀手”

python 线程池顺序执行的方法实现

《python线程池顺序执行的方法实现》在Python中,线程池默认是并发执行任务的,但若需要实现任务的顺序执行,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋... 目录方案一:强制单线程(伪顺序执行)方案二:按提交顺序获取结果方案三:任务间依赖控制方案四:队列顺序消

Spring创建Bean的八种主要方式详解

《Spring创建Bean的八种主要方式详解》Spring(尤其是SpringBoot)提供了多种方式来让容器创建和管理Bean,@Component、@Configuration+@Bean、@En... 目录引言一、Spring 创建 Bean 的 8 种主要方式1. @Component 及其衍生注解

SpringBoot通过main方法启动web项目实践

《SpringBoot通过main方法启动web项目实践》SpringBoot通过SpringApplication.run()启动Web项目,自动推断应用类型,加载初始化器与监听器,配置Spring... 目录1. 启动入口:SpringApplication.run()2. SpringApplicat

Nginx中配置使用非默认80端口进行服务的完整指南

《Nginx中配置使用非默认80端口进行服务的完整指南》在实际生产环境中,我们经常需要将Nginx配置在其他端口上运行,本文将详细介绍如何在Nginx中配置使用非默认端口进行服务,希望对大家有所帮助... 目录一、为什么需要使用非默认端口二、配置Nginx使用非默认端口的基本方法2.1 修改listen指令

Redis实现分布式锁全过程

《Redis实现分布式锁全过程》文章介绍Redis实现分布式锁的方法,包括使用SETNX和EXPIRE命令确保互斥性与防死锁,Redisson客户端提供的便捷接口,以及Redlock算法通过多节点共识... 目录Redis实现分布式锁1. 分布式锁的基本原理2. 使用 Redis 实现分布式锁2.1 获取锁

Java利用@SneakyThrows注解提升异常处理效率详解

《Java利用@SneakyThrows注解提升异常处理效率详解》这篇文章将深度剖析@SneakyThrows的原理,用法,适用场景以及隐藏的陷阱,看看它如何让Java异常处理效率飙升50%,感兴趣的... 目录前言一、检查型异常的“诅咒”:为什么Java开发者讨厌它1.1 检查型异常的痛点1.2 为什么说