From ee93d2d3d6af26beae5fd515127c14ab4c555778 Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Tue, 06 Sep 2022 11:40:18 +0800
Subject: [PATCH] 20220902
---
src/main/resources/mapper/modules/MallTeamLeaderMapper.xml | 1
src/main/java/cc/mrbird/febs/mall/service/IApiMallAddressInfoService.java | 3
src/main/java/cc/mrbird/febs/mall/controller/ApiLoginController.java | 13 +++
src/test/java/cc/mrbird/febs/ProfitTest.java | 104 +++++++++++++++++++++++++
src/main/java/cc/mrbird/febs/pay/service/impl/XcxPayServiceImpl.java | 59 +++++++-------
src/main/java/cc/mrbird/febs/mall/controller/ApiMallAddressInfoController.java | 3
src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallAddressInfoServiceImpl.java | 5 +
7 files changed, 153 insertions(+), 35 deletions(-)
diff --git a/src/main/java/cc/mrbird/febs/mall/controller/ApiLoginController.java b/src/main/java/cc/mrbird/febs/mall/controller/ApiLoginController.java
index 7196119..1dfd151 100644
--- a/src/main/java/cc/mrbird/febs/mall/controller/ApiLoginController.java
+++ b/src/main/java/cc/mrbird/febs/mall/controller/ApiLoginController.java
@@ -1,15 +1,18 @@
package cc.mrbird.febs.mall.controller;
import cc.mrbird.febs.common.entity.FebsResponse;
+import cc.mrbird.febs.common.utils.RedisUtils;
import cc.mrbird.febs.mall.dto.*;
import cc.mrbird.febs.mall.service.IApiMallMemberService;
import cc.mrbird.febs.pay.model.WxGenerateQrCodeDto;
import cc.mrbird.febs.pay.service.IXcxPayService;
+import cc.mrbird.febs.pay.util.WechatConfigure;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j;
import net.sf.json.JSONObject;
+import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.*;
@@ -31,6 +34,7 @@
private final IApiMallMemberService memberService;
private final IXcxPayService iXcxPayService;
+ private final RedisUtils redisUtils;
@ApiOperation(value = "app注册接口", notes = "app注册接口")
@PostMapping(value = "/register")
@@ -107,4 +111,13 @@
return iXcxPayService.generateQrCode(wxGenerateQrCodeDto);
}
+ /**
+ * 获取ACCESS_TOKEN
+ */
+ @ApiOperation(value = "获取ACCESS_TOKEN", notes = "获取ACCESS_TOKEN")
+ @GetMapping(value = "/getAccessToken")
+ public FebsResponse getAccessToken(){
+ return new FebsResponse().success().data(redisUtils.get(WechatConfigure.WX_ACCESS_TOKEN_REDIS_KEY).toString());
+ }
+
}
diff --git a/src/main/java/cc/mrbird/febs/mall/controller/ApiMallAddressInfoController.java b/src/main/java/cc/mrbird/febs/mall/controller/ApiMallAddressInfoController.java
index 35b5dc0..6130cf7 100644
--- a/src/main/java/cc/mrbird/febs/mall/controller/ApiMallAddressInfoController.java
+++ b/src/main/java/cc/mrbird/febs/mall/controller/ApiMallAddressInfoController.java
@@ -53,8 +53,7 @@
@ApiOperation(value = "添加地址", notes = "添加地址")
@PostMapping(value = "/addAddress")
public FebsResponse addAddress(@RequestBody AddressInfoDto addressInfoDto) {
- mallAddressInfoService.addAddress(addressInfoDto);
- return new FebsResponse().success().message("添加成功");
+ return mallAddressInfoService.addAddress(addressInfoDto);
}
@ApiOperation(value = "修改地址", notes = "修改地址")
diff --git a/src/main/java/cc/mrbird/febs/mall/service/IApiMallAddressInfoService.java b/src/main/java/cc/mrbird/febs/mall/service/IApiMallAddressInfoService.java
index 64d27c3..d4d5a65 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/IApiMallAddressInfoService.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/IApiMallAddressInfoService.java
@@ -1,5 +1,6 @@
package cc.mrbird.febs.mall.service;
+import cc.mrbird.febs.common.entity.FebsResponse;
import cc.mrbird.febs.mall.dto.AddressInfoDto;
import cc.mrbird.febs.mall.entity.MallAddressInfo;
import cc.mrbird.febs.mall.vo.AddressInfoVo;
@@ -11,7 +12,7 @@
List<AddressInfoVo> findAddressInfoList();
- void addAddress(AddressInfoDto addressInfoDto);
+ FebsResponse addAddress(AddressInfoDto addressInfoDto);
void modifyAddress(AddressInfoDto addressInfoDto);
diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallAddressInfoServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallAddressInfoServiceImpl.java
index a9b258c..4ebfcd9 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallAddressInfoServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallAddressInfoServiceImpl.java
@@ -1,5 +1,6 @@
package cc.mrbird.febs.mall.service.impl;
+import cc.mrbird.febs.common.entity.FebsResponse;
import cc.mrbird.febs.common.exception.FebsException;
import cc.mrbird.febs.common.utils.LoginUserUtil;
import cc.mrbird.febs.mall.conversion.MallAddressInfoConversion;
@@ -36,7 +37,7 @@
}
@Override
- public void addAddress(AddressInfoDto addressInfoDto) {
+ public FebsResponse addAddress(AddressInfoDto addressInfoDto) {
MallAddressInfo addressInfo = MallAddressInfoConversion.INSTANCE.dtoToEntity(addressInfoDto);
MallMember member = LoginUserUtil.getLoginUser();
@@ -54,6 +55,8 @@
addressInfo.setCreatedBy(member.getPhone());
addressInfo.setUpdatedBy(member.getPhone());
this.baseMapper.insert(addressInfo);
+
+ return new FebsResponse().success().data(addressInfo.getId());
}
@Override
diff --git a/src/main/java/cc/mrbird/febs/pay/service/impl/XcxPayServiceImpl.java b/src/main/java/cc/mrbird/febs/pay/service/impl/XcxPayServiceImpl.java
index b41bbb9..2b29706 100644
--- a/src/main/java/cc/mrbird/febs/pay/service/impl/XcxPayServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/pay/service/impl/XcxPayServiceImpl.java
@@ -249,34 +249,37 @@
@Override
public FebsResponse generateQrCode(WxGenerateQrCodeDto wxGenerateQrCodeDto) {
String base64 = null;
- try {
- RestTemplate restTemplate = new RestTemplate();
- String url = "https://api.weixin.qq.com/wxa/getwxacodeunlimit?access_token=" + redisUtils.get(WechatConfigure.WX_ACCESS_TOKEN_REDIS_KEY);
- Map<String, Object> params = new HashMap<>();
- params.put("scene", wxGenerateQrCodeDto.getScene());
- params.put("page", wxGenerateQrCodeDto.getPage());
- params.put("width", 430);
- ResponseEntity<byte[]> responseEntity = restTemplate.postForEntity(url, params, byte[].class);
- if (responseEntity.getStatusCode() == HttpStatus.OK) {
- byte[] body = responseEntity.getBody();
- InputStream inputStream = new ByteArrayInputStream(body);
- // 将获取流转为base64格式
- byte[] data = null;
- ByteArrayOutputStream swapStream = new ByteArrayOutputStream();
- byte[] buff = new byte[100];
- int rc = 0;
- while ((rc = inputStream.read(buff, 0, 100)) > 0) {
- swapStream.write(buff, 0, rc);
- }
- data = swapStream.toByteArray();
- base64 = Base64.byteArrayToBase64(data);
- inputStream.close();
- swapStream.close();
- }
- } catch (IOException e) {
- throw new ApiException("生成二维码失败");
- }
- return new FebsResponse().success().data(base64);
+// try {
+// RestTemplate restTemplate = new RestTemplate();
+// String url = "https://api.weixin.qq.com/wxa/getwxacodeunlimit?access_token=" + redisUtils.get(WechatConfigure.WX_ACCESS_TOKEN_REDIS_KEY);
+// Map<String, Object> params = new HashMap<>();
+// params.put("scene", wxGenerateQrCodeDto.getScene());
+// params.put("page", wxGenerateQrCodeDto.getPage());
+// params.put("width", 430);
+// ResponseEntity<byte[]> responseEntity = restTemplate.postForEntity(url, params, byte[].class);
+// log.info(String.valueOf(JSONUtil.parse(responseEntity)));
+// if (responseEntity.getStatusCode() == HttpStatus.OK) {
+// byte[] body = responseEntity.getBody();
+// InputStream inputStream = new ByteArrayInputStream(body);
+// // 将获取流转为base64格式
+// byte[] data = null;
+// ByteArrayOutputStream swapStream = new ByteArrayOutputStream();
+// byte[] buff = new byte[100];
+// int rc = 0;
+// while ((rc = inputStream.read(buff, 0, 100)) > 0) {
+// swapStream.write(buff, 0, rc);
+// }
+// data = swapStream.toByteArray();
+// base64 = Base64.byteArrayToBase64(data);
+// inputStream.close();
+// swapStream.close();
+//
+// return new FebsResponse().success().data(body);
+// }
+// } catch (IOException e) {
+// throw new ApiException("生成二维码失败");
+// }
+ return new FebsResponse().success();
}
/**
diff --git a/src/main/resources/mapper/modules/MallTeamLeaderMapper.xml b/src/main/resources/mapper/modules/MallTeamLeaderMapper.xml
index b687adf..fcd5bac 100644
--- a/src/main/resources/mapper/modules/MallTeamLeaderMapper.xml
+++ b/src/main/resources/mapper/modules/MallTeamLeaderMapper.xml
@@ -74,6 +74,7 @@
<result column="carriage" property="carriage" />
<result column="remark" property="remark" />
<result column="del_flag" property="delFlag" />
+ <result column="is_home" property="isHome" />
<collection property="items" ofType="cc.mrbird.febs.mall.entity.MallOrderItem">
<id property="id" column="item_id" />
<result property="orderId" column="order_id" />
diff --git a/src/test/java/cc/mrbird/febs/ProfitTest.java b/src/test/java/cc/mrbird/febs/ProfitTest.java
index c147e50..92113df 100644
--- a/src/test/java/cc/mrbird/febs/ProfitTest.java
+++ b/src/test/java/cc/mrbird/febs/ProfitTest.java
@@ -4,7 +4,10 @@
import cc.mrbird.febs.common.enumerates.DataDictionaryEnum;
import cc.mrbird.febs.common.enumerates.FlowTypeEnum;
import cc.mrbird.febs.common.enumerates.MoneyFlowTypeEnum;
+import cc.mrbird.febs.common.properties.XcxProperties;
import cc.mrbird.febs.common.utils.MallUtils;
+import cc.mrbird.febs.common.utils.RedisUtils;
+import cc.mrbird.febs.common.utils.SpringContextHolder;
import cc.mrbird.febs.mall.dto.ApiLeaderOrderConfirmDto;
import cc.mrbird.febs.mall.entity.*;
import cc.mrbird.febs.mall.mapper.*;
@@ -12,23 +15,41 @@
import cc.mrbird.febs.mall.vo.ApiLeaderProfitVo;
import cc.mrbird.febs.pay.model.WxGenerateQrCodeDto;
import cc.mrbird.febs.pay.service.IXcxPayService;
+import cc.mrbird.febs.pay.util.WechatConfigure;
import cc.mrbird.febs.rabbit.consumer.AgentConsumer;
import cn.hutool.core.collection.CollUtil;
import cn.hutool.core.date.DateTime;
import cn.hutool.core.date.DateUtil;
+import cn.hutool.core.util.IdUtil;
+import cn.hutool.core.util.StrUtil;
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject;
+import lombok.RequiredArgsConstructor;
import org.apache.commons.collections.CollectionUtils;
+import org.apache.http.HttpResponse;
+import org.apache.http.client.methods.HttpPost;
+import org.apache.http.entity.StringEntity;
+import org.apache.http.impl.client.CloseableHttpClient;
+import org.apache.http.impl.client.HttpClientBuilder;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
+import org.springframework.http.ResponseEntity;
import org.springframework.web.client.RestTemplate;
import javax.annotation.Resource;
+import java.io.*;
import java.math.BigDecimal;
-import java.util.Date;
+import java.net.HttpURLConnection;
+import java.util.*;
+import java.io.BufferedInputStream;
+import java.io.ByteArrayOutputStream;
+import java.io.InputStream;
+import java.io.PrintWriter;
+import java.net.HttpURLConnection;
+import java.net.URL;
+import java.util.Base64;
import java.util.HashMap;
-import java.util.List;
import java.util.Map;
/**
@@ -182,7 +203,7 @@
private IXcxPayService iXcxPayService;
@Test
- public void qrcode(){
+ public void qrcodeBase64(){
WxGenerateQrCodeDto wxGenerateQrCodeDto = new WxGenerateQrCodeDto();
wxGenerateQrCodeDto.setPage("wxGenerateQrCodeDto");
wxGenerateQrCodeDto.setScene("15");
@@ -286,6 +307,83 @@
System.out.println(monthProfit +";");
}
+ @Autowired
+ RedisUtils redisUtils;
+
+
+
+ @Test
+ public void qrcode(){
+// RestTemplate restTemplate = new RestTemplate();
+// String url = "https://api.weixin.qq.com/wxa/getwxacodeunlimit?access_token=" + redisUtils.get(WechatConfigure.WX_ACCESS_TOKEN_REDIS_KEY);
+// Map<String, Object> params = new HashMap<>();
+// params.put("scene", "pages/index/index");
+// params.put("page", "15");
+// params.put("width", 430);
+// ResponseEntity<byte[]> responseEntity = restTemplate.postForEntity(url, params, byte[].class);
+// System.out.println(responseEntity.getBody());xcx_appid: wx0b515f652282158e
+// xcx_secret: 8d3d3c14221f7dc37650b861dc0fc570
+
+ String imageNames = System.currentTimeMillis() + IdUtil.simpleUUID();
+ String s = getminiqrQr("15", redisUtils.get(WechatConfigure.WX_ACCESS_TOKEN_REDIS_KEY).toString(), "pages/index/index");
+ System.out.print(s);
+ }
+
+ private static final String GET_WXACODE ="https://api.weixin.qq.com/wxa/getwxacodeunlimit?access_token=";
+ /**
+ * 生成小程序码返回base64字符串
+ * @param sceneStr 要携带的参数
+ * @param accessToken 上面方法得到的token
+ * @param page 要跳转的小程序页面(必须是已发布的)
+ * @return
+ */
+
+ private static final String GETWXACODEUNLIMIT_URL = "https://api.weixin.qq.com/wxa/getwxacodeunlimit?access_token=%s";// 生成小程序码地址
+ private static final String URL_GET_TOKEN = "https://api.weixin.qq.com/cgi-bin/token";//获取access_token地址
+ private static final String APP_ID = "wx0b515f652282158e";// 小程序appid
+ private static final String APP_SECRET = "8d3d3c14221f7dc37650b861dc0fc570"; // 小程序秘钥
+
+ public static final String PATH_HOME = "";
+ private static final String BASE_PREFIX = "data:image/png;base64,"; // base64图片固定前缀
+ public static String getminiqrQr(String sceneStr, String accessToken,String page) {
+ HttpURLConnection httpURLConnection = null;
+ try {
+ URL url = new URL(String.format(GETWXACODEUNLIMIT_URL,accessToken));
+ httpURLConnection = (HttpURLConnection) url.openConnection();
+ httpURLConnection.setRequestMethod("POST");// 提交模式
+ // 发送POST请求必须设置如下两行
+ httpURLConnection.setDoOutput(true);
+ httpURLConnection.setDoInput(true);
+ // 获取URLConnection对象对应的输出流
+ PrintWriter printWriter = new PrintWriter(httpURLConnection.getOutputStream());
+ // 发送请求参数
+ JSONObject paramJson = new JSONObject();
+ paramJson.put("scene", sceneStr);
+ paramJson.put("page", page);
+ printWriter.write(paramJson.toString());
+ // flush输出流的缓冲
+ printWriter.flush();
+ //开始获取数据
+
+ BufferedInputStream bis = new BufferedInputStream(httpURLConnection.getInputStream());
+ try (InputStream is = httpURLConnection.getInputStream(); ByteArrayOutputStream baos = new ByteArrayOutputStream();){
+ byte[] buffer = new byte[1024];
+ int len = -1;
+ while ((len = is.read(buffer)) != -1) {
+ baos.write(buffer, 0, len);
+ }
+ return BASE_PREFIX+ Base64.getEncoder().encodeToString(baos.toByteArray());
+ }
+ } catch (Exception e) {
+ e.printStackTrace();
+ }finally {
+ if (httpURLConnection != null){
+ httpURLConnection.disconnect();
+ }
+ }
+ return null;
+ }
+
public static void main(String[] args) {
BigDecimal amount = new BigDecimal("0.15").setScale(2,BigDecimal.ROUND_DOWN);
System.out.println(amount);
--
Gitblit v1.9.1