|
@@ -16,12 +16,13 @@ import com.ruoyi.common.utils.reflect.ReflectUtils;
|
|
import com.ruoyi.common.utils.spring.SpringUtils;
|
|
import com.ruoyi.common.utils.spring.SpringUtils;
|
|
import com.ruoyi.framework.config.properties.CaptchaProperties;
|
|
import com.ruoyi.framework.config.properties.CaptchaProperties;
|
|
import com.ruoyi.framework.config.properties.MailProperties;
|
|
import com.ruoyi.framework.config.properties.MailProperties;
|
|
-import com.ruoyi.sms.config.properties.SmsProperties;
|
|
|
|
-import com.ruoyi.sms.core.SmsTemplate;
|
|
|
|
-import com.ruoyi.sms.entity.SmsResult;
|
|
|
|
import com.ruoyi.system.service.ISysConfigService;
|
|
import com.ruoyi.system.service.ISysConfigService;
|
|
import lombok.RequiredArgsConstructor;
|
|
import lombok.RequiredArgsConstructor;
|
|
import lombok.extern.slf4j.Slf4j;
|
|
import lombok.extern.slf4j.Slf4j;
|
|
|
|
+import org.dromara.sms4j.api.SmsBlend;
|
|
|
|
+import org.dromara.sms4j.api.entity.SmsResponse;
|
|
|
|
+import org.dromara.sms4j.core.factory.SmsFactory;
|
|
|
|
+import org.dromara.sms4j.provider.enumerate.SupplierType;
|
|
import org.springframework.expression.Expression;
|
|
import org.springframework.expression.Expression;
|
|
import org.springframework.expression.ExpressionParser;
|
|
import org.springframework.expression.ExpressionParser;
|
|
import org.springframework.expression.spel.standard.SpelExpressionParser;
|
|
import org.springframework.expression.spel.standard.SpelExpressionParser;
|
|
@@ -32,6 +33,7 @@ import org.springframework.web.bind.annotation.RestController;
|
|
import javax.validation.constraints.NotBlank;
|
|
import javax.validation.constraints.NotBlank;
|
|
import java.time.Duration;
|
|
import java.time.Duration;
|
|
import java.util.HashMap;
|
|
import java.util.HashMap;
|
|
|
|
+import java.util.LinkedHashMap;
|
|
import java.util.Map;
|
|
import java.util.Map;
|
|
|
|
|
|
/**
|
|
/**
|
|
@@ -47,7 +49,6 @@ import java.util.Map;
|
|
public class CaptchaController {
|
|
public class CaptchaController {
|
|
|
|
|
|
private final CaptchaProperties captchaProperties;
|
|
private final CaptchaProperties captchaProperties;
|
|
- private final SmsProperties smsProperties;
|
|
|
|
private final ISysConfigService configService;
|
|
private final ISysConfigService configService;
|
|
private final MailProperties mailProperties;
|
|
private final MailProperties mailProperties;
|
|
|
|
|
|
@@ -58,21 +59,18 @@ public class CaptchaController {
|
|
*/
|
|
*/
|
|
@GetMapping("/captchaSms")
|
|
@GetMapping("/captchaSms")
|
|
public R<Void> smsCaptcha(@NotBlank(message = "{user.phonenumber.not.blank}") String phonenumber) {
|
|
public R<Void> smsCaptcha(@NotBlank(message = "{user.phonenumber.not.blank}") String phonenumber) {
|
|
- if (!smsProperties.getEnabled()) {
|
|
|
|
- return R.fail("当前系统没有开启短信功能!");
|
|
|
|
- }
|
|
|
|
String key = CacheConstants.CAPTCHA_CODE_KEY + phonenumber;
|
|
String key = CacheConstants.CAPTCHA_CODE_KEY + phonenumber;
|
|
String code = RandomUtil.randomNumbers(4);
|
|
String code = RandomUtil.randomNumbers(4);
|
|
RedisUtils.setCacheObject(key, code, Duration.ofMinutes(Constants.CAPTCHA_EXPIRATION));
|
|
RedisUtils.setCacheObject(key, code, Duration.ofMinutes(Constants.CAPTCHA_EXPIRATION));
|
|
// 验证码模板id 自行处理 (查数据库或写死均可)
|
|
// 验证码模板id 自行处理 (查数据库或写死均可)
|
|
String templateId = "";
|
|
String templateId = "";
|
|
- Map<String, String> map = new HashMap<>(1);
|
|
|
|
|
|
+ LinkedHashMap<String, String> map = new LinkedHashMap<>(1);
|
|
map.put("code", code);
|
|
map.put("code", code);
|
|
- SmsTemplate smsTemplate = SpringUtils.getBean(SmsTemplate.class);
|
|
|
|
- SmsResult result = smsTemplate.send(phonenumber, templateId, map);
|
|
|
|
- if (!result.isSuccess()) {
|
|
|
|
- log.error("验证码短信发送异常 => {}", result);
|
|
|
|
- return R.fail(result.getMessage());
|
|
|
|
|
|
+ SmsBlend smsBlend = SmsFactory.createSmsBlend(SupplierType.ALIBABA);
|
|
|
|
+ SmsResponse smsResponse = smsBlend.sendMessage(phonenumber, templateId, map);
|
|
|
|
+ if (!"OK".equals(smsResponse.getCode())) {
|
|
|
|
+ log.error("验证码短信发送异常 => {}", smsResponse);
|
|
|
|
+ return R.fail(smsResponse.getMessage());
|
|
}
|
|
}
|
|
return R.ok();
|
|
return R.ok();
|
|
}
|
|
}
|