Merge remote-tracking branch 'origin/dev' into dev
This commit is contained in:
@ -280,6 +280,13 @@
|
||||
<artifactId>netty-all</artifactId>
|
||||
</dependency>
|
||||
|
||||
|
||||
<dependency>
|
||||
<groupId>commons-codec</groupId>
|
||||
<artifactId>commons-codec</artifactId>
|
||||
<version>1.15</version> <!-- 最新版本可自行调整 -->
|
||||
</dependency>
|
||||
|
||||
</dependencies>
|
||||
|
||||
</project>
|
||||
|
||||
@ -3,10 +3,12 @@ package org.dromara.project.controller;
|
||||
import cn.dev33.satoken.annotation.SaIgnore;
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import lombok.extern.slf4j.Slf4j;
|
||||
import org.apache.commons.codec.binary.Base64;
|
||||
import org.dromara.common.core.domain.R;
|
||||
import org.dromara.common.web.core.BaseController;
|
||||
import org.dromara.project.domain.BusAttendanceMachine;
|
||||
import org.dromara.project.domain.dto.attendance.*;
|
||||
import org.dromara.project.domain.vo.attendance.DeviceResult;
|
||||
import org.dromara.project.service.IBusAttendanceMachineService;
|
||||
import org.dromara.project.service.IBusAttendanceService;
|
||||
import org.springframework.mock.web.MockMultipartFile;
|
||||
@ -17,7 +19,7 @@ import org.springframework.web.multipart.MultipartFile;
|
||||
import java.io.IOException;
|
||||
import java.time.LocalDateTime;
|
||||
import java.time.format.DateTimeFormatter;
|
||||
import java.util.Base64;
|
||||
|
||||
|
||||
/**
|
||||
* 考勤
|
||||
@ -34,15 +36,15 @@ public class BusAttendanceDeviceController extends BaseController {
|
||||
|
||||
private final IBusAttendanceService busAttendanceService;
|
||||
|
||||
private final IBusAttendanceMachineService busAttendanceMachineService;
|
||||
private final IBusAttendanceMachineService busAttendanceMachineService;
|
||||
|
||||
@PostMapping("/api/v1/record/face")
|
||||
@SaIgnore
|
||||
public R<Boolean> punchCardByFace(@RequestBody DeviceDto dto) {
|
||||
public DeviceResult punchCardByFace(@RequestBody DeviceDto dto) {
|
||||
//打印接收数据
|
||||
log.info("接收数据:{}", dto);
|
||||
if (dto.getLogs().isEmpty()) {
|
||||
return R.fail("没有数据");
|
||||
return new DeviceResult(500, "没有数据");
|
||||
}
|
||||
Log first = dto.getLogs().getFirst();
|
||||
|
||||
@ -53,7 +55,7 @@ public class BusAttendanceDeviceController extends BaseController {
|
||||
.last("limit 1")
|
||||
.one();
|
||||
if (one == null || one.getProjectId() == null) {
|
||||
return R.fail("考勤机不存在或未关联项目");
|
||||
return new DeviceResult(500, "考勤机不存在或未关联项目");
|
||||
}
|
||||
|
||||
String recogTime = first.getRecog_time();
|
||||
@ -74,14 +76,14 @@ public class BusAttendanceDeviceController extends BaseController {
|
||||
// 假设first.getImage()返回base64字符串,且你有一个文件名
|
||||
MultipartFile file = convert(first.getPhoto(), "face.jpg");
|
||||
log.info("开始打卡");
|
||||
return R.ok(busAttendanceService.punchCardByFace(file, req));
|
||||
busAttendanceService.punchCardByFace(file, req);
|
||||
return new DeviceResult(0, "打卡成功");
|
||||
} catch (IOException e) {
|
||||
return R.fail("文件转换失败");
|
||||
return new DeviceResult(500, "文件转换失败");
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
public static MultipartFile convert(String base64String, String fileName) throws IOException {
|
||||
// 先进行URL解码(如果是URL编码过的数据)
|
||||
try {
|
||||
@ -96,23 +98,11 @@ public class BusAttendanceDeviceController extends BaseController {
|
||||
}
|
||||
|
||||
// 解码base64字符串
|
||||
byte[] decodedBytes = Base64.getDecoder().decode(base64String);
|
||||
byte[] decodedBytes = Base64.decodeBase64(base64String);
|
||||
|
||||
// 创建MultipartFile对象
|
||||
return new MockMultipartFile(fileName, fileName, "image/jpeg", decodedBytes);
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
}
|
||||
|
||||
@ -0,0 +1,16 @@
|
||||
package org.dromara.project.domain.vo.attendance;
|
||||
|
||||
|
||||
import lombok.AllArgsConstructor;
|
||||
import lombok.Data;
|
||||
import lombok.NoArgsConstructor;
|
||||
|
||||
@Data
|
||||
@AllArgsConstructor
|
||||
@NoArgsConstructor
|
||||
public class DeviceResult {
|
||||
|
||||
private Integer Result;
|
||||
|
||||
private String Msg;
|
||||
}
|
||||
@ -12,14 +12,11 @@ public enum XzdClassEnum {
|
||||
JS_ZHFW_JINDU("xzd_js_zhfw_jindu"), //综合服务合同进度结算
|
||||
JS_CG_JUNGON("xzd_js_cg_jungon"), //采购合同竣工结算
|
||||
JS_CG_JINDU("xzd_js_cg_jindu"), //采购合同进度结算
|
||||
// 分包合同
|
||||
FENBAOHETONG_INFORMATION("xzd_subcontract"),
|
||||
// 分包合同变更
|
||||
FENBAOHETONGBINGGENG_INFORMATION("xzd_subcontract_change"),
|
||||
// 采购变更合同
|
||||
CAIGOUHETONG_INFORMATION("xzd_purchase_contract_alteration"),
|
||||
// 采购合同
|
||||
PURCHASE_CONTRACT_INFORMATION("xzd_purchase_contract_information");
|
||||
FENBAOHETONG_INFORMATION("xzd_subcontract"),//分包合同
|
||||
FENBAOHETONGBINGGENG_INFORMATION("xzd_subcontract_change"),//分包合同变更
|
||||
CAIGOUHETONG_INFORMATION("xzd_purchase_contract_alteration"), //采购变更合同
|
||||
FENBAOHETONG_JINDU("xzd_settlement_of_subcontracting_contract"),//分包合同进度结算
|
||||
PURCHASE_CONTRACT_INFORMATION("xzd_purchase_contract_information");//采购合同
|
||||
|
||||
|
||||
|
||||
|
||||
@ -5,6 +5,9 @@ public enum ZxdEnum {
|
||||
|
||||
TYPE_CORRESPONDENT("客户","1"),
|
||||
TYPE_SUPPLIER("供应商","2"),
|
||||
FENBAOHET("分包合同","2"),
|
||||
HETONGLEIXING("合同外清单","1"),
|
||||
HETONGLEIXINGNEI("合同内清单","2"),
|
||||
PURCHASE_PREFIX("采购合同信息前缀","CCTEG(CWZ)"),
|
||||
FENBAOHETONG_PREFIX("分包合同信息前缀","CCTEG(CSG)");
|
||||
|
||||
|
||||
@ -40,6 +40,11 @@ public class XzdAlterationInventory extends BaseEntity {
|
||||
*/
|
||||
private String code;
|
||||
|
||||
/**
|
||||
* 合同类型(1、承包合同,2、分包合同,3、采购合同,4综合服务合同)
|
||||
*/
|
||||
private String contractType;
|
||||
|
||||
/**
|
||||
* 合同清单名称
|
||||
*/
|
||||
|
||||
@ -44,6 +44,11 @@ public class XzdAlterationInventoryBo extends BaseEntity {
|
||||
*/
|
||||
private String contractListName;
|
||||
|
||||
/**
|
||||
* 合同类型(1、承包合同,2、分包合同,3、采购合同,4综合服务合同)
|
||||
*/
|
||||
private String contractType;
|
||||
|
||||
/**
|
||||
* 项目名称
|
||||
*/
|
||||
|
||||
@ -94,8 +94,12 @@ public class XzdAlterationInventoryVo implements Serializable {
|
||||
* 含税单价
|
||||
*/
|
||||
@ExcelProperty(value = "含税单价")
|
||||
private BigDecimal taxInclusiveUnitPrice;
|
||||
|
||||
|
||||
/**
|
||||
* 合同类型(1、承包合同,2、分包合同,3、采购合同,4综合服务合同)
|
||||
*/
|
||||
private String contractType;
|
||||
/**
|
||||
* 本期结算数量
|
||||
*/
|
||||
|
||||
Reference in New Issue
Block a user