From 6b1886314fd18f34740c96bb4fd86046600dd2c0 Mon Sep 17 00:00:00 2001 From: 晏有为 <13214124+yan-youwei@user.noreply.gitee.com> Date: 星期四, 16 五月 2024 17:08:36 +0800 Subject: [PATCH] Merge branch 'master' of http://114.132.189.42:9002/r/center-lims-after --- inspect-server/src/main/java/com/yuanchu/mom/controller/InsReportController.java | 78 ++++++++++++++++++++++++++++++++------- 1 files changed, 64 insertions(+), 14 deletions(-) diff --git a/inspect-server/src/main/java/com/yuanchu/mom/controller/InsReportController.java b/inspect-server/src/main/java/com/yuanchu/mom/controller/InsReportController.java index c580fc2..ae91318 100644 --- a/inspect-server/src/main/java/com/yuanchu/mom/controller/InsReportController.java +++ b/inspect-server/src/main/java/com/yuanchu/mom/controller/InsReportController.java @@ -1,28 +1,36 @@ package com.yuanchu.mom.controller; -import cn.hutool.core.lang.UUID; +import cn.hutool.core.io.FileUtil; +import cn.hutool.http.HttpUtil; +import com.alibaba.fastjson.JSONObject; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.yuanchu.mom.annotation.ValueAuth; +import com.yuanchu.mom.annotation.ValueClassify; import com.yuanchu.mom.dto.ReportPageDto; -import com.yuanchu.mom.dto.SampleOrderDto; import com.yuanchu.mom.exception.ErrorException; import com.yuanchu.mom.service.InsReportService; import com.yuanchu.mom.utils.JackSonUtil; import com.yuanchu.mom.vo.Result; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; -import lombok.AllArgsConstructor; import org.springframework.beans.factory.annotation.Value; import org.springframework.web.bind.annotation.*; import org.springframework.web.multipart.MultipartFile; import javax.annotation.Resource; +import javax.servlet.http.HttpServletRequest; +import javax.servlet.http.HttpServletResponse; import java.io.File; -import java.util.HashMap; +import java.io.PrintWriter; +import java.time.LocalDateTime; +import java.time.format.DateTimeFormatter; import java.util.Map; +import java.util.Objects; +import java.util.Scanner; @RestController @RequestMapping("/insReport") +//@AllArgsConstructor @Api("妫�楠屾姤鍛�") public class InsReportController { @@ -32,6 +40,7 @@ @Value("${wordUrl}") private String wordUrl; + @ValueClassify("鎶ュ憡缂栧埗") @ApiOperation(value = "鏌ヨ妫�楠屾姤鍛婃暟鎹�") @PostMapping("/pageInsReport") public Result pageInsReport(@RequestBody Map<String, Object> data) throws Exception { @@ -40,15 +49,9 @@ return Result.success(insReportService.pageInsReport(page, reportPageDto)); } - @ApiOperation(value = "Word杞琀TML") - @PostMapping("/wordToHtml") - @ValueAuth - public Result wordToHtml(String path) { - return Result.success("杞崲鎴愬姛", insReportService.wordToHtml(path)); - } - @ApiOperation(value = "鎶ュ憡涓婁紶") @PostMapping("/inReport") + @ValueAuth public Result inReport(MultipartFile file, Integer id) { String urlString; String pathName; @@ -58,7 +61,7 @@ if (!realpath.exists()) { realpath.mkdirs(); } - pathName = UUID.randomUUID() + "_" + file.getOriginalFilename(); + pathName = LocalDateTime.now().format(DateTimeFormatter.ofPattern("yyMMddHHmmss")) + "_" + file.getOriginalFilename(); urlString = realpath + "/" + pathName; file.transferTo(new File(urlString)); return Result.success(insReportService.inReport("/word/"+pathName, id)); @@ -66,17 +69,64 @@ throw new ErrorException("鏂囦欢涓婁紶澶辫触"); } } - + @ValueClassify("鎶ュ憡缂栧埗") @ApiOperation(value = "鎶ュ憡杩樺師") @PostMapping("/upReportUrl") public Result upReportUrl(Integer id) { return Result.success(insReportService.upReportUrl(id)); } - + @ValueClassify("鎶ュ憡缂栧埗") @ApiOperation(value = "鎶ュ憡鍦ㄧ嚎缂栧埗") @GetMapping("/upReportFile") public Result upReportFile() { return Result.success(); } + @ValueClassify("鎶ュ憡缂栧埗") + @ApiOperation(value = "鎻愪氦") + @PostMapping("/writeReport") + public Result writeReport(Integer id) { + return Result.success(insReportService.writeReport(id)); + } + @ValueClassify("鎶ュ憡缂栧埗") + @ApiOperation(value = "瀹℃牳") + @PostMapping("/examineReport") + public Result examineReport(Integer id, Integer isExamine, String examineTell) { + return Result.success(insReportService.examineReport(id, isExamine, examineTell)); + } + @ValueClassify("鎶ュ憡缂栧埗") + @ApiOperation(value = "鎵瑰噯") + @PostMapping("/ratifyReport") + public Result ratifyReport(Integer id, Integer isRatify, String ratifyTell) { + return Result.success(insReportService.ratifyReport(id, isRatify, ratifyTell)); + } + @RequestMapping("/onlyOffice/save") + public void saveFile(@RequestParam String fileName, HttpServletRequest request, HttpServletResponse response) { + PrintWriter writer = null; + try { + writer = response.getWriter(); + // 鑾峰彇浼犺緭鐨刯son鏁版嵁 + Scanner scanner = new Scanner(request.getInputStream()).useDelimiter("\\A"); + String body = scanner.hasNext() ? scanner.next() : ""; + JSONObject jsonObject = JSONObject.parseObject(body); + + System.out.println(jsonObject); + if (jsonObject.containsKey("url")) { + String jsonArray = jsonObject.get("lastsave").toString(); // 鏇存柊鏃堕棿 + String fileUrl = jsonObject.get("url").toString(); // 鏇存柊鏂囦欢url + HttpUtil.downloadFile(fileUrl, FileUtil.file(wordUrl + "/" + fileName)); + } + } catch (Exception e) { + e.printStackTrace(); + writer.write("{\"error\":-1}"); + return; + } + /* + * status = 1锛屾垜浠粰onlyOffice鐨勬湇鍔¤繑鍥瀧"error":"0"}鐨勪俊鎭�� + * 杩欐牱onlyOffice浼氳涓哄洖璋冩帴鍙f槸娌¢棶棰樼殑锛岃繖鏍峰氨鍙互鍦ㄧ嚎缂栬緫鏂囨。浜嗭紝鍚﹀垯鐨勮瘽浼氬脊鍑虹獥鍙h鏄� + */ + if (Objects.nonNull(writer)) { + writer.write("{\"error\":0}"); + } + } } -- Gitblit v1.9.3