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

