From e15c348bc992de7331d14d76451032358aae9289 Mon Sep 17 00:00:00 2001 From: KKSU <15274802129@163.com> Date: Thu, 09 Jan 2025 15:44:14 +0800 Subject: [PATCH] feat(mall): 商品列表增加活动筛选功能 --- src/main/java/cc/mrbird/febs/mall/controller/CommonController.java | 184 ++++++++++++++++++++++++++++++++++++++++++--- 1 files changed, 171 insertions(+), 13 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 0c1db62..dbe5a30 100644 --- a/src/main/java/cc/mrbird/febs/mall/controller/CommonController.java +++ b/src/main/java/cc/mrbird/febs/mall/controller/CommonController.java @@ -1,23 +1,29 @@ package cc.mrbird.febs.mall.controller; +import cc.mrbird.febs.common.annotation.ControllerEndpoint; import cc.mrbird.febs.common.entity.FebsResponse; import cc.mrbird.febs.common.exception.FebsException; -import cc.mrbird.febs.common.utils.AppContants; -import cc.mrbird.febs.common.utils.RedisUtils; -import cc.mrbird.febs.common.utils.SubMailSend; -import cc.mrbird.febs.common.utils.ZzSmsSend; +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 cc.mrbird.febs.mall.vo.OrderListVo; +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.web.bind.annotation.GetMapping; -import org.springframework.web.bind.annotation.RequestMapping; -import org.springframework.web.bind.annotation.RequestParam; -import org.springframework.web.bind.annotation.RestController; +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 java.io.IOException; import java.util.HashMap; +import java.util.List; import java.util.Map; /** @@ -25,6 +31,7 @@ * @date 2021-09-16 **/ @Slf4j +@CrossOrigin("*") @RestController @RequestMapping(value = "/api/common") @RequiredArgsConstructor @@ -32,8 +39,9 @@ public class CommonController { 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) { @@ -46,7 +54,7 @@ // 发送手机验证码 if (AppContants.ACCOUNT_TYPE_MOBILE.equals(type)) { - 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); @@ -68,4 +76,154 @@ } return new FebsResponse().fail().message("验证码发送失败"); } + + @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("验证码已发送"); + } + + // 发送手机验证码 + 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("验证码发送成功"); + } + // 发送邮件验证码 + } else if (AppContants.ACCOUNT_TYPE_EMAIL.equals(type)) { + boolean flag = SubMailSend.sendMail(account, code.toString()); + if (flag) { + redisUtils.set(AppContants.VERIFY_CODE_PREFIX + account, code, 120); + return new FebsResponse().success().message("验证码发送成功"); + } else { + return new FebsResponse().fail().message("验证码发送失败"); + } + } else { + log.info("未定义账号类型"); + throw new FebsException("未定义账号类型"); + } + return new FebsResponse().fail().message("验证码发送失败"); + } + + /** + * 通用上传请求 + */ + // 文件保存目录路径 + @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) 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; + } + + @ApiOperation(value = "数据字典") + @GetMapping(value = "/findDataDic/{type}") + public FebsResponse findDataDic(@PathVariable("type") String type) { + List<DataDictionaryCustom> dic = commonService.findDataDicByType(type); + return new FebsResponse().success().data(dic); + } + + @ApiOperation(value = "base64上传") + @PostMapping(value = "/base64Upload") + public FebsResponse base64Upload(@RequestBody @Validated Base64UploadDto base64UploadDto) { + String base64Str = base64UploadDto.getBase64Str(); + if (base64Str.startsWith("data:image")) { + base64Str = base64Str.substring(base64Str.indexOf(",") + 1, base64Str.length() - 1); + } + + String imageFuffix = ".jpg"; + String imageNames = System.currentTimeMillis() + IdUtil.simpleUUID() + imageFuffix; + String imageName = "uploadeFile/" + imageNames; + OssUtils.uploadFileWithBase64(base64Str, imageName); + String bucket_name ="https://excoin.oss-cn-hangzhou.aliyuncs.com"; + String url = bucket_name + "/" + imageName; + + return new FebsResponse().message("上传成功").success().data(url); + } + + @ApiOperation(value = "获取版本信息") + @GetMapping(value = "/appVersion") + public FebsResponse appVersion() { + return new FebsResponse().message("获取成功").success().data(commonService.findAppVersion()); + } + + @ApiOperation(value = "验证验证码接口") + @PostMapping(value = "/checkCode") + public FebsResponse checkCode(@RequestBody AccountAndCodeDto accountAndCodeDto) { + + boolean flag = commonService.verifyCode(accountAndCodeDto.getAccount(), accountAndCodeDto.getCode()); + if (flag) { + return new FebsResponse().success(); + } + 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