From 664184af3e070dee665ee736caffa0297804975f Mon Sep 17 00:00:00 2001 From: KKSU <15274802129@163.com> Date: Tue, 18 Mar 2025 11:46:02 +0800 Subject: [PATCH] perf(mall): 移除会员利润计算中的异步执行 --- src/main/java/cc/mrbird/febs/mall/controller/CommonController.java | 131 +++++++++++++++++++++++++++++++------------ 1 files changed, 93 insertions(+), 38 deletions(-) diff --git a/src/main/java/cc/mrbird/febs/mall/controller/CommonController.java b/src/main/java/cc/mrbird/febs/mall/controller/CommonController.java index 87f7a27..bab14ba 100644 --- a/src/main/java/cc/mrbird/febs/mall/controller/CommonController.java +++ b/src/main/java/cc/mrbird/febs/mall/controller/CommonController.java @@ -5,20 +5,20 @@ import cc.mrbird.febs.common.exception.FebsException; import cc.mrbird.febs.common.utils.*; import cc.mrbird.febs.mall.dto.AccountAndCodeDto; +import cc.mrbird.febs.mall.dto.ApiCheckTraceInfoDto; import cc.mrbird.febs.mall.dto.Base64UploadDto; import cc.mrbird.febs.mall.entity.DataDictionaryCustom; import cc.mrbird.febs.mall.service.ICommonService; import cn.hutool.core.util.IdUtil; import cn.hutool.core.util.StrUtil; -import io.swagger.annotations.Api; -import io.swagger.annotations.ApiOperation; -import io.swagger.annotations.ApiParam; +import com.best.javaSdk.kdTraceQuery.response.KdTraceQueryRsp; +import io.swagger.annotations.*; import lombok.RequiredArgsConstructor; import lombok.extern.slf4j.Slf4j; +import org.springframework.beans.factory.annotation.Value; import org.springframework.validation.annotation.Validated; import org.springframework.web.bind.annotation.*; import org.springframework.web.multipart.MultipartFile; -import sun.misc.BASE64Encoder; import java.io.IOException; import java.util.HashMap; @@ -40,7 +40,7 @@ private final RedisUtils redisUtils; private final ICommonService commonService; - @ApiOperation(value = "获取验证码接口", notes = "获取验证码通用接口") + @ApiOperation(value = "(马来西亚)INFOBIP获取验证码接口", notes = "(马来西亚)INFOBIP获取验证码接口") @GetMapping(value = "/verifyCode") public FebsResponse verifyCode(@ApiParam(name = "account", value = "手机号", required = true) @RequestParam(value = "account") String account, @ApiParam(name = "type", value = "类型1-手机号", required = true) @RequestParam("type") String type) { @@ -53,9 +53,7 @@ // 发送手机验证码 if (AppContants.ACCOUNT_TYPE_MOBILE.equals(type)) { -// boolean result = Sms106Send.sendVerifyCode(account, code.toString(), 2); - boolean result = ZzSmsSend.sendALiYun(account, code.toString()); -// boolean result = ZzSmsSend.sendVerifyCode(account, code.toString(), 2); + boolean result = InfobipSmsSend.sendSms(account, code.toString()); if (result) { Map<String, Object> map = new HashMap<>(); boolean flag = redisUtils.set(AppContants.VERIFY_CODE_PREFIX + account, code, 120); @@ -78,9 +76,31 @@ return new FebsResponse().fail().message("验证码发送失败"); } - @ApiOperation(value = "获取阿里云验证码接口", notes = "获取阿里云验证码接口") + @ApiOperation(value = "假的获取阿里云验证码接口", notes = "假的获取阿里云验证码接口") @GetMapping(value = "/aliVerifyCode") public FebsResponse aliVerifyCode(@ApiParam(name = "account", value = "手机号", required = true) @RequestParam(value = "account") String account, + @ApiParam(name = "type", value = "类型1-手机号", required = true) @RequestParam("type") String type) { + log.info("#账号:{}, 类型:{}#", account, type); + + Integer code = (int) ((Math.random() * 9 + 1) * 100000); + if (StrUtil.isNotBlank(redisUtils.getString(AppContants.VERIFY_CODE_PREFIX + account))) { + throw new FebsException("验证码已发送"); + } + boolean flag = redisUtils.set(AppContants.VERIFY_CODE_PREFIX + account, code, 120); + if(flag){ + + Map<String, Object> map = new HashMap<>(); + map.put("code", code); + return new FebsResponse().success().data(map); + }else{ + return new FebsResponse().fail().message("验证码发送失败"); + } + + } + + @ApiOperation(value = "获取阿里云验证码接口", notes = "获取阿里云验证码接口") + @GetMapping(value = "/aliVerifyCodeReal") + public FebsResponse aliVerifyCodeReal(@ApiParam(name = "account", value = "手机号", required = true) @RequestParam(value = "account") String account, @ApiParam(name = "type", value = "类型1-手机号", required = true) @RequestParam("type") String type) { log.info("#账号:{}, 类型:{}#", account, type); @@ -88,15 +108,15 @@ if (StrUtil.isNotBlank(redisUtils.getString(AppContants.VERIFY_CODE_PREFIX + account))) { throw new FebsException("验证码已发送"); } - // 发送手机验证码 if (AppContants.ACCOUNT_TYPE_MOBILE.equals(type)) { boolean result = ZzSmsSend.sendALiYun(account, code.toString()); if (result) { Map<String, Object> map = new HashMap<>(); - boolean flag = redisUtils.set(AppContants.VERIFY_CODE_PREFIX + account, code, 300); - map.put("code", flag); - return new FebsResponse().success().message("验证码发送成功"); + boolean flag = redisUtils.set(AppContants.VERIFY_CODE_PREFIX + account, code, 120); + map.put("code", code); + return new FebsResponse().success().message("发送成功"); +// return new FebsResponse().success().data(map); } // 发送邮件验证码 } else if (AppContants.ACCOUNT_TYPE_EMAIL.equals(type)) { @@ -115,40 +135,60 @@ } /** + * 通用上传请求 + */ + // 文件保存目录路径 + @Value("${static.resource.url}") + private String resourceUrl; + // 文件保存目录URL + @Value("${static.resource.path}") + private String resourcePath; + + @ControllerEndpoint(operation = "文件上传服务器", exceptionMessage = "上传失败") + @PostMapping(value = "/fileUploadEsc") + public Map<String,Object> fileUploadEsc(@RequestBody @Validated MultipartFile file) throws IOException { + if (file == null) { + throw new FebsException("上传文件不能为空"); + } + return FileUtil.fileUploadEsc(file,resourceUrl,resourcePath); + } + + /** * 图片上传 * @return */ @PostMapping(value = "/uploadFileBase64") @ControllerEndpoint(operation = "图片上传", exceptionMessage = "上传失败") - public Map<String,Object> uploadFileBase64(@RequestBody @Validated MultipartFile file) { + public Map<String,Object> uploadFileBase64(@RequestBody @Validated MultipartFile file) throws IOException { if (file == null || file.isEmpty()) { return new FebsResponse().message("上传文件为空"); } + return FileUtil.fileUploadEsc(file,resourceUrl,resourcePath); - //文件加密 - BASE64Encoder base64Encoder =new BASE64Encoder(); - String base64EncoderImg = null; - try { - base64EncoderImg = base64Encoder.encode(file.getBytes()); - } catch (IOException e) { - e.printStackTrace(); - } - - String imageFuffix = ".png"; - String imageNames = System.currentTimeMillis() + IdUtil.simpleUUID() + imageFuffix; - String imageName = "uploadeFile/" + imageNames; - OssUtils.uploadFileWithBase64(base64EncoderImg, imageName); - String bucket_name ="https://excoin.oss-cn-hangzhou.aliyuncs.com"; - String url = bucket_name + "/" + imageName; - - Map<String,Object> map = new HashMap<String,Object>(); - Map<String,Object> map2 = new HashMap<String,Object>(); - map.put("code",0);//0表示成功,1失败 - map.put("msg","上传成功");//提示消息 - map.put("data",map2); - map2.put("src",url);//图片url - map2.put("title",imageNames);//图片名称,这个会显示在输入框里 - return map; +// //文件加密 +// BASE64Encoder base64Encoder =new BASE64Encoder(); +// String base64EncoderImg = null; +// try { +// base64EncoderImg = base64Encoder.encode(file.getBytes()); +// } catch (IOException e) { +// e.printStackTrace(); +// } +// +// String imageFuffix = ".png"; +// String imageNames = System.currentTimeMillis() + IdUtil.simpleUUID() + imageFuffix; +// String imageName = "uploadeFile/" + imageNames; +// OssUtils.uploadFileWithBase64(base64EncoderImg, imageName); +// String bucket_name ="https://excoin.oss-cn-hangzhou.aliyuncs.com"; +// String url = bucket_name + "/" + imageName; +// +// Map<String,Object> map = new HashMap<String,Object>(); +// Map<String,Object> map2 = new HashMap<String,Object>(); +// map.put("code",0);//0表示成功,1失败 +// map.put("msg","上传成功");//提示消息 +// map.put("data",map2); +// map2.put("src",url);//图片url +// map2.put("title",imageNames);//图片名称,这个会显示在输入框里 +// return map; } @ApiOperation(value = "数据字典") @@ -192,4 +232,19 @@ } return new FebsResponse().fail().message("验证码错误"); } + + @ApiOperation(value = "获取快递信息接口") + @ApiResponses({ + @ApiResponse(code = 200, message = "success", response = KdTraceQueryRsp.class) + }) + @PostMapping(value = "/checkTraceInfo") + public FebsResponse checkTraceInfo(@RequestBody ApiCheckTraceInfoDto checkTraceInfoDto) { + + KdTraceQueryRsp traceQueryRsp = commonService.checkTraceInfo(checkTraceInfoDto); + boolean result = traceQueryRsp.isResult(); + if (result) { + return new FebsResponse().success().data(traceQueryRsp); + } + return new FebsResponse().fail().message("请检查您的快递单号是否输入正确。"); + } } -- Gitblit v1.9.1