From 8945b94fc922fc6598f7558b318dc7674f525b70 Mon Sep 17 00:00:00 2001 From: zhanghua <314079846@qq.com> Date: 星期四, 17 八月 2023 10:11:35 +0800 Subject: [PATCH] bug修改 --- ycl-platform/src/main/java/com/ycl/controller/dingding/DingController.java | 76 ++++++++++++++++++++++++++++++++++++- 1 files changed, 73 insertions(+), 3 deletions(-) diff --git a/ycl-platform/src/main/java/com/ycl/controller/dingding/DingController.java b/ycl-platform/src/main/java/com/ycl/controller/dingding/DingController.java index 2110dbf..f8f7622 100644 --- a/ycl-platform/src/main/java/com/ycl/controller/dingding/DingController.java +++ b/ycl-platform/src/main/java/com/ycl/controller/dingding/DingController.java @@ -1,8 +1,14 @@ package com.ycl.controller.dingding; +import cn.hutool.core.util.ObjectUtil; +import com.alibaba.fastjson.JSONObject; +import com.alibaba.xxpt.gateway.shared.client.http.ExecutableClient; +import com.alibaba.xxpt.gateway.shared.client.http.GetClient; +import com.alibaba.xxpt.gateway.shared.client.http.PostClient; import com.ycl.api.CommonResult; import com.ycl.bo.AdminUserDetails; import com.ycl.common.dingding.DingCommon; +import com.ycl.config.DingConfig; import com.ycl.controller.BaseController; import com.ycl.entity.dingding.DingUserInfo; import com.ycl.service.auth.AuthService; @@ -12,18 +18,24 @@ import com.ycl.vo.NewAddressBookVO; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; +import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Value; import org.springframework.security.core.context.SecurityContextHolder; import org.springframework.web.bind.annotation.*; +import javax.annotation.Resource; import java.util.HashMap; import java.util.List; import java.util.Map; +import static com.ycl.common.constant.DingConst.GET_TIKER; +import static com.ycl.common.constant.DingConst.GET_TOKEN; + @RestController @RequestMapping("/ding") @Api(tags = "閽夐拤") +@Slf4j public class DingController extends BaseController { @Autowired @@ -46,6 +58,13 @@ @Autowired private BookRemarkService bookRemarkService; + @Resource + private ExecutableClient executableClient; + + @Resource + private DingConfig dingConfig; + + @ApiOperation(value = "鏍规嵁閽夐拤鎺堟潈鐮佽幏鍙杢oken") @GetMapping("/dingLogin") public CommonResult<Map> dingLogin(@RequestParam String code) { @@ -58,6 +77,60 @@ map.put("tokenHead", tokenHead); map.put("accountId", dingUser.getAccountId()); return CommonResult.success(map); + } + + @ApiOperation(value = "鏍规嵁閽夐拤鎺堟潈鐮佽幏鍙杍sapiToken") + @GetMapping("/dingTicker") + public CommonResult<Map> dingTicker() { + String accessToken = getToken(); + String ticket = getTiker(accessToken); + HashMap<String, Object> map = new HashMap<>(); + + map.put("accessToken", accessToken); + + map.put("ticket", ticket); + return CommonResult.success(map); + } + + private String getToken() { + //璋冪敤API + GetClient getTokenClient = executableClient.newGetClient(GET_TOKEN); + //璁剧疆鍙傛暟 + getTokenClient.addParameter("appkey", dingConfig.getAppKey()); + getTokenClient.addParameter("appsecret", dingConfig.getAppSecret()); + String apiResult = getTokenClient.get(); + return parsingResult(apiResult); + } + + private String getTiker(String accToken) { + //璋冪敤API + PostClient postClient = executableClient.newPostClient(GET_TIKER); + //璁剧疆鍙傛暟 + if (ObjectUtil.isNotNull(accToken)) { + postClient.addParameter("accessToken", accToken); + postClient.addParameter("appkey", dingConfig.getAppKey()); + postClient.addParameter("appsecret", dingConfig.getAppSecret()); + String apiResult = postClient.post(); + return parsingResult(apiResult); + } + return null; + } + + private String parsingResult(String apiResult) { + if (ObjectUtil.isNotNull(apiResult)) { + JSONObject resJson = JSONObject.parseObject(apiResult); + if (resJson.getBoolean("success")) { + JSONObject content = resJson.getJSONObject("content"); + if (content.getBoolean("success")) { + JSONObject dataObj = content.getJSONObject("data"); + String accessToken = dataObj.getString("accessToken"); + return accessToken; + } + } else { + log.error(resJson.toJSONString()); + } + } + return null; } @ApiOperation(value = "閫氳褰�") @@ -77,15 +150,12 @@ } - - @ApiOperation(value = "閫氳褰曢�掑綊") @GetMapping("/getDddressBook") public CommonResult<NewAddressBookVO> getNewAddressBook(@RequestParam("id") Long id) { AdminUserDetails user = (AdminUserDetails) SecurityContextHolder.getContext().getAuthentication().getPrincipal(); return CommonResult.success(dingService.getAddressBookById(id, user.getUserId())); } - @ApiOperation(value = "淇敼閫氳褰曞娉�") -- Gitblit v1.8.0