开发者

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

目录
  • 目标功能
  • 示例配置(application.yml)
  • 配置类绑定
  • 短信发送策略接口
  • 示例:阿里云 & 腾讯云 实现类
  • 动态选择器(默认服务商 + 指定服务商)
  • 接口测试
  • 测试效果
  • 总结

目标功能

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

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

可配置默认短信服务商

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

可扩展更多服务商/通道

示例配置(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.devze.comlass 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 - 测试一波

总结

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

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

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

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

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

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新开发

开发排行榜