From 5c3154277d1f6d94d511cb7fd70e7b88ab318a99 Mon Sep 17 00:00:00 2001
From: wujianwei <wjw@11.com>
Date: 星期三, 07 一月 2026 17:00:39 +0800
Subject: [PATCH] 新增开票接口
---
service/src/main/java/com/ruoyi/cwgl/service/impl/InvoiceManageServiceImpl.java | 256 +++++++++++++++++++++++++++++++++++++++-----------
1 files changed, 198 insertions(+), 58 deletions(-)
diff --git a/service/src/main/java/com/ruoyi/cwgl/service/impl/InvoiceManageServiceImpl.java b/service/src/main/java/com/ruoyi/cwgl/service/impl/InvoiceManageServiceImpl.java
index 675ba4e..f70fb1d 100644
--- a/service/src/main/java/com/ruoyi/cwgl/service/impl/InvoiceManageServiceImpl.java
+++ b/service/src/main/java/com/ruoyi/cwgl/service/impl/InvoiceManageServiceImpl.java
@@ -1,16 +1,24 @@
package com.ruoyi.cwgl.service.impl;
-import java.util.ArrayList;
-import java.util.Date;
-import java.util.List;
+import java.util.*;
+import cn.hutool.core.collection.CollectionUtil;
+import cn.hutool.http.HttpUtil;
+import com.alibaba.fastjson2.JSONObject;
import com.ruoyi.common.core.domain.AjaxResult;
+import com.ruoyi.common.enums.SystemDataNoEnum;
+import com.ruoyi.common.exception.ServiceException;
import com.ruoyi.common.utils.DateUtils;
import javax.annotation.Resource;
import com.ruoyi.common.utils.SecurityUtils;
import com.ruoyi.common.utils.StringUtils;
-import com.ruoyi.cwgl.domain.InvoiceDetail;
+import com.ruoyi.cwgl.domain.*;
+import com.ruoyi.cwgl.domain.dto.CallbackReceiptDto;
+import com.ruoyi.cwgl.service.IInvoiceBusinessService;
+import com.ruoyi.system.service.ISystemDataNoService;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.beans.factory.annotation.Value;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.stereotype.Service;
import org.springframework.scheduling.annotation.Async;
@@ -23,8 +31,7 @@
import com.ruoyi.common.core.service.BaseService;
import com.ruoyi.cwgl.mapper.InvoiceManageMapper;
-import com.ruoyi.cwgl.domain.InvoiceManage;
-import com.ruoyi.cwgl.domain.InvoiceManageLog;
+import com.ruoyi.cwgl.mapper.InvoiceBillDetailMapper;
import com.ruoyi.cwgl.service.IInvoiceManageService;
import com.ruoyi.cwgl.service.IInvoiceManageLogService;
import com.ruoyi.common.core.text.Convert;
@@ -37,15 +44,31 @@
*/
@Service
@Transactional(rollbackFor = Exception.class)
-public class InvoiceManageServiceImpl extends BaseService<InvoiceManageMapper, InvoiceManage> implements IInvoiceManageService
-{
+public class InvoiceManageServiceImpl extends BaseService<InvoiceManageMapper, InvoiceManage> implements IInvoiceManageService {
protected final Logger logger = LoggerFactory.getLogger(getClass());
@Resource
private InvoiceManageMapper invoiceManageMapper;
-
+
+ @Resource
+ private InvoiceBillDetailMapper invoiceBillDetailMapper;
+
@Resource
private IInvoiceManageLogService invoiceManageLogService;
+ @Autowired
+ private ISystemDataNoService systemDataNoService;
+ @Autowired
+ private IInvoiceBusinessService businessService;
+ @Value("${custom.gdpaasApi.extensionNumber}")
+ private String extensionNumber;
+
+
+ @Value("${custom.gdpaasApi.clerk}")
+ private String clerk;
+ @Value("${custom.gdpaasApi.invoicingAddress}")
+ private String invoicingAddress;
+ @Value("${custom.gdpaasApi.returnAddress}")
+ private String returnAddress;
/**
* 鏌ヨ鍙戠エ绠$悊
@@ -55,8 +78,7 @@
*/
@DataSource(DataSourceType.SLAVE)
@Override
- public InvoiceManage selectInvoiceManageById(Integer id)
- {
+ public InvoiceManage selectInvoiceManageById(Integer id) {
return invoiceManageMapper.selectInvoiceManageById(id);
}
@@ -68,8 +90,7 @@
*/
@DataSource(DataSourceType.SLAVE)
@Override
- public int selectInvoiceManageCount(InvoiceManage invoiceManage)
- {
+ public int selectInvoiceManageCount(InvoiceManage invoiceManage) {
return invoiceManageMapper.selectInvoiceManageCount(invoiceManage);
}
@@ -81,8 +102,7 @@
*/
@DataSource(DataSourceType.SLAVE)
@Override
- public List<InvoiceManage> selectInvoiceManageList(InvoiceManage invoiceManage)
- {
+ public List<InvoiceManage> selectInvoiceManageList(InvoiceManage invoiceManage) {
return invoiceManageMapper.selectInvoiceManageList(invoiceManage);
}
@@ -90,15 +110,15 @@
* 鏌ヨ鍙戠エ绠$悊鍒楄〃 寮傛 瀵煎嚭
*
* @param invoiceManage 鍙戠エ绠$悊
- * @param exportKey 瀵煎嚭鍔熻兘鐨勫敮涓�鏍囪瘑
+ * @param exportKey 瀵煎嚭鍔熻兘鐨勫敮涓�鏍囪瘑
* @return 鍙戠エ绠$悊闆嗗悎
*/
@DataSource(DataSourceType.SLAVE)
@Async
@Override
- public void export(InvoiceManage invoiceManage,String exportKey) {
+ public void export(InvoiceManage invoiceManage, String exportKey) {
- super.export(InvoiceManage.class,exportKey,"invoiceManageData",(pageNum)->{
+ super.export(InvoiceManage.class, exportKey, "invoiceManageData", (pageNum) -> {
PageUtils.startPage(pageNum, Constants.EXPORT_PATE_SIZE);
return selectInvoiceManageList(invoiceManage);
});
@@ -112,17 +132,17 @@
* @return 缁撴灉
*/
@Override
- public int insertInvoiceManage(InvoiceManage invoiceManage)
- {
+ public int insertInvoiceManage(InvoiceManage invoiceManage) {
invoiceManage.setCreateTime(DateUtils.getNowDate());
+ invoiceManage.setOrderNo(systemDataNoService.getNoByKey(SystemDataNoEnum.FP));
int rows = invoiceManageMapper.insertInvoiceManage(invoiceManage);
insertInvoiceDetail(invoiceManage);
-
+
// 璁板綍鏂板鍙戠エ绠$悊鏃ュ織
if (rows > 0) {
recordInvoiceManageLog(invoiceManage, "鏂板鍙戠エ绠$悊");
}
-
+
return rows;
}
@@ -133,17 +153,16 @@
* @return 缁撴灉
*/
@Override
- public int insertInvoiceManageBatch(List<InvoiceManage> invoiceManages)
- {
+ public int insertInvoiceManageBatch(List<InvoiceManage> invoiceManages) {
int rows = invoiceManageMapper.insertInvoiceManageBatch(invoiceManages);
-
+
// 璁板綍鎵归噺鏂板鍙戠エ绠$悊鏃ュ織
if (rows > 0 && invoiceManages != null && !invoiceManages.isEmpty()) {
for (InvoiceManage invoiceManage : invoiceManages) {
recordInvoiceManageLog(invoiceManage, "鎵归噺鏂板鍙戠エ绠$悊");
}
}
-
+
return rows;
}
@@ -155,18 +174,17 @@
*/
@Transactional
@Override
- public int updateInvoiceManage(InvoiceManage invoiceManage)
- {
+ public int updateInvoiceManage(InvoiceManage invoiceManage) {
invoiceManage.setUpdateTime(DateUtils.getNowDate());
invoiceManageMapper.deleteInvoiceDetailByInvoiceManageId(invoiceManage.getId());
insertInvoiceDetail(invoiceManage);
int rows = invoiceManageMapper.updateInvoiceManage(invoiceManage);
-
+
// 璁板綍淇敼鍙戠エ绠$悊鏃ュ織
if (rows > 0) {
recordInvoiceManageLog(invoiceManage, "淇敼鍙戠エ绠$悊");
}
-
+
return rows;
}
@@ -177,16 +195,16 @@
* @return 缁撴灉
*/
@Override
- public int updateInvoiceManageBatch(List<InvoiceManage> invoiceManages){
+ public int updateInvoiceManageBatch(List<InvoiceManage> invoiceManages) {
int rows = invoiceManageMapper.updateInvoiceManageBatch(invoiceManages);
-
+
// 璁板綍鎵归噺淇敼鍙戠エ绠$悊鏃ュ織
if (rows > 0 && invoiceManages != null && !invoiceManages.isEmpty()) {
for (InvoiceManage invoiceManage : invoiceManages) {
recordInvoiceManageLog(invoiceManage, "鎵归噺淇敼鍙戠エ绠$悊");
}
}
-
+
return rows;
}
@@ -198,22 +216,19 @@
*/
@Transactional
@Override
- public int deleteInvoiceManageByIds(String ids)
- {
+ public int deleteInvoiceManageByIds(String ids) {
return deleteInvoiceManageByIds(Convert.toIntArray(ids));
}
/**
* 鍒犻櫎鍙戠エ绠$悊瀵硅薄
*
- *
* @param ids 闇�瑕佸垹闄ょ殑鏁版嵁ID
* @return 缁撴灉
*/
@Transactional
@Override
- public int deleteInvoiceManageByIds(Integer[] ids)
- {
+ public int deleteInvoiceManageByIds(Integer[] ids) {
invoiceManageMapper.deleteInvoiceDetailByInvoiceManageIds(ids);
return invoiceManageMapper.deleteInvoiceManageByIds(ids);
}
@@ -225,8 +240,7 @@
* @return 缁撴灉
*/
@Override
- public int deleteInvoiceManageById(Integer id)
- {
+ public int deleteInvoiceManageById(Integer id) {
invoiceManageMapper.deleteInvoiceDetailByInvoiceManageId(id);
return invoiceManageMapper.deleteInvoiceManageById(id);
}
@@ -237,22 +251,32 @@
* @param invoiceManage 鍙戠エ绠$悊瀵硅薄
*/
@Override
- public void insertInvoiceDetail(InvoiceManage invoiceManage)
- {
+ public void insertInvoiceDetail(InvoiceManage invoiceManage) {
List<InvoiceDetail> invoiceDetailList = invoiceManage.getInvoiceDetailList();
Integer id = invoiceManage.getId();
- if (StringUtils.isNotNull(invoiceDetailList))
- {
+ if (StringUtils.isNotNull(invoiceDetailList)) {
List<InvoiceDetail> list = new ArrayList<InvoiceDetail>();
- for (InvoiceDetail invoiceDetail : invoiceDetailList)
- {
+ for (InvoiceDetail invoiceDetail : invoiceDetailList) {
invoiceDetail.setInvoiceManageId(id);
invoiceDetail.setCreateTime(new Date());
list.add(invoiceDetail);
}
- if (list.size() > 0)
- {
+ if (list.size() > 0) {
invoiceManageMapper.batchInvoiceDetail(list);
+ }
+ }
+
+ // 鏂板鍙戠エ涓氬姟鍟嗗搧鏄庣粏淇℃伅
+ List<InvoiceBillDetail> invoiceBillDetails = invoiceManage.getInvoiceBillDetails();
+ if (StringUtils.isNotNull(invoiceBillDetails)) {
+ List<InvoiceBillDetail> billDetailList = new ArrayList<InvoiceBillDetail>();
+ for (InvoiceBillDetail invoiceBillDetail : invoiceBillDetails) {
+ invoiceBillDetail.setInvoiceManageId(id);
+ invoiceBillDetail.setCreateTime(new Date());
+ billDetailList.add(invoiceBillDetail);
+ }
+ if (billDetailList.size() > 0) {
+ invoiceBillDetailMapper.insertInvoiceBillDetailBatch(billDetailList);
}
}
}
@@ -263,22 +287,21 @@
* @param invoiceManage 鍙戠エ绠$悊瀵硅薄
* @param operationType 鎿嶄綔绫诲瀷
*/
- private void recordInvoiceManageLog(InvoiceManage invoiceManage, String operationType)
- {
+ private void recordInvoiceManageLog(InvoiceManage invoiceManage, String operationType) {
try {
InvoiceManageLog log = new InvoiceManageLog();
log.setInvoiceManageId(invoiceManage.getId());
log.setOperator(SecurityUtils.getUsername());
log.setOperationTime(DateUtils.getNowDate());
-
+
// 鏋勫缓鎿嶄綔鎻忚堪锛屽寘鍚紑绁ㄩ噾棰濄�佸叧鑱旇处鍗曠紪鍙峰拰瀵瑰簲寮�绁ㄩ噾棰�
StringBuilder descBuilder = new StringBuilder();
descBuilder.append(operationType).append(": ");
-
+
if (invoiceManage.getInvoiceAmount() != null) {
descBuilder.append("寮�绁ㄩ噾棰�=").append(invoiceManage.getInvoiceAmount()).append("; ");
}
-
+
// 鑾峰彇鍏宠仈璐﹀崟淇℃伅
if (invoiceManage.getInvoiceDetailList() != null && !invoiceManage.getInvoiceDetailList().isEmpty()) {
descBuilder.append("鍏宠仈璐﹀崟淇℃伅: ");
@@ -292,10 +315,10 @@
descBuilder.append("; ");
}
}
-
+
log.setOperationDesc(descBuilder.toString());
log.setCreateTime(DateUtils.getNowDate());
-
+
invoiceManageLogService.insertInvoiceManageLog(log);
} catch (Exception e) {
logger.error("璁板綍鍙戠エ绠$悊鎿嶄綔鏃ュ織澶辫触: {}", e.getMessage());
@@ -304,8 +327,96 @@
@Override
public AjaxResult applyInvoice(Integer id) {
+ InvoiceManage invoiceManage = selectInvoiceManageById(id);
+ if (invoiceManage == null) {
+ throw new ServiceException("鍙戠エ璁板綍涓嶅瓨鍦�");
+ }
+ if (invoiceManage.getStatus().equals(1)) {
+ throw new ServiceException("璇峰嬁閲嶅寮�绁�");
- return AjaxResult.success("鐢宠寮�绁ㄦ垚鍔�");
+ }
+ List<InvoiceBillDetail> invoiceBillDetails = invoiceManage.getInvoiceBillDetails();
+ if (CollectionUtil.isEmpty(invoiceBillDetails)) {
+ throw new ServiceException("鍟嗗搧鏄庣粏鏃犳暟鎹棤娉曞紑鍙戠エ");
+
+ }
+
+ // 璁板綍鐢宠寮�绁ㄦ棩蹇�
+ recordApplyInvoiceLog(invoiceManage);
+
+ return componentInvoice(invoiceManage.getInvoiceNo(),"FP",invoiceManage,invoiceBillDetails);
+ }
+
+ public AjaxResult componentInvoice(String orderNo, String businessType, InvoiceManage invoiceManage, List<InvoiceBillDetail> invoiceBillDetails) {
+
+ InvoicingVo invoicingVo = new InvoicingVo();
+ Order order = new Order();
+ order.setSalerTaxNum(invoiceManage.getInvoiceSellerCreditCode());
+ order.setSalerTel(invoiceManage.getInvoiceSellerPhone());
+ order.setSalerAddress(invoiceManage.getInvoiceSellerAddress());
+ order.setInvoiceDate(DateUtils.dateTimeNow(DateUtils.YYYY_MM_DD_HH_MM_SS));
+ order.setClerk(clerk);
+ order.setInvoiceType("1");
+ order.setPushMode("0");
+ order.setExtensionNumber(extensionNumber);
+
+ order.setOrderNo(orderNo);
+ order.setEmail(invoiceManage.getInvoiceOperatingLicenseEmail());
+ order.setBuyerName(invoiceManage.getInvoiceCompanyName());
+ order.setInvoiceLine(invoiceManage.getInvoiceType());
+ order.setBuyerPhone(invoiceManage.getInvoiceOperatingLicensePhone());
+ order.setBuyerTaxNum(invoiceManage.getInvoiceCreditCode());
+ order.setBuyerTel(invoiceManage.getInvoiceOperatingLicensePhone());
+ if (StringUtils.isNotBlank(invoiceManage.getInvoiceBankNo()) &&
+ StringUtils.isNotBlank(invoiceManage.getInvoiceBankName())) {
+ order.setBuyerAccount(invoiceManage.getInvoiceBankName() + " " + invoiceManage.getInvoiceBankNo());
+ }
+
+ List<InvoiceDetailApi> invoiceDetailList = new ArrayList<>();
+ //鍟嗗搧鏄庣粏
+ for (InvoiceBillDetail billingDetail : invoiceBillDetails) {
+ InvoiceDetailApi invoiceDetail = new InvoiceDetailApi();
+
+
+ invoiceDetail.setGoodsName(invoiceDetail.getGoodsName());
+
+ invoiceDetail.setWithTaxFlag(billingDetail.getWithTaxFlag().toString());
+ invoiceDetail.setTaxRate("0.06");
+ invoiceDetail.setUnit("椤�");
+ invoiceDetail.setNum("1");
+ invoiceDetail.setPrice(billingDetail.getPrice().toString()); // 鍒濆浠锋牸涓�0
+ invoiceDetailList.add(invoiceDetail);
+ }
+
+
+ order.setInvoiceDetail(invoiceDetailList);
+ invoicingVo.setOrder(order);
+ String body = JSONObject.toJSONString(invoicingVo);
+ String json = HttpUtil.post(invoicingAddress + "?businessType=" + businessType + "&returnUrl=" + returnAddress, body);
+
+ if (json == null) {
+ logger.info("寮�绁ㄥけ璐�");
+ return AjaxResult.error("寮�绁ㄥけ璐�");
+ }
+ JSONObject jsonObject = JSONObject.parseObject(json);
+ String code = jsonObject.getString("code");
+
+ String invoiceSerialNum = null;
+ InvoiceBusiness record = new InvoiceBusiness();
+ record.setReqData(JSONObject.toJSONString(invoicingVo));
+ record.setResData(json);
+ record.setCreateTime(new Date());
+ if ("0".equals(code)) {
+ String data = jsonObject.getString("data");
+
+ JSONObject dataJson = JSONObject.parseObject(data);
+ invoiceSerialNum = dataJson.getString("invoiceSerialNum");
+ logger.info("寮�绁ㄦ垚鍔熷彂绁ㄥ簭鍒楀彿涓簕}", invoiceSerialNum);
+ record.setInvoiceSerialNum(invoiceSerialNum);
+ record.setInvoiceManageId(invoiceManage.getId());
+ return AjaxResult.success();
+ }
+ return AjaxResult.error("寮�绁ㄥけ璐�");
}
/**
@@ -313,8 +424,7 @@
*
* @param invoiceManage 鍙戠エ绠$悊瀵硅薄
*/
- private void recordApplyInvoiceLog(InvoiceManage invoiceManage)
- {
+ private void recordApplyInvoiceLog(InvoiceManage invoiceManage) {
try {
InvoiceManageLog log = new InvoiceManageLog();
log.setInvoiceManageId(invoiceManage.getId());
@@ -351,4 +461,34 @@
logger.error("璁板綍鐢宠寮�绁ㄦ棩蹇楀け璐�: {}", e.getMessage());
}
}
+
+ @Override
+ public void invoicingSuccess(CallbackReceiptDto callbackReceiptDto) {
+ InvoiceManage invoiceBusiness = invoiceManageMapper.selectInvoiceManageLogByOrderNo(callbackReceiptDto.getOrderno());
+ if (invoiceBusiness == null) {
+ return;
+ }
+ String content = callbackReceiptDto.getContent();
+ if (StringUtils.isEmpty(content)) {
+ return;
+ }
+ JSONObject jsonObject = JSONObject.parseObject(content);
+
+ int c_status = Integer.parseInt(jsonObject.getString("c_status"));
+ invoiceBusiness.setStatus(c_status);
+ if (c_status == 1) {
+
+
+ String invoiceNumStr = jsonObject.getString("c_fphm");
+
+ InvoiceManage invoiceManageUpdate = new InvoiceManage();
+ invoiceManageUpdate.setInvoiceNo(invoiceNumStr);
+ invoiceManageUpdate.setId(invoiceBusiness.getId());
+ invoiceManageUpdate.setStatus(2);
+ invoiceManageMapper.updateById(invoiceBusiness);
+ }
+ }
}
+
+
+
--
Gitblit v1.8.0