Merge pull request 'dev' (#3) from dev into beta

Reviewed-on: crm/crm-print#3
This commit is contained in:
luobai 2023-12-21 17:53:15 +08:00
commit 3cd4cf8e1c
2 changed files with 14 additions and 7 deletions

View File

@ -237,7 +237,7 @@ public class ContractService {
* @throws Exception * @throws Exception
*/ */
public File download(String templateName, Map<String, Object> dataMap) throws Exception { public File download(String templateName, Map<String, Object> dataMap,String type) throws Exception {
OutputStream os = null; OutputStream os = null;
try { try {
File outFile = new File(Consts.uploadAbsDir()); File outFile = new File(Consts.uploadAbsDir());
@ -266,10 +266,12 @@ public class ContractService {
xwpfDocument.write(os); xwpfDocument.write(os);
String outFilePath = Consts.uploadAbsDir()+ File.separator+ pdfName; String outFilePath = Consts.uploadAbsDir()+ File.separator+ pdfName;
officeToPdfService.openOfficeToPDF(pathFile, outFilePath); officeToPdfService.openOfficeToPDF(pathFile, outFilePath);
if("pdf".equals(type)){
//返回pdf //返回pdf
return new File(outFilePath); return new File(outFilePath);
}
//返回word //返回word
//return new File(pathFile); return new File(pathFile);
} finally { } finally {
if (os != null) { if (os != null) {
os.close(); os.close();

View File

@ -5,6 +5,7 @@ import cn.keking.service.ContractService;
import cn.keking.utils.Consts; import cn.keking.utils.Consts;
import cn.keking.utils.ServiceResponse; import cn.keking.utils.ServiceResponse;
import com.alibaba.fastjson2.JSON; import com.alibaba.fastjson2.JSON;
import com.github.xiaoymin.knife4j.core.util.StrUtil;
import io.swagger.annotations.*; import io.swagger.annotations.*;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
import org.springframework.web.bind.annotation.*; import org.springframework.web.bind.annotation.*;
@ -119,17 +120,21 @@ public class ContractController {
@ApiParam(value = "模板名称: 销售合同: sellContract ; 销售框架合同: frameContract", required = true) @PathVariable String templateName, @ApiParam(value = "模板名称: 销售合同: sellContract ; 销售框架合同: frameContract", required = true) @PathVariable String templateName,
@io.swagger.v3.oas.annotations.parameters.RequestBody() @io.swagger.v3.oas.annotations.parameters.RequestBody()
@RequestBody Map<String, Object> dataMap, @RequestBody Map<String, Object> dataMap,
HttpServletResponse response HttpServletResponse response,
@RequestParam(value = "type", required = false) String type
) { ) {
try { try {
log.error(JSON.toJSONString(dataMap)); log.error(JSON.toJSONString(dataMap));
OutputStream outstream = null; OutputStream outstream = null;
if (type == null) {
type="pdf";
}
File file = contractService.download(templateName, dataMap); File file = contractService.download(templateName, dataMap,type);
outstream = response.getOutputStream(); outstream = response.getOutputStream();
response.setCharacterEncoding("utf-8"); response.setCharacterEncoding("utf-8");
response.setContentType("application/octet-stream"); response.setContentType("application/octet-stream");
String filename = dataMap.get("conCode") + ".pdf"; String filename = dataMap.get("conCode") + "."+type;
response.reset(); response.reset();
// 设置response的Header // 设置response的Header
response.addHeader("Content-Disposition", "attachment;filename=" + new String(filename.getBytes())); response.addHeader("Content-Disposition", "attachment;filename=" + new String(filename.getBytes()));