123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881 |
- package com.jkcredit.invoice.controller.business;
- import com.jkcredit.invoice.service.nocar.WayBillFileService;
- import cn.afterturn.easypoi.excel.ExcelImportUtil;
- import cn.afterturn.easypoi.excel.entity.ImportParams;
- import com.alibaba.fastjson.JSON;
- import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
- import com.jkcredit.invoice.annotation.LoginRequired;
- import com.jkcredit.invoice.annotation.annotationdes.AuthenticationInterceptor;
- import com.jkcredit.invoice.mapper.waybill.NoCarWaybillMapper;
- import com.jkcredit.invoice.model.entity.calculate.NoCarCalculateInfor;
- import com.jkcredit.invoice.model.entity.customer.CustomerCarRec;
- import com.jkcredit.invoice.model.entity.customer.CustomerOper;
- import com.jkcredit.invoice.model.entity.invoice.BillInvoice;
- import com.jkcredit.invoice.model.entity.user.User;
- import com.jkcredit.invoice.model.entity.waybill.NoCarWayBill;
- import com.jkcredit.invoice.model.vo.CodeAndNumVo;
- import com.jkcredit.invoice.service.calculateinfor.NoCarCalculateInfoService;
- import com.jkcredit.invoice.service.customer.CustomerOperService;
- import com.jkcredit.invoice.service.lowerservice.CheckHasAuthRole;
- import com.jkcredit.invoice.service.lowerservice.NoCarService;
- import com.jkcredit.invoice.service.nocar.NoCarBillWayImportService;
- import com.jkcredit.invoice.service.nocar.NoCarBillWayService;
- import com.jkcredit.invoice.service.nocar.NoCarRecService;
- import com.jkcredit.invoice.service.nocar.NocarInvoiceService;
- import com.jkcredit.invoice.util.Base64Utils;
- import com.jkcredit.invoice.util.DateUtil;
- import com.jkcredit.invoice.util.RespR;
- import com.jkcredit.invoice.util.ZipUtils;
- import io.swagger.annotations.Api;
- import io.swagger.annotations.ApiOperation;
- import lombok.extern.slf4j.Slf4j;
- import org.apache.commons.io.FileUtils;
- import org.apache.ibatis.annotations.Param;
- import org.apache.poi.util.IOUtils;
- import org.springframework.beans.factory.annotation.Autowired;
- import org.springframework.beans.factory.annotation.Value;
- import org.springframework.util.StringUtils;
- import org.springframework.web.bind.annotation.*;
- import org.springframework.web.multipart.MultipartFile;
- import javax.servlet.http.HttpServletResponse;
- import javax.validation.constraints.NotNull;
- import java.io.*;
- import java.net.URLEncoder;
- import java.text.DateFormat;
- import java.text.SimpleDateFormat;
- import java.util.ArrayList;
- import java.util.Arrays;
- import java.util.List;
- import com.jkcredit.invoice.model.entity.waybill.NoCarWayBillFileInfo;
- import static com.jkcredit.invoice.common.CommonConst.*;
- @Api(tags = "无车操作")
- @RestController
- @RequestMapping(value = {"/noCar"})
- @Slf4j
- /**
- * @Description 无车操作
- * @Author mashengyi
- * @Date 2022/2/8 18:15
- * @Param
- * @Return
- * @Exception
- *
- */
- public class NoCarController {
- @Autowired
- NoCarRecService noCarRecService;
- @Autowired
- NoCarBillWayService noCarBillWayService;
- @Autowired
- NoCarBillWayImportService noCarBillWayImportService;
- @Autowired
- NocarInvoiceService nocarInvoiceService;
- @Autowired
- NoCarCalculateInfoService noCarCalculateInfoService;
- @Autowired
- NoCarWaybillMapper noCarWaybillMapper;
- @Autowired
- NoCarService noCarService;
- @Autowired
- CustomerOperService customerOperService;
- @Autowired
- private CheckHasAuthRole checkHasAuthRole;
- @Autowired
- private WayBillFileService wayBillFileService;
- /**
- * 分页查询无车备案信息
- *
- * @param page 参数集
- * @return 用户集合
- */
- @PostMapping("/findCarRec")
- @ApiOperation(value = "分页查询无车/自有车备案信息", notes = "分页查询无车/自有车备案信息")
- @LoginRequired
- public RespR getCustomersByPage(Page page, CustomerCarRec customerCarRec, User user) {
- try {
- checkHasAuthRole.checkCustomerRole(user, customerCarRec.getCustomerName());
- if (!StringUtils.isEmpty(customerCarRec.getStartTime()) && !NULL.equals(customerCarRec.getStartTime())) {
- String[] res = customerCarRec.getStartTime().split(",");
- customerCarRec.setStartTime(res[0]);
- customerCarRec.setEndTime(res[1].replace("00:00:00", "23:59:59"));
- } else {
- customerCarRec.setStartTime(null);
- }
- RespR respR = new RespR(noCarRecService.findByPageAndCarRec(page, customerCarRec));
- return respR;
- } catch (Exception e) {
- e.printStackTrace();
- return new RespR(false, e.getMessage());
- }
- }
- public void setTimeDue(NoCarWayBill noCarWayBill) {
- if (!StringUtils.isEmpty(noCarWayBill.getStartBegin()) && !NULL.equals(noCarWayBill.getStartBegin())) {
- String[] res = noCarWayBill.getStartBegin().split(",");
- noCarWayBill.setStartBegin(res[0]);
- noCarWayBill.setStartEnd(res[1].replace("00:00:00", "23:59:59"));
- } else {
- noCarWayBill.setStartBegin(null);
- }
- if (!StringUtils.isEmpty(noCarWayBill.getEndBegin()) && !NULL.equals(noCarWayBill.getEndBegin())) {
- String[] res = noCarWayBill.getEndBegin().split(",");
- noCarWayBill.setEndBegin(res[0]);
- noCarWayBill.setEndEnd(res[1].replace("00:00:00", "23:59:59"));
- } else {
- noCarWayBill.setEndBegin(null);
- }
- }
- public void setTimeDue2(NoCarWayBill noCarWayBill) {
- if (NULL.equals(noCarWayBill.getStartBegin())) {
- noCarWayBill.setStartBegin(null);
- }
- if (NULL.equals(noCarWayBill.getStartEnd())) {
- noCarWayBill.setStartEnd(null);
- }
- if (NULL.equals(noCarWayBill.getEndBegin())) {
- noCarWayBill.setEndBegin(null);
- }
- if (NULL.equals(noCarWayBill.getEndEnd())) {
- noCarWayBill.setEndEnd(null);
- }
- }
- /**
- * 分页查询运单信息
- *
- * @param page 参数集
- * @return 用户集合
- */
- @PostMapping("/findBillWay")
- @ApiOperation(value = "分页查询无车运单信息", notes = "分页查询无车运单信息")
- @LoginRequired(role = AuthenticationInterceptor.AUTH_NOCAR)
- public RespR findBillWay(Page page, NoCarWayBill noCarWayBill, User user) {
- try {
- checkHasAuthRole.checkCustomerRole(user, noCarWayBill.getCustomerName());
- setTimeDue(noCarWayBill);
- setBillNums(noCarWayBill);
- RespR respR = new RespR(noCarBillWayService.findByPageAndWayBill(page, noCarWayBill));
- return respR;
- } catch (Exception e) {
- e.printStackTrace();
- return new RespR(false, e.getMessage());
- }
- }
- public void setBillNums(NoCarWayBill noCarWayBill) {
- String billNums = noCarWayBill.getBillNum();
- if (!StringUtils.isEmpty(billNums)) {
- String[] billNumArr = billNums.split(",");
- noCarWayBill.setBillNums(Arrays.asList(billNumArr));
- }
- }
- /**
- * 分页查询客户运单信息
- *
- * @param page 参数集
- * @return 用户集合
- */
- @PostMapping("/findBillWayCust")
- @ApiOperation(value = "分页查询无车运单信息", notes = "分页查询无车运单信息")
- @LoginRequired(role = AuthenticationInterceptor.AUTH_NOCAR)
- public RespR findBillWayCust(Page page, NoCarWayBill noCarWayBill, User user) {
- try {
- checkHasAuthRole.checkCustomerRole(user, noCarWayBill.getCustomerName());
- setTimeDue2(noCarWayBill);
- setBillNums(noCarWayBill);
- noCarWayBill.setBatchNum("1");
- RespR respR = new RespR(noCarBillWayService.findByPageAndWayBill(page, noCarWayBill));
- return respR;
- } catch (Exception e) {
- e.printStackTrace();
- return new RespR(false, e.getMessage());
- }
- }
- /**
- * 分页查询运单信息
- *
- * @param page 参数集
- * @return 用户集合
- */
- @PostMapping("/findImportBillWay")
- @ApiOperation(value = "分页查询无车运单信息", notes = "分页查询无车运单信息")
- @LoginRequired(role = AuthenticationInterceptor.AUTH_NOCAR)
- public RespR findImportBillWay(Page page, NoCarWayBill noCarWayBill, User user) {
- try {
- checkHasAuthRole.checkCustomerRole(user, noCarWayBill.getCustomerName());
- setTimeDue(noCarWayBill);
- RespR respR = new RespR(noCarBillWayImportService.findByPageAndWayBill(page, noCarWayBill));
- return respR;
- } catch (Exception e) {
- e.printStackTrace();
- return new RespR(false, e.getMessage());
- }
- }
- /**
- * 分页查询运单信息
- *
- * @param page 参数集
- * @return 用户集合
- */
- @PostMapping("/findBatchFileList")
- @ApiOperation(value = "分页查询运单协议上传", notes = "分页查询运单协议上传")
- @LoginRequired(role = AuthenticationInterceptor.AUTH_NOCAR)
- public RespR findBatchFileList(Page page, NoCarWayBillFileInfo noCarWayBillFileInfo, User user) {
- try {
- checkHasAuthRole.checkCustomerRole(user, noCarWayBillFileInfo.getCustomerId());
- RespR respR = new RespR(wayBillFileService.selectAllFiles(page,noCarWayBillFileInfo));
- return respR;
- } catch (Exception e) {
- e.printStackTrace();
- return new RespR(false, e.getMessage());
- }
- }
- /**
- * 重新获取发票并更新状态
- *
- * @return 用户集合
- */
- @PostMapping("/updateStatus")
- @ApiOperation(value = "重新获取发票并更新状态", notes = "重新获取发票并更新状态")
- @LoginRequired(role = AuthenticationInterceptor.AUTH_ADMIN)
- public RespR updateStatus(@NotNull(message = "发票更新状态失败,不能为空") String noCarWayBillStr) {
- List<NoCarWayBill> noCarWayBills = JSON.parseArray(noCarWayBillStr, NoCarWayBill.class);
- if (noCarWayBills != null && noCarWayBills.size() > 0) {
- noCarWayBills.stream().forEach(noCarWayBill -> {
- try {
- noCarWayBill.setBillwayStatus(-5);
- noCarService.getInvoiceByWayBillNumReal(noCarWayBill, false);
- } catch (Exception e) {
- log.info("重新获取发票并更新状态失败" + e.getMessage());
- }
- });
- }
- return new RespR("更新成功");
- }
- /**
- * 分页查询异常运单信息
- *
- * @param page 参数集
- * @return 用户集合
- */
- @PostMapping("/findBillWayException")
- @ApiOperation(value = "分页查询异常运单信息", notes = "分页查询异常运单信息")
- @LoginRequired(role = AuthenticationInterceptor.AUTH_ADMIN)
- public RespR findBillWayException(Page page, NoCarWayBill noCarWayBill) {
- try {
- setTimeDue(noCarWayBill);
- RespR respR = new RespR(noCarBillWayService.findByPageAndWayBillException(page, noCarWayBill));
- return respR;
- } catch (Exception e) {
- e.printStackTrace();
- return new RespR(false, e.getMessage());
- }
- }
- /**
- * 分页查询无车运单信息
- *
- * @param page 参数集
- * @return 用户集合
- */
- @PostMapping("/findNocarInvoices")
- @ApiOperation(value = "分页查询无车发票信息", notes = "分页查询无车发票信息")
- @LoginRequired(role = AuthenticationInterceptor.AUTH_NOCAR)
- public RespR findNocarInvoices(Page page, BillInvoice billInvoice, User user) {
- try {
- checkHasAuthRole.checkCustomerRole(user, billInvoice.getCustomerName());
- setParams(billInvoice);
- RespR respR = new RespR(nocarInvoiceService.findByPageAndInvoice(page, billInvoice));
- return respR;
- } catch (Exception e) {
- e.printStackTrace();
- return new RespR(false, e.getMessage());
- }
- }
- private void setParams(BillInvoice billInvoice) {
- if (!StringUtils.isEmpty(billInvoice.getInvoiceMakeTime()) && !NULL.equals(billInvoice.getInvoiceMakeTime())) {
- String[] res = billInvoice.getInvoiceMakeTime().split(",");
- billInvoice.setInvoiceMakeStart(res[0]);
- billInvoice.setInvoiceMakeEnd(res[1].replace("00:00:00", "23:59:59"));
- }
- if (!StringUtils.isEmpty(billInvoice.getCalculateTime()) && !NULL.equals(billInvoice.getCalculateTime())) {
- String[] res = billInvoice.getCalculateTime().split(",");
- billInvoice.setCalculateTimeStart(res[0]);
- billInvoice.setCalculateTimeEnd(res[1].replace("00:00:00", "23:59:59"));
- }
- if (!StringUtils.isEmpty(billInvoice.getWaybillNum())) {
- String[] billNumArr = billInvoice.getWaybillNum().split(",");
- billInvoice.setWaybillNums(Arrays.asList(billNumArr));
- }
- if (!StringUtils.isEmpty(billInvoice.getPlateNum())) {
- String[] plateNums = billInvoice.getPlateNum().split(COMMA);
- billInvoice.setPlateNums(Arrays.asList(plateNums));
- }
- if (!StringUtils.isEmpty(billInvoice.getInvoiceCode()) && billInvoice.getInvoiceCode().indexOf(COMMAS) > 0) {
- String[] invoiceCodeArr = billInvoice.getInvoiceCode().split(",");
- String[] invoiceNumArr = null;
- if (billInvoice.getInvoiceNum() != null) {
- invoiceNumArr = billInvoice.getInvoiceNum().split(",");
- }
- List<CodeAndNumVo> codeAndNumVos = new ArrayList<>();
- for (int i = 0; i < invoiceCodeArr.length; i++) {
- CodeAndNumVo codeAndNumVo = new CodeAndNumVo();
- codeAndNumVo.setCode(invoiceCodeArr[i]);
- if (invoiceNumArr != null && invoiceNumArr.length >= i + 1) {
- codeAndNumVo.setNum(invoiceNumArr[i]);
- } else {
- codeAndNumVo.setNum("");
- }
- codeAndNumVos.add(codeAndNumVo);
- }
- billInvoice.setCodeAndNumVos(codeAndNumVos);
- }
- }
- /**
- * 批量查询无车发票信息
- *
- * @param file 参数集
- * @return
- */
- @PostMapping("/batchImportNocarInvoices")
- @ApiOperation(value = "批量查询无车发票信息", notes = "批量查询无车发票信息")
- @LoginRequired(role = AuthenticationInterceptor.AUTH_ADMIN)
- public RespR batchImportNocarInvoices(@RequestParam("file") MultipartFile file) {
- try {
- if (null == file) {
- return new RespR(false, "批量查询无车发票信息失败,请查看数据是否维护准确");
- }
- ImportParams params = new ImportParams();
- params.setTitleRows(1);
- params.setHeadRows(1);
- List<BillInvoice> list = ExcelImportUtil.importExcel(file.getInputStream(), BillInvoice.class, params);
- RespR respR = nocarInvoiceService.findImportNocarInvoices(list);
- return respR;
- } catch (Exception e) {
- e.printStackTrace();
- return new RespR(false, e.getMessage());
- }
- }
- /**
- * 批量查询无车运单信息
- *
- * @param file 参数集
- * @return
- */
- @PostMapping("/batchImportNocarBillWay")
- @ApiOperation(value = "批量查询无车运单信息", notes = "批量查询无车运单信息")
- @LoginRequired(role = AuthenticationInterceptor.AUTH_ADMIN)
- public RespR batchImportNocarBillWay(@RequestParam("file") MultipartFile file) {
- try {
- if (null == file) {
- return new RespR(false, "批量查询无车运单信息失败,请查看数据是否维护准确");
- }
- ImportParams params = new ImportParams();
- params.setTitleRows(1);
- params.setHeadRows(1);
- List<NoCarWayBill> list = ExcelImportUtil.importExcel(file.getInputStream(), NoCarWayBill.class, params);
- RespR respR = noCarBillWayService.findImportNocarBillWay(list);
- return respR;
- } catch (Exception e) {
- e.printStackTrace();
- return new RespR(false, e.getMessage());
- }
- }
- /**
- * 分页查询无车运单统计信息
- *
- * @param billInvoice
- * @return 用户集合
- */
- @PostMapping("/findNocarInvoicesStatic")
- @ApiOperation(value = "分页查询无车发票统计信息", notes = "分页查询无车发票统计信息")
- @LoginRequired(role = AuthenticationInterceptor.AUTH_NOCAR)
- public RespR findNocarInvoicesStatic(BillInvoice billInvoice, User user) {
- checkHasAuthRole.checkCustomerRole(user, billInvoice.getCustomerName());
- try {
- if (!StringUtils.isEmpty(billInvoice.getInvoiceMakeTime()) && !NULL.equals(billInvoice.getInvoiceMakeTime())) {
- String[] res = billInvoice.getInvoiceMakeTime().split(",");
- billInvoice.setInvoiceMakeStart(res[0]);
- billInvoice.setInvoiceMakeEnd(res[1].replace("00:00:00", "23:59:59"));
- }
- if (!StringUtils.isEmpty(billInvoice.getCalculateTime()) && !NULL.equals(billInvoice.getCalculateTime())) {
- String[] res = billInvoice.getCalculateTime().split(",");
- billInvoice.setCalculateTimeStart(res[0]);
- billInvoice.setCalculateTimeEnd(res[1].replace("00:00:00", "23:59:59"));
- }
- RespR respR = new RespR(nocarInvoiceService.findInvoiceStatics(billInvoice));
- return respR;
- } catch (Exception e) {
- e.printStackTrace();
- return new RespR(false, e.getMessage());
- }
- }
- /**
- * 批量运单导入
- *
- * @param file 参数集
- * @return
- */
- @PostMapping("/batchImprotBillWay")
- @ApiOperation(value = "批量运单导入", notes = "批量运单导入")
- @LoginRequired(role = AuthenticationInterceptor.AUTH_NOCAR)
- public RespR batchImprotBillWay(@RequestParam("file") MultipartFile file, @NotNull(message = "批量运单导入,客户名称不能为空") String customerName,String batchNum, User user) {
- try {
- if (null == file) {
- return new RespR(false, "批量运单导入失败,请查看数据是否维护准确");
- }
- checkHasAuthRole.checkCustomerRole(user, customerName);
- ImportParams params = new ImportParams();
- params.setTitleRows(1);
- params.setHeadRows(1);
- params.setKeyIndex(2);
- List<NoCarWayBill> list = ExcelImportUtil.importExcel(file.getInputStream(), NoCarWayBill.class, params);
- buildDate(list);
- RespR respR = noCarBillWayService.batchBillWayStart(list, customerName,batchNum);
- return respR;
- } catch (Exception e) {
- e.printStackTrace();
- return new RespR(false, e.getMessage());
- }
- }
- @Value("${param.fileTmp:/home/app/logs/temp}")
- private String tempPath = "d:/log";
- /**
- * 批量运单导入
- *
- * @param file 参数集
- * @return
- */
- @PostMapping("/batchImprotBillWayFile")
- @ApiOperation(value = "批量文件导入", notes = "批量文件导入")
- @LoginRequired(role = AuthenticationInterceptor.AUTH_NOCAR)
- public RespR batchImprotBillWayFile(@RequestParam("file") MultipartFile file, @NotNull(message = "批量运单导入,客户名称不能为空") String customerName, User user) {
- FileOutputStream fileOutputStream = null;
- String realPath = "";
- try {
- log.info("开始导入文件{},{}M",file.getName(),file.getSize()/1024/1024);
- if (null == file) {
- return new RespR(false, "文件导入失败");
- }
- checkHasAuthRole.checkCustomerRole(user, customerName);
- //将文件放到临时目录,
- String batchNumber = "YDF" + System.currentTimeMillis();
- realPath = tempPath+"/"+batchNumber+"/";
- File file1 = new File(realPath);
- file1.mkdirs();
- fileOutputStream = new FileOutputStream(realPath+file.getOriginalFilename());
- fileOutputStream.write(file.getBytes());
- ZipUtils.unZipFiles(realPath+file.getOriginalFilename(),realPath+"out/");
- File fileout = new File(realPath+"out/");
- File [] files = fileout.listFiles();
- while ( files.length>0&& files[0].isDirectory()){
- files = fileout.listFiles()[0].listFiles();
- }
- for(int i=0;i<files.length;i++){
- File fileTemp = files[i];
- if(fileTemp.isDirectory() || !(fileTemp.getName().contains(".pdf")||fileTemp.getName().contains(".PDF"))){
- continue;
- }
- NoCarWayBillFileInfo noCarWayBillFileInfo = new NoCarWayBillFileInfo();
- noCarWayBillFileInfo.setCustomerId(customerName);
- noCarWayBillFileInfo.setBatchNum(batchNumber);
- noCarWayBillFileInfo.setUpdateTime(DateUtil.getCurrentDateStr());
- noCarWayBillFileInfo.setBase64Str( Base64Utils.fileToBase64Str(fileTemp));
- noCarWayBillFileInfo.setWayBillNum(fileTemp.getName().replaceAll(".pdf","").replaceAll(".PDF",""));
- noCarWayBillFileInfo.setFileName(fileTemp.getName());
- wayBillFileService.insert(noCarWayBillFileInfo);
- }
- return new RespR(true);
- } catch (Exception e) {
- e.printStackTrace();
- return new RespR(false, e.getMessage());
- }finally {
- if(fileOutputStream !=null){
- try {
- fileOutputStream.close();
- FileUtils.deleteDirectory(new File(realPath));
- }catch (IOException e){
- }
- }
- }
- }
- public void deleteFile(File file){
- if(file.isFile()){
- file.delete();
- return;
- }
- File [] files = file.listFiles();
- for(File file1:files){
- deleteFile(file1);
- }
- }
- /**
- * 批量运单导入
- *
- * @param file 参数集
- * @return
- */
- @PostMapping("/batchImprotHistoryBillWay")
- @ApiOperation(value = "批量历史运单导入", notes = "批量历史运单导入")
- @LoginRequired(role = AuthenticationInterceptor.AUTH_NOCAR)
- public RespR batchImprotHistoryBillWay(@RequestParam("file") MultipartFile file, @NotNull(message = "批量运单导入,客户名称不能为空") String customerName,String batchNum, User user) {
- try {
- if (null == file) {
- return new RespR(false, "批量历史运单导入失败,请查看数据是否维护准确");
- }
- checkHasAuthRole.checkCustomerRole(user, customerName);
- ImportParams params = new ImportParams();
- params.setTitleRows(1);
- params.setHeadRows(1);
- params.setKeyIndex(2);
- List<NoCarWayBill> list = ExcelImportUtil.importExcel(file.getInputStream(), NoCarWayBill.class, params);
- log.info("batchImprotHistoryBillWay数量" + list.size());
- buildDate(list);
- RespR respR = noCarBillWayService.batchHsitoryBillWay(list, customerName,batchNum);
- return respR;
- } catch (Exception e) {
- e.printStackTrace();
- return new RespR(false, e.getMessage());
- }
- }
- /**
- * 批量运单导入
- *
- * @param file 参数集
- * @return
- */
- @PostMapping("/batchImprotEndBillWay")
- @ApiOperation(value = "批量运单结束", notes = "批量运单结束")
- @LoginRequired(role = AuthenticationInterceptor.AUTH_NOCAR)
- public RespR batchImprotEndBillWay(@RequestParam("file") MultipartFile file, @NotNull(message = "批量运单导入,客户名称不能为空") String customerName, User user) {
- if (null == file) {
- return new RespR(false, "批量运单结束失败,请查看数据是否维护准确");
- }
- checkHasAuthRole.checkCustomerRole(user, customerName);
- try {
- ImportParams params = new ImportParams();
- params.setTitleRows(1);
- params.setHeadRows(1);
- params.setKeyIndex(2);
- List<NoCarWayBill> list = ExcelImportUtil.importExcel(file.getInputStream(), NoCarWayBill.class, params);
- buildDateEnd(list);
- log.info("batchImprotEndBillWay数量" + list.size());
- RespR respR = noCarBillWayService.batchBillWayEnd(list, customerName);
- return respR;
- } catch (Exception e) {
- e.printStackTrace();
- return new RespR(false, e.getMessage());
- }
- }
- public void buildDate(List<NoCarWayBill> list) {
- StringBuffer sb = new StringBuffer();
- DateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
- int i = 0;
- String strError = "";
- for (int j = 0; j < list.size(); j++) {
- NoCarWayBill noCarWayBill = list.get(j);
- try {
- if (null == noCarWayBill) {
- log.error("buildDateError" + sb.toString() + "第" + (j + 1) + "行数据存在错误,请检查数据是否未传递");
- strError = "第" + (j + 1) + "行数据存在错误,请检查数据是否未传递";
- throw new RuntimeException("第" + (j + 1) + "行数据存在错误,请检查数据是否未传递");
- }
- if (org.apache.commons.lang3.StringUtils.isBlank(noCarWayBill.getBillNum())) {
- log.error("buildDateError" + sb.toString() + "第" + (j + 1) + "行数据存在错误,请检查运单编号是否未输入或者输入是否正确");
- strError = "第" + (j + 1) + "行数据存在错误,请检查运单编号是否未输入或者输入是否正确";
- throw new RuntimeException("第" + (j + 1) + "行数据存在错误,请检查运单编号是否未输入或者输入是否正确");
- }
- if (org.apache.commons.lang3.StringUtils.isBlank(noCarWayBill.getPlateNum())) {
- log.error("buildDateError" + sb.toString() + "第" + (j + 1) + "行数据存在错误,请检查车牌号码是否未输入或者输入是否正确");
- strError = "第" + (j + 1) + "行数据存在错误,请检查车牌号码是否未输入或者输入是否正确";
- throw new RuntimeException("第" + (j + 1) + "行数据存在错误,请检查车牌号码是否未输入或者输入是否正确");
- }
- if (org.apache.commons.lang3.StringUtils.isBlank(noCarWayBill.getPlateColor())) {
- log.error("buildDateError" + sb.toString() + "第" + (j + 1) + "行数据存在错误,请检查车牌颜色是否未输入或者输入是否正确");
- strError = "第" + (j + 1) + "行数据存在错误,请检查车牌颜色是否未输入或者输入是否正确";
- throw new RuntimeException("第" + (j + 1) + "行数据存在错误,请检查车牌颜色是否未输入或者输入是否正确");
- }
- if (!org.apache.commons.lang3.StringUtils.isNumeric(noCarWayBill.getPlateColor())) {
- log.error("buildDateError" + sb.toString() + "第" + (j + 1) + "行数据存在错误,请检查车牌颜色是否是数值码");
- strError = "第" + (j + 1) + "行数据存在错误,请检查车牌颜色是否是数值码";
- throw new RuntimeException("第" + (j + 1) + "行数据存在错误,请检查车牌颜色是否是数值码");
- }
- if (null == noCarWayBill.getStartTimeDate()) {
- log.error("buildDateError" + sb.toString() + "第" + (j + 1) + "行数据存在错误,请检查运单开始时间是否未输入或者输入是否正确");
- strError = "第" + (j + 1) + "行数据存在错误,请检查运单开始时间是否未输入或者输入是否正确";
- throw new RuntimeException("第" + (j + 1) + "行数据存在错误,请检查运单开始时间是否未输入或者输入是否正确");
- }
- if (org.apache.commons.lang3.StringUtils.isBlank(noCarWayBill.getSourceAddr())) {
- log.error("buildDateError" + sb.toString() + "第" + (j + 1) + "行数据存在错误,请检查运单开始地址是否未输入或者输入是否正确");
- strError = "第" + (j + 1) + "行数据存在错误,请检查运单开始地址是否未输入或者输入是否正确";
- throw new RuntimeException("第" + (j + 1) + "行数据存在错误,请检查运单开始地址是否未输入或者输入是否正确");
- }
- if (org.apache.commons.lang3.StringUtils.isBlank(noCarWayBill.getDestAddr())) {
- log.error("buildDateError" + sb.toString() + "第" + (j + 1) + "行数据存在错误,请检查运单目的地址是否未输入或者输入是否正确");
- strError = "第" + (j + 1) + "行数据存在错误,请检查运单目的地址是否未输入或者输入是否正确";
- throw new RuntimeException("第" + (j + 1) + "行数据存在错误,请检查运单目的地址是否未输入或者输入是否正确");
- }
- if (null == noCarWayBill.getPredictEndTimeDate()) {
- log.error("buildDateError" + sb.toString() + "第" + (j + 1) + "行数据存在错误,请检查运单预计完成时间是否未输入或者输入是否正确");
- strError = "第" + (j + 1) + "行数据存在错误,请检查运单预计完成时间是否未输入或者输入是否正确";
- throw new RuntimeException("第" + (j + 1) + "行数据存在错误,请检查运单预计完成时间是否未输入或者输入是否正确");
- }
- if (null == noCarWayBill.getFeeD()) {
- log.error("buildDateError" + sb.toString() + "第" + (j + 1) + "行数据存在错误,请检查运单费用是否未输入或者输入是否正确");
- strError = "第" + (j + 1) + "行数据存在错误,请检查运单费用是否未输入或者输入是否正确";
- throw new RuntimeException("第" + (j + 1) + "行数据存在错误,请检查运单费用是否未输入或者输入是否正确");
- }
- if (org.apache.commons.lang3.StringUtils.isBlank(noCarWayBill.getTaxplayerCode())) {
- log.error("buildDateError" + sb.toString() + "第" + (j + 1) + "行数据存在错误,请检查税号是否未输入或者输入是否正确");
- strError = "第" + (j + 1) + "行数据存在错误,请检查税号是否未输入或者输入是否正确";
- throw new RuntimeException("第" + (j + 1) + "行数据存在错误,请检查税号是否未输入或者输入是否正确");
- }
- noCarWayBill.setStartTime(format.format(noCarWayBill.getStartTimeDate()));
- noCarWayBill.setPredictEndTime(format.format(noCarWayBill.getPredictEndTimeDate()));
- if (noCarWayBill.getFeeD() != null) {
- noCarWayBill.setFee(Math.round(noCarWayBill.getFeeD() * 100));
- }
- noCarWayBill.setTaxplayerCode(noCarWayBill.getTaxplayerCode().trim());
- noCarWayBill.setBillNum(noCarWayBill.getBillNum().trim());
- } catch (Exception e) {
- sb.append(noCarWayBill.getBillNum() + "#");
- log.error(noCarWayBill.getBillNum());
- i++;
- }
- }
- if (i > 0) {
- log.error(org.apache.commons.lang3.StringUtils.isBlank(strError) ? "buildDateError" + sb.toString() + "第" + i + "行数据存在错误,请检查文件中数据,金额是否有空的,时间是否全是时间格式" : "buildDateError" + sb.toString() + strError);
- throw new RuntimeException(org.apache.commons.lang3.StringUtils.isBlank(strError) ? "第" + i + "行数据存在错误,请检查文件中数据,金额是否有空的,时间是否全是时间格式" : strError);
- }
- }
- public void buildDateEnd(List<NoCarWayBill> list) {
- DateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
- int i = 0;
- StringBuffer sb = new StringBuffer();
- String strError = "";
- for (int j = 0; j < list.size(); j++) {
- NoCarWayBill noCarWayBill = list.get(j);
- try {
- if (null == noCarWayBill) {
- log.error("buildDateError" + sb.toString() + "第" + (j + 1) + "行数据存在错误,请检查数据是否未传递");
- strError = "第" + (j + 1) + "行数据存在错误,请检查数据是否未传递";
- throw new RuntimeException("第" + (j + 1) + "行数据存在错误,请检查数据是否未传递");
- }
- if (org.apache.commons.lang3.StringUtils.isBlank(noCarWayBill.getBillNum())) {
- log.error("buildDateError" + sb.toString() + "第" + (j + 1) + "行数据存在错误,请检查运单编号是否未输入或者输入是否正确");
- strError = "第" + (j + 1) + "行数据存在错误,请检查运单编号是否未输入或者输入是否正确";
- throw new RuntimeException("第" + (j + 1) + "行数据存在错误,请检查运单编号是否未输入或者输入是否正确");
- }
- if (null == noCarWayBill.getActEndTimeDate()) {
- log.error("buildDateError" + sb.toString() + "第" + (j + 1) + "行数据存在错误,请检查运单实际结束时间是否未输入或者输入是否正确");
- strError = "第" + (j + 1) + "行数据存在错误,请检查运单实际结束时间是否未输入或者输入是否正确";
- throw new RuntimeException("第" + (j + 1) + "行数据存在错误,请检查运单实际结束时间是否未输入或者输入是否正确");
- }
- if (org.apache.commons.lang3.StringUtils.isBlank(noCarWayBill.getDestAddr())) {
- log.error("buildDateError" + sb.toString() + "第" + (j + 1) + "行数据存在错误,请检查运单目的地址是否未输入或者输入是否正确");
- strError = "第" + (j + 1) + "行数据存在错误,请检查运单目的地址是否未输入或者输入是否正确";
- throw new RuntimeException("第" + (j + 1) + "行数据存在错误,请检查运单目的地址是否未输入或者输入是否正确");
- }
- noCarWayBill.setPredictEndTime(format.format(noCarWayBill.getActEndTimeDate()));
- } catch (Exception e) {
- sb.append(noCarWayBill.getBillNum() + "#");
- log.error(noCarWayBill.getBillNum());
- i++;
- }
- }
- if (i > 0) {
- log.error(org.apache.commons.lang3.StringUtils.isBlank(strError) ? "buildDateError" + sb.toString() + "第" + i + "行数据存在错误,请检查文件中数据,时间是否全是时间格式" : "buildDateError" + sb.toString() + strError);
- throw new RuntimeException(org.apache.commons.lang3.StringUtils.isBlank(strError) ? "第" + i + "行数据存在错误,请检查文件中数据,时间是否全是时间格式" : strError);
- }
- }
- /**
- * 分页查询无车计费信息
- *
- * @param page 参数集
- * @return 用户集合
- */
- @PostMapping("/findBatchList")
- @ApiOperation(value = "运单批次号查询", notes = "运单批次号查询")
- @LoginRequired(role = AuthenticationInterceptor.AUTH_NOCAR)
- public RespR findBatchList(Page page, CustomerOper customerOper, User user) {
- try {
- checkHasAuthRole.checkCustomerRole(user, customerOper.getCustomerName());
- RespR respR = new RespR(customerOperService.findAllCustomerOper(page, customerOper));
- return respR;
- } catch (Exception e) {
- e.printStackTrace();
- return new RespR(false, e.getMessage());
- }
- }
- /**
- * 分页查询无车计费信息
- *
- * @param page 参数集
- * @return 用户集合
- */
- @PostMapping("/findNocarCalculateInfo")
- @ApiOperation(value = "分页查询无车计费信息", notes = "分页查询无车计费信息")
- @LoginRequired(role = AuthenticationInterceptor.AUTH_NOCAR)
- public RespR findNocarCalculateInfo(Page page, NoCarCalculateInfor carCalculateInfor, User user) {
- try {
- checkHasAuthRole.checkCustomerRole(user, carCalculateInfor.getCustomId());
- setTimeDue1(carCalculateInfor);
- RespR respR = new RespR(noCarCalculateInfoService.findByPageAndCalculateInfor(page, carCalculateInfor));
- return respR;
- } catch (Exception e) {
- e.printStackTrace();
- return new RespR(false, e.getMessage());
- }
- }
- /**
- * 分页查询无车计费统计信息
- *
- * @param carCalculateInfor 参数集
- * @return 用户集合
- */
- @PostMapping("/findNocarCalculateInfoStatis")
- @ApiOperation(value = "分页查询无车计费统计信息", notes = "分页查询无车计费统计信息")
- @LoginRequired(role = AuthenticationInterceptor.AUTH_NOCAR)
- public RespR findNocarCalculateInfoStatis(NoCarCalculateInfor carCalculateInfor, User user) {
- try {
- checkHasAuthRole.checkCustomerRole(user, carCalculateInfor.getCustomId());
- setTimeDue1(carCalculateInfor);
- RespR respR = new RespR(noCarCalculateInfoService.findNocarCalculateInfoStatis(carCalculateInfor));
- return respR;
- } catch (Exception e) {
- e.printStackTrace();
- return new RespR(false, e.getMessage());
- }
- }
- @GetMapping("/templateDownload")
- @ApiOperation(value = "模板下载", notes = "模板下载")
- public RespR contractDownload(@NotNull(message = "模板下载,文件名称不能为空") String fileName, HttpServletResponse response) {
- if (ONE.equals(fileName)) {
- fileName = "运单模板.xlsx";
- } else if (TWO.equals(fileName)) {
- fileName = "运单结束模板.xlsx";
- } else if (THREE.equals(fileName)) {
- fileName = "历史运单模板.xlsx";
- } else if (FOR.equals(fileName)) {
- fileName = "无车发票查询模板.xlsx";
- } else if (FIVE.equals(fileName)) {
- fileName = "无车运单查询模板.xlsx";
- } else if (SIX.equals(fileName)) {
- fileName = "自有车交易查询模板.xlsx";
- } else if (SEVEN.equals(fileName)) {
- fileName = "自有车发票查询模板.xlsx";
- } else if (EIGHT.equals(fileName)) {
- fileName = "自有车按交易查询申请模板.xlsx";
- }
- OutputStream outputStream = null;
- InputStream inputStream = null;
- try {
- File file = new File("/home/app/excel/" + fileName);
- inputStream = new FileInputStream(file);
- response.setHeader("Content-Disposition", "attachment;filename=" + URLEncoder.encode(fileName, "UTF-8"));
- outputStream = response.getOutputStream();
- IOUtils.copy(inputStream, outputStream);
- response.flushBuffer();
- return new RespR(true);
- } catch (IOException e) {
- } finally {
- IOUtils.closeQuietly(inputStream);
- IOUtils.closeQuietly(outputStream);
- }
- return new RespR(false);
- }
- @GetMapping("/downloadWayBillFile")
- @ApiOperation(value = "运单文件下载", notes = "运单文件下载")
- public RespR downloadWayBillFile(@Param("wayBillNum") String wayBillNum, @Param("batchNum")String batchNum, HttpServletResponse response) {
- OutputStream outputStream = null;
- InputStream inputStream = null;
- try {
- NoCarWayBillFileInfo noCarWayBillFileInfo = wayBillFileService.selectFileInfo(batchNum,wayBillNum);
- byte[] bytes = Base64Utils.DECODER_64.decode(noCarWayBillFileInfo.getBase64Str());
- ByteArrayInputStream byteInputStream = new ByteArrayInputStream(bytes);
- response.setHeader("Content-Disposition", "attachment;filename=" + URLEncoder.encode(noCarWayBillFileInfo.getFileName(), "UTF-8"));
- outputStream = response.getOutputStream();
- IOUtils.copy(byteInputStream, outputStream);
- response.flushBuffer();
- return new RespR(true);
- } catch (IOException e) {
- } finally {
- IOUtils.closeQuietly(inputStream);
- IOUtils.closeQuietly(outputStream);
- }
- return new RespR(false);
- }
- public void setTimeDue1(NoCarCalculateInfor carCalculateInfor) {
- if (!StringUtils.isEmpty(carCalculateInfor.getInvoiceMakeTime()) && !NULL.equals(carCalculateInfor.getInvoiceMakeTime())) {
- String[] res = carCalculateInfor.getInvoiceMakeTime().split(",");
- carCalculateInfor.setInvoiceMakeStart(res[0]);
- carCalculateInfor.setInvoiceMakeEnd(res[1].replace("00:00:00", "23:59:59"));
- } else {
- carCalculateInfor.setInvoiceMakeTime(null);
- }
- if (!StringUtils.isEmpty(carCalculateInfor.getCalculateTime()) && !NULL.equals(carCalculateInfor.getCalculateTime())) {
- String[] res = carCalculateInfor.getCalculateTime().split(",");
- carCalculateInfor.setCalculateStart(res[0]);
- carCalculateInfor.setCalculateEnd(res[1].replace("00:00:00", "23:59:59"));
- } else {
- carCalculateInfor.setCalculateTime(null);
- }
- }
- }
|