From 1cad14bca191807e18705c3a5526eda8151be439 Mon Sep 17 00:00:00 2001
From: zhanghua <314079846@qq.com>
Date: 星期一, 14 四月 2025 23:10:22 +0800
Subject: [PATCH] 批量审核和图片保存bug

---
 ycl-platform/src/main/java/com/ycl/controller/dingding/DingController.java |  259 +++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 255 insertions(+), 4 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..206ea90 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,29 +1,64 @@
 package com.ycl.controller.dingding;
 
+import cn.hutool.core.util.ObjectUtil;
+import com.alibaba.fastjson.JSONObject;
+import com.alibaba.xxpt.gateway.shared.api.request.OapiMediaUploadRequest;
+import com.alibaba.xxpt.gateway.shared.api.response.OapiMediaUploadResponse;
+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.IntelligentPostClient;
+import com.alibaba.xxpt.gateway.shared.client.http.PostClient;
+import com.aliyun.oss.OSS;
+import com.aliyun.oss.OSSClientBuilder;
+import com.aliyun.oss.common.utils.StringUtils;
+import com.aliyun.oss.model.ObjectMetadata;
 import com.ycl.api.CommonResult;
 import com.ycl.bo.AdminUserDetails;
 import com.ycl.common.dingding.DingCommon;
+import com.ycl.config.DdTest;
+import com.ycl.config.DingConfig;
 import com.ycl.controller.BaseController;
+import com.ycl.dto.video.OssFileDto;
 import com.ycl.entity.dingding.DingUserInfo;
 import com.ycl.service.auth.AuthService;
 import com.ycl.service.ding.BookRemarkService;
 import com.ycl.service.ding.DingService;
+import com.ycl.service.oss.OssService;
+import com.ycl.utils.ConstantPropertiesUtils;
+import com.ycl.utils.common.RandomUtils;
 import com.ycl.vo.AddressBookVO;
 import com.ycl.vo.NewAddressBookVO;
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiOperation;
+import lombok.extern.slf4j.Slf4j;
+import org.apache.commons.fileupload.FileItem;
+import org.apache.commons.fileupload.FileItemFactory;
+import org.apache.commons.fileupload.disk.DiskFileItemFactory;
+import org.apache.http.HttpEntity;
+import org.apache.http.client.methods.CloseableHttpResponse;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.beans.factory.annotation.Value;
+import org.springframework.http.MediaType;
 import org.springframework.security.core.context.SecurityContextHolder;
 import org.springframework.web.bind.annotation.*;
+import org.springframework.web.multipart.MultipartFile;
+import org.springframework.web.multipart.commons.CommonsMultipartFile;
 
+import javax.annotation.Resource;
+import java.io.*;
+import java.time.LocalDateTime;
+import java.time.format.DateTimeFormatter;
+import java.util.Date;
 import java.util.HashMap;
 import java.util.List;
 import java.util.Map;
 
+import static com.ycl.common.constant.DingConst.*;
+
 @RestController
 @RequestMapping("/ding")
 @Api(tags = "閽夐拤")
+@Slf4j
 public class DingController extends BaseController {
 
     @Autowired
@@ -46,13 +81,25 @@
     @Autowired
     private BookRemarkService bookRemarkService;
 
+    @Resource
+    private ExecutableClient executableClient;
+
+    @Resource
+    private DingConfig dingConfig;
+
+
+    @Autowired
+    private OssService ossService;
+
     @ApiOperation(value = "鏍规嵁閽夐拤鎺堟潈鐮佽幏鍙杢oken")
     @GetMapping("/dingLogin")
     public CommonResult<Map> dingLogin(@RequestParam String code) {
+        log.info("涓�閿櫥褰曞弬鏁癱ode--------------->{}", code);
         HashMap<String, Object> map = new HashMap<>();
         //鑾峰彇鐢ㄦ埛淇℃伅
         DingUserInfo dingUser = dingCommon.getDingUserInfo(code);
         //鎸塪ing鐧诲綍
+        log.info("鐢ㄦ埛淇℃伅------------------->{}", dingUser);
         String token = authService.dingLogin(dingUser);
         map.put("token", token);
         map.put("tokenHead", tokenHead);
@@ -60,11 +107,64 @@
         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 = "閫氳褰�")
     @GetMapping("/addressBook")
     public CommonResult<List<AddressBookVO>> getAddressBook() {
         AdminUserDetails user = (AdminUserDetails) SecurityContextHolder.getContext().getAuthentication().getPrincipal();
-
         return CommonResult.success(dingService.getAddressBook(user.getUserId()));
     }
 
@@ -77,15 +177,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 = "淇敼閫氳褰曞娉�")
@@ -96,4 +193,158 @@
     }
 
 
+    @PostMapping("/oss/sign")
+    public CommonResult ossSign(@RequestBody OssFileDto dto) {
+
+        if (StringUtils.isNullOrEmpty(dto.getMediaId()) || StringUtils.isNullOrEmpty(dto.getExtension())) {
+            return CommonResult.failed("鍙傛暟涓嶈兘涓虹┖锛�");
+        }
+        ExecutableClient executableClient = DdTest.getExecutableClient();
+        CloseableHttpResponse response = null;
+        OSS ossClient = null;
+
+        DateTimeFormatter dtf2 = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");
+
+        System.out.println("寮�濮嬭幏鍙�--" + dtf2.format(LocalDateTime.now()));
+        try {
+            //浠庨拤閽夎幏鍙栬棰戞祦
+            String api = "/media/download";
+            GetClient getClient = executableClient.newGetClient(api);
+            //浠巖edis鑾峰彇token
+            String token = getToken();
+            //璁剧疆鍙傛暟
+            getClient.addParameter("access_token", token);
+            getClient.addParameter("media_id", dto.getMediaId());
+            response = getClient.getB();
+            HttpEntity entity = response.getEntity();
+            InputStream is = entity.getContent();
+
+//            MultipartFile file = getMultipartFile(is, fileName);
+
+            String url = ossService.uploadImages(is, dto.getExtension(),0);
+            return CommonResult.success(url);
+        } catch (Exception e) {
+            e.printStackTrace();
+            System.out.println(e.getMessage());
+        } finally {
+            if (ossClient != null) {
+                ossClient.shutdown();
+            }
+            if (response != null) {
+                try {
+                    response.close();
+                } catch (Exception e) {
+                    System.out.println(e);
+                }
+            }
+        }
+        return null;
+    }
+
+    @ApiOperation(value = "鑾峰彇瑙嗛")
+    @GetMapping("/getVideo/{mediaId}")
+    public CommonResult<String> getVideo(@PathVariable String mediaId) {
+        String accessToken = getToken();
+
+        MultipartFile file = getDownload(accessToken, mediaId);
+        String url = ossService.uploadImages(file);
+        return CommonResult.success(url);
+    }
+
+
+    private MultipartFile getDownload(String access_token, String media_id) {
+        CloseableHttpResponse response = null;
+        try {
+            String api = "/media/download";
+            GetClient getClient = executableClient.newGetClient(api);
+            //璁剧疆鍙傛暟
+            getClient.addParameter("access_token", access_token);
+            getClient.addParameter("media_id", media_id);
+
+            response = getClient.getB();
+            HttpEntity entity = response.getEntity();
+            InputStream is = entity.getContent();
+
+            DateTimeFormatter dtf2 = DateTimeFormatter.ofPattern("yyyyMMddHHmmss");
+
+            String strDate2 = dtf2.format(LocalDateTime.now());
+            String fileName = strDate2 + RandomUtils.generateRandomInt(4) + ".MOV";
+            return getMultipartFile(is, fileName);
+
+        } catch (Exception e) {
+            System.out.println(e);
+        } finally {
+            if (response != null) {
+                try {
+                    //鐗瑰埆鎻愰啋锛氶渶瑕佽皟鐢╮esponse鐨刢lose鏂规硶鍏抽棴缃戠粶杩炴帴锛侊紒锛�
+                    response.close();
+                } catch (Exception e) {
+                    System.out.println(e);
+                }
+            }
+        }
+        return null;
+    }
+
+    /**
+     * 鑾峰彇灏佽寰桵ultipartFile
+     *
+     * @param inputStream inputStream
+     * @param fileName    fileName
+     * @return MultipartFile
+     */
+    public MultipartFile getMultipartFile(InputStream inputStream, String fileName) {
+        FileItem fileItem = createFileItem(inputStream, fileName);
+        //CommonsMultipartFile鏄痜eign瀵筸ultipartFile鐨勫皝瑁咃紝浣嗘槸瑕丗ileItem绫诲璞�
+        return new CommonsMultipartFile(fileItem);
+    }
+
+
+    /**
+     * FileItem绫诲璞″垱寤�
+     *
+     * @param inputStream inputStream
+     * @param fileName    fileName
+     * @return FileItem
+     */
+    public FileItem createFileItem(InputStream inputStream, String fileName) {
+        FileItemFactory factory = new DiskFileItemFactory(16, null);
+        DateTimeFormatter dtf2 = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");
+        String strDate2 = dtf2.format(LocalDateTime.now());
+        String textFieldName = strDate2 + RandomUtils.generateRandomInt(4);
+        FileItem item = factory.createItem(textFieldName, MediaType.MULTIPART_FORM_DATA_VALUE, true, fileName);
+        int bytesRead = 0;
+        byte[] buffer = new byte[8192];
+        OutputStream os = null;
+        //浣跨敤杈撳嚭娴佽緭鍑鸿緭鍏ユ祦鐨勫瓧鑺�
+        try {
+            os = item.getOutputStream();
+            while ((bytesRead = inputStream.read(buffer, 0, 8192)) != -1) {
+                os.write(buffer, 0, bytesRead);
+            }
+            inputStream.close();
+        } catch (IOException e) {
+            log.error("Stream copy exception", e);
+            throw new IllegalArgumentException("鏂囦欢涓婁紶澶辫触");
+        } finally {
+            if (os != null) {
+                try {
+                    os.close();
+                } catch (IOException e) {
+                    log.error("Stream close exception", e);
+
+                }
+            }
+            if (inputStream != null) {
+                try {
+                    inputStream.close();
+                } catch (IOException e) {
+                    log.error("Stream close exception", e);
+                }
+            }
+        }
+
+        return item;
+    }
 }
+

--
Gitblit v1.8.0