SpringBoot基于配置實現(xiàn)短信服務策略的動態(tài)切換
目標功能
多短信服務商(策略)接入
支持配置啟用/禁用服務商
可配置默認短信服務商
支持動態(tài)切換(如按業(yè)務類型、環(huán)境等)
可擴展更多服務商/通道
示例配置(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; } }
短信發(fā)送策略接口
public interface SmsProvider { String getProviderKey(); // aliyun / tencent / huawei boolean isEnabled(); // 是否啟用(可從配置讀?。? void sendSms(String phone, String message); }
示例:阿里云 & 騰訊云 實現(xiàn)類
@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("【阿里云】發(fā)送短信:" + 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("【騰訊云】發(fā)送短信:" + phone + " - " + message); // 實際調用 SDK } }
動態(tài)選擇器(默認服務商 + 指定服務商)
@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 "發(fā)送成功"; } }
測試效果
默認發(fā)送(配置的是 aliyun)
POST /sms/send?phone=13800138000&msg=測試一波
輸出:
【阿里云】發(fā)送短信:13800138000 - 測試一波
指定騰訊云發(fā)送:
POST /sms/send?phone=13800138000&msg=測試一波&provider=tencent
輸出:
【騰訊云】發(fā)送短信:13800138000 - 測試一波
總結
通過配置驅動 + 策略模式的組合,短信服務切換更靈活,具備:
- 高擴展性(支持無限短信服務商)
- 高可維護性(配置即策略)
- 高可控性(啟用、禁用、默認、切換快速搞定)
不僅適用于短信服務,還可拓展到:
- 第三方支付(支付寶 / 微信 / Stripe)
- 文件存儲(阿里 OSS / 騰訊 COS)
- 消息通知(釘釘 / 企業(yè)微信 / 飛書)
到此這篇關于SpringBoot基于配置實現(xiàn)短信服務策略的動態(tài)切換的文章就介紹到這了,更多相關SpringBoot動態(tài)切換短信服務內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Java(Springboot)項目調用第三方WebService接口實現(xiàn)代碼
這篇文章主要介紹了如何使用Java調用WebService接口,傳遞XML參數(shù),獲取XML響應,并將其解析為JSON格式,文中詳細描述了WSDL文檔的使用、HttpClientBuilder和Apache?Axis兩種調用方式的具體實現(xiàn)步驟,需要的朋友可以參考下2025-02-02JAVA實現(xiàn)連接本地打印機并打印文件的實現(xiàn)代碼
這篇文章主要介紹了JAVA實現(xiàn)連接本地打印機并打印文件的實現(xiàn)代碼,需要的朋友可以參考下2019-10-10