当前位置: 首页 > news >正文

小熊家务帮day8-day9 客户管理模块2 (用户定位,地址簿,实名认证,银行卡信息上传等功能)

客户管理模块

  • 0.用户定位功能
    • 0.1 需求
    • 0.2 接口分析
    • 0.3 接口开发
      • Controller层开发
      • Service层开发
  • 1.我的地址簿功能
    • 1.1 需求
    • 1.2 数据库设计
    • 1.3 新增地址簿
      • 1.3.1 接口设计
      • 1.3.2 接口开发
        • Controller层开发
        • Service层开发
        • 测试功能
    • 1.4 地址簿查询
      • 1.4.1 接口设计
      • 1.4.2 接口开发
        • Controller层开发
        • Service层开发
        • 功能测试
    • 1.4 地址簿编辑
      • 1.4.1 需求
        • 1.4.2 根据地址薄id查询地址薄
          • 接口分析
          • Controller
        • 1.4.3 修改地址薄信息
          • 接口分析
          • Controller
          • Service层开发
        • 1.4.4 功能测试
    • 1.5 地址簿删除
      • 1.5.1 接口设计
      • 1.5.2 接口开发
        • Controller层开发
    • 1.6 设置/取消默认地址
      • 1.6.1 接口分析
      • 1.6.2 接口开发
        • Controller层开发
        • Service层开发
      • 1.6.3 功能测试
    • 1.7 获取默认地址接口
      • 1.7.1 接口分析
      • 1.7.2 接口设计
        • Controller层开发
        • Service层开发
  • 2.我的账户设置
    • 2.1 需求
    • 2.1 机构端设置银行账号
      • 2.1.1 新增或更新银行账号信息
        • 2.1.1.0 数据库表设计
        • 2.1.1.1 接口分析
        • 2.1.1.2 接口开发
          • Controller层开发
          • Service层开发
        • 2.1.1.3 功能测试
      • 2.1.2 查询银行账号信息
        • 2.1.2.1 接口分析
        • 2.1.2.2 接口开发
          • Controller层开发
    • 2.2 服务端设置银行账号
      • 2.2.1 服务端新增/更新银行账户
        • 2.2.1.1 接口分析
        • 2.2.1.2 接口开发
          • Controller层开发
        • 2.2.1.3 功能测试
      • 2.2.2 服务端获取当前用户银行账号接口
        • 2.2.2.1 接口分析
        • 2.2.2.2 接口开发
          • Controller层开发
        • 2.2.2.3 功能测试
  • 3.机构/服务人员认证模块
    • 3.1 需求
      • 3.1.1 服务端认证
      • 3.1.2 机构端认证
      • 3.1.1 运营端审核认证
    • 3.2 服务端提交认证
      • 3.2.0 服务人员认证审核表设计
      • 3.2.1 接口设计
      • 3.2.2 接口开发
        • Controller层开发
        • Service层开发
      • 3.2.3 功能测试
      • 3.2.4 服务人员查询认证驳回原因设计
        • 接口分析
        • Controller层
        • Service层
    • 3.3 机构端提交认证
      • 3.3.1 表设计
      • 3.3.2 接口设计
      • 3.3.3 接口开发
        • Controller层开发
        • Service层开发
      • 3.3.4 功能测试
      • 3.3.5 查询最新的驳回原因
        • 接口分析
        • 接口设计
          • Controller层
          • Service层
  • 4.运营端审核认证模块
    • 4.1 需求
    • 4.1审核服务人员
      • 4.1.1 分页查询审核信息
        • 4.1.1.1 接口分析
        • 4.1.1.2 接口开发
          • Controller层
          • Service层
        • 4.1.1.3 功能测试
      • 4.1.2 审核信息
        • 4.1.2.1 接口分析
        • 4.1.2.2 接口开发
          • Controller层
          • Service层
    • 4.2 审核机构人员
      • 4.2.1 分页查询审核信息
        • 2.2.1.1 接口分析
        • 2.2.1.2 接口开发
          • Controller层
          • Service层
      • 4.2.2 审核信息
        • 4.2.2.1接口分析
        • 4.2.2.2 接口开发
          • Controller层
          • Service层

0.用户定位功能

0.1 需求

用户端在小程序认证通过后会自动进行定位,也可以在首页手动定位,定位成功后用户在查询家政服务项目时会根据定位的城市查询该城市有哪些服务项目。
手动定位过程如下图:
在这里插入图片描述
点击下图箭头位置进行手动定位。
在这里插入图片描述
定位成功再次进入首页发现位置变为新地址

小程序端的定位是通过手机的定位模块进行定位,定位成功获取经纬度坐标,平台根据经纬度坐标请求地图服务获取经纬度坐标对应的具体位置。
在这里插入图片描述

小程序首先通过微信提供的方法拿到经纬度坐标,然后请求后端获取具体的位置,后端会请求高德地图根据经纬度获取具体的城市信息。

0.2 接口分析

当用户进入小程序后,批准小程序获取位置,则会发出以下请求:
在这里插入图片描述
后端会请求高德地图根据经纬度获取具体的cityCode

0.3 接口开发

Controller层开发

@RestController
@RequestMapping("/inner/map")
@Api(tags = "内部接口 - 地图服务相关接口")
public class InnerMapController implements MapApi {@Resourceprivate MapService mapService;@Override@GetMapping("/getLocationByAddress")@ApiOperation("根据地址查询经纬度")@ApiImplicitParams({@ApiImplicitParam(name = "address", value = "地址", required = true, dataTypeClass = String.class)})public LocationResDTO getLocationByAddress(@RequestParam("address") String address) {String location = mapService.getLocationByAddress(address);return new LocationResDTO(location);}
}

Service层开发

首先就是存一下经纬度以及高德开发api的key,其中高德开发者key存在了nacos配置中心中,之后调用高德api获取到cityCode进行返回即可:
在这里插入图片描述

    public String getLocationByAddress(String address) {Map<String, Object> params = new HashMap();params.put("address", address);params.put("key", this.amapProperties.getKey());String jsonStr = HttpRequest.get("https://restapi.amap.com/v3/geocode/geo?").form(params).execute().body();JSONObject jsonObject = JSONUtil.parseObj(jsonStr);JSONArray geocodes = JSONUtil.parseArray(jsonObject.get("geocodes"));Object location = JSONUtil.parseObj(geocodes.get(0)).get("location");return location.toString();}

1.我的地址簿功能

1.1 需求

用户下单时需要选择服务地址(相当于收货地址),在“我的”–》“我的地址”界面维护地址簿信息。
在这里插入图片描述
点击“我的地址”即可进入地址簿管理界面
因此,需要完成以下功能:

  • 新增地址簿
  • 地址簿编辑
  • 地址簿删除
  • 地址簿查询
  • 批量删除
  • 设置默认地址

1.2 数据库设计

create table `jzo2o-customer`.address_book
(id          bigint                             not null comment '主键'constraint `PRIMARY`primary key,user_id     bigint                             not null comment '用户id',name        varchar(255)                       not null comment '名称',phone       varchar(255)                       not null comment '电话',province    varchar(255)                       not null comment '省份',city        varchar(255)                       not null comment '市级',county      varchar(255)                       not null comment '区/县',address     varchar(255)                       not null comment '详细地址',lon         double(10, 5)                      null comment '经度',lat         double(10, 5)                      null comment '纬度',is_default  int      default 0                 not null comment '是否为默认地址,0:否,1:是',is_deleted  int      default 0                 not null comment '是否已删除,0:未删除,1:已删除',create_time datetime default CURRENT_TIMESTAMP not null comment '创建时间',create_by   bigint                             null comment '创建者',update_time datetime default CURRENT_TIMESTAMP not null on update CURRENT_TIMESTAMP comment '更新时间',update_by   bigint                             null comment '更新者'
)

1.3 新增地址簿

1.3.1 接口设计

接口路径:POST/customer/consumer/address-book
请求数据类型 application/json
在这里插入图片描述在这里插入图片描述

1.3.2 接口开发

Controller层开发
@RestController("consumerAddressBookController")
@RequestMapping("/consumer/address-book")
@Api(tags = "用户端 - 地址薄相关接口")
public class AddressBookCotroller {@Autowiredprivate IAddressBookService addressBookService;@RequestMapping("/address-book")@ApiOperation("地址薄新增")public void add(@RequestBody AddressBookUpsertReqDTO addressBookUpsertReqDTO){IAddressBookService.add(addressBookUpsertReqDTO);}
}
Service层开发

大概业务逻辑就是:

  • 从Threadlocal中获取userId
  • 若请求中该新增地址设为默认,则取消之前的默认地址
  • 拼接地址
  • 写入数据库

取消之前的默认地址如下:

    /*** 取消默认地址* @param userId*/private void cancelDefault(Long userId) {lambdaUpdate().eq(AddressBook::getId,userId).set(AddressBook::getIsDefault,0).update();}

Service层代码:

    /*** 新增地址簿* @param addressBookUpsertReqDTO*/@Overridepublic void add(AddressBookUpsertReqDTO addressBookUpsertReqDTO){//1.从Threadlocal中获取当前用户idLong userId = UserContext.currentUserId();//2.如果新增中设为默认地址,取消其他默认地址if (1 == addressBookUpsertReqDTO.getIsDefault()) {cancelDefault(userId);}AddressBook addressBook = BeanUtil.toBean(addressBookUpsertReqDTO, AddressBook.class);addressBook.setId(userId);//3.组装详细地址String completeAddress = addressBookUpsertReqDTO.getProvince() +addressBookUpsertReqDTO.getCity() +addressBookUpsertReqDTO.getCounty() +addressBookUpsertReqDTO.getAddress();//4.如果请求体中没有经纬度,需要调用第三方api根据详细地址获取经纬度if(ObjectUtils.isEmpty(addressBookUpsertReqDTO.getLocation())){//调用高德接口获得经纬度LocationResDTO locationDto = mapApi.getLocationByAddress(completeAddress);//经纬度(字符串格式:经度,纬度),经度在前,纬度在后String location = locationDto.getLocation();addressBookUpsertReqDTO.setLocation(location);}if(StringUtils.isNotEmpty(addressBookUpsertReqDTO.getLocation())) {// 经度addressBook.setLon(NumberUtils.parseDouble(addressBookUpsertReqDTO.getLocation().split(",")[0]));// 纬度addressBook.setLat(NumberUtils.parseDouble(addressBookUpsertReqDTO.getLocation().split(",")[1]));}addressBookService.save(addressBook);}
测试功能

输入信息:
在这里插入图片描述
请求正常被收到并且处理:
在这里插入图片描述
数据库也插入了:
在这里插入图片描述

1.4 地址簿查询

1.4.1 接口设计

接口路径:GET/customer/consumer/address-book/page
请求数据类型 application/x-www-form-urlencoded
在这里插入图片描述
在这里插入图片描述

1.4.2 接口开发

Controller层开发
    @GetMapping("/page")@ApiOperation("地址薄分页查询")public PageResult<AddressBookResDTO> page(AddressBookPageQueryReqDTO addressBookPageQueryReqDTO){return addressBookService.page(addressBookPageQueryReqDTO);}
Service层开发
    /*** 地址簿分页查询* @param addressBookPageQueryReqDTO* @return*/@Overridepublic PageResult<AddressBookResDTO> page(AddressBookPageQueryReqDTO addressBookPageQueryReqDTO) {Page<AddressBook> page = PageUtils.parsePageQuery(addressBookPageQueryReqDTO, AddressBook.class);LambdaQueryWrapper<AddressBook> lambdaQueryWrapper = Wrappers.lambdaQuery(AddressBook.class).eq(AddressBook::getUserId, UserContext.currentUserId());Page<AddressBook> page1 = addressBookService.page(page, lambdaQueryWrapper);return PageUtils.toPage(page1, AddressBookResDTO.class);}
功能测试

在这里插入图片描述

1.4 地址簿编辑

1.4.1 需求

实现点击编辑按钮,应该首先显示出当前地址信息,之后修改后数据写回数据库,因此,这个功能包含两部分:

  • 根据地址薄id查询信息
  • 修改地址薄
1.4.2 根据地址薄id查询地址薄
接口分析

接口路径:GET/customer/consumer/address-book/{id}在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

Controller
    @GetMapping("/#{id}")@ApiOperation("地址薄详情")@ApiImplicitParams({@ApiImplicitParam(name = "id", value = "地址薄id", required = true, dataTypeClass = Long.class)})public AddressBookResDTO detail(@PathVariable("id") Long id){AddressBook addressBook = addressBookService.getById(id);return BeanUtil.toBean(addressBook, AddressBookResDTO.class);}
1.4.3 修改地址薄信息
接口分析

接口路径:PUT/customer/consumer/address-book/{id}
请求数据类型 application/json
在这里插入图片描述
在这里插入图片描述

Controller
    @PutMapping("/{id}")@ApiOperation("地址薄修改")@ApiImplicitParams({@ApiImplicitParam(name = "id", value = "地址薄id", required = true, dataTypeClass = Long.class)})public void update(@PathVariable("id") Long id,@RequestBody AddressBookUpsertReqDTO addressBookUpsertReqDTO){addressBookService.update(id,addressBookUpsertReqDTO);}
Service层开发
    @Overridepublic void update(Long id, AddressBookUpsertReqDTO addressBookUpsertReqDTO) {//1.判断是否取消默认if(addressBookUpsertReqDTO.getIsDefault() == 1){cancelDefault(id);}AddressBook addressBook = BeanUtil.toBean(addressBookUpsertReqDTO, AddressBook.class);addressBook.setId(id);//调用第三方,根据地址获取经纬度坐标String completeAddress = addressBookUpsertReqDTO.getProvince() +addressBookUpsertReqDTO.getCity() +addressBookUpsertReqDTO.getCounty() +addressBookUpsertReqDTO.getAddress();//远程请求高德获取经纬度LocationResDTO locationDto = mapApi.getLocationByAddress(completeAddress);//经纬度(字符串格式:经度,纬度),经度在前,纬度在后String location = locationDto.getLocation();if(StringUtils.isNotEmpty(location)) {// 经度addressBook.setLon(NumberUtils.parseDouble(locationDto.getLocation().split(",")[0]));// 纬度addressBook.setLat(NumberUtils.parseDouble(locationDto.getLocation().split(",")[1]));}addressBookMapper.updateById(addressBook);}
1.4.4 功能测试

首先点击了编辑:
在这里插入图片描述
之后开始编辑并且确定:
在这里插入图片描述
功能已经实现:
在这里插入图片描述

1.5 地址簿删除

1.5.1 接口设计

接口路径:DELETE/customer/consumer/address-book/batch
在这里插入图片描述
在这里插入图片描述

1.5.2 接口开发

Controller层开发

实现比较简单,直接在controller调用mp的方法即可:

    @DeleteMapping("/batch")@ApiOperation("地址薄批量删除")@ApiImplicitParam(name = "ids", value = "地址薄id列表", required = true, dataTypeClass = List.class)public void batch(@RequestBody List<Long> ids){addressBookService.removeByIds(ids);}

1.6 设置/取消默认地址

1.6.1 接口分析

接口路径:PUT/customer/consumer/address-book/default
请求数据类型 application/x-www-form-urlencoded
在这里插入图片描述
在这里插入图片描述

1.6.2 接口开发

Controller层开发
    @PutMapping("/default")@ApiOperation("地址薄设为默认/取消默认")@ApiImplicitParams({@ApiImplicitParam(name = "id", value = "地址薄id", required = true, dataTypeClass = Long.class),@ApiImplicitParam(name = "flag", value = "是否为默认地址,0:否,1:是", required = true, dataTypeClass = Integer.class)})public void updateDefaultStatus(@NotNull(message = "id不能为空") @RequestParam("id") Long id,@NotNull(message = "状态值不能为空") @RequestParam("flag") Integer flag) {//当前登录用户idLong userId = UserContext.currentUserId();addressBookService.updateDefaultStatus(userId,id, flag);}
Service层开发
    /*** 设置/取消默认地址* @param userId* @param id* @param flag*/@Overridepublic void updateDefaultStatus(Long userId, Long id, Integer flag) {if (1 == flag) {//如果设默认地址,先把其他地址取消默认cancelDefault(userId);}AddressBook addressBook = new AddressBook();addressBook.setId(id);addressBook.setIsDefault(flag);addressBookMapper.updateById(addressBook);}

1.6.3 功能测试

一开始:
在这里插入图片描述
之后我们李浩111设为默认地址:
在这里插入图片描述
功能测试成功

1.7 获取默认地址接口

在下单界面先获取当前用户的默认地址,如果有默认地址则直接显示在页面中,因此需要提前设计好这个接口

1.7.1 接口分析

接口路径:GET/customer/consumer/address-book/defaultAddress
请求数据类型 application/x-www-form-urlencoded
请求参数:无
在这里插入图片描述
在这里插入图片描述

1.7.2 接口设计

Controller层开发
    @GetMapping("/defaultAddress")@ApiOperation("获取默认地址")public AddressBookResDTO defaultAddress(){return addressBookService.defaultAddress();}
Service层开发
    /*** 获取默认地址信息* @return*/@Overridepublic AddressBookResDTO defaultAddress() {LambdaQueryWrapper<AddressBook> lambdaQueryWrapper = Wrappers.lambdaQuery(AddressBook.class);lambdaQueryWrapper.eq(AddressBook::getUserId,UserContext.currentUserId()).eq(AddressBook::getIsDefault,1);AddressBook addressBook = addressBookMapper.selectOne(lambdaQueryWrapper);return BeanUtil.toBean(addressBook,AddressBookResDTO.class);}

2.我的账户设置

2.1 需求

需要完成以下功能:

  • 服务端设置银行卡
  • 机构端设置银行卡
  • 新增或者更新以上设置的银行卡
  • 获取银行卡信息的接口

本模块在维护银行账户信息时需要上传银行卡照片,本项目的图片服务器使用阿里的OSS存储。

2.1 机构端设置银行账号

2.1.1 新增或更新银行账号信息

2.1.1.0 数据库表设计
CREATE TABLE `bank_account` (`id` bigint DEFAULT NULL COMMENT '服务人员/机构id',`type` int DEFAULT NULL COMMENT '类型,2:服务人员,3:服务机构',`name` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci DEFAULT NULL COMMENT '户名',`bank_name` varchar(50) DEFAULT NULL COMMENT '银行名称',`province` varchar(50) DEFAULT NULL COMMENT '省',`city` varchar(50) DEFAULT NULL COMMENT '市',`district` varchar(50) DEFAULT NULL COMMENT '区',`branch` varchar(50) DEFAULT NULL COMMENT '网点',`account` varchar(50) DEFAULT NULL COMMENT '银行账号',`account_certification` varchar(100) DEFAULT NULL COMMENT '开户证明',`create_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',`update_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间'
)
2.1.1.1 接口分析

接口路径:POST/customer/agency/bank-account
请求类型:application/json
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2.1.1.2 接口开发
Controller层开发
@RestController("agencyBankAccountController")
@RequestMapping("/agency/bank-account")
@Api(tags = "机构端 - 银行账户信息相关接口")
public class BankAccountController {@Autowiredprivate IBankAccountService bankAccountService;@PostMapping@ApiOperation("新增或更新银行账号信息")public void queryByServeProviderId(@RequestBody BankAccountUpsertReqDTO bankAccountUpsertReqDTO){CurrentUserInfo currentUserInfo = UserContext.currentUser();bankAccountUpsertReqDTO.setId(currentUserInfo.getId());bankAccountUpsertReqDTO.setType(currentUserInfo.getUserType());bankAccountService.queryAndUpdate(bankAccountUpsertReqDTO);}
}
Service层开发
public class BankAccountServiceImpl extends ServiceImpl<BankAccountMapper, BankAccount> implements IBankAccountService {/*** 更新或新增银行账户* @param bankAccountUpsertReqDTO*/@Overridepublic void queryAndUpdate(BankAccountUpsertReqDTO bankAccountUpsertReqDTO) {BankAccount bankAccount = BeanUtil.toBean(bankAccountUpsertReqDTO, BankAccount.class);super.saveOrUpdate(bankAccount);}
}
2.1.1.3 功能测试

点击账户设置,之后填好信息:
在这里插入图片描述
点击提交:
在这里插入图片描述
在这里插入图片描述
功能测试成功

2.1.2 查询银行账号信息

2.1.2.1 接口分析

接口路径:GET/customer/worker/bank-account/currentUserBankAccount
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2.1.2.2 接口开发
Controller层开发
    @GetMapping("/currentUserBankAccount")@ApiOperation("获取当前用户银行账号")public BankAccountResDTO queryCurrentUserBankAccount() {BankAccount bankAccount = bankAccountService.getById(UserContext.currentUserId());return BeanUtil.toBean(bankAccount, BankAccountResDTO.class);}

2.2 服务端设置银行账号

2.2.1 服务端新增/更新银行账户

2.2.1.1 接口分析

接口路径:POST/customer/worker/bank-account
请求类型:application/json
在这里插入图片描述
在这里插入图片描述

2.2.1.2 接口开发
Controller层开发
@RestController("workerBankAccountController")
@RequestMapping("/worker/bank-account")
@Api(tags = "服务端 - 银行账户信息相关接口")
public class BankAccountController {@Autowiredprivate IBankAccountService bankAccountService;@PostMapping@ApiOperation("新增或更新银行账号信息")public void queryByServeProviderId(@RequestBody BankAccountUpsertReqDTO bankAccountUpsertReqDTO){CurrentUserInfo currentUserInfo = UserContext.currentUser();bankAccountUpsertReqDTO.setId(currentUserInfo.getId());bankAccountUpsertReqDTO.setType(currentUserInfo.getUserType());bankAccountService.queryAndUpdate(bankAccountUpsertReqDTO);}
}
2.2.1.3 功能测试

填入银行账户信息:
在这里插入图片描述
点击提交:
在这里插入图片描述
在这里插入图片描述
功能测试成功

2.2.2 服务端获取当前用户银行账号接口

2.2.2.1 接口分析

接口路径:GET/customer/worker/bank-account/currentUserBankAccount
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2.2.2.2 接口开发
Controller层开发
    @PostMapping("/currentUserBankAccount")@ApiOperation("查询银行账户信息")public BankAccountResDTO queryCurrentUserBankAccount(){BankAccount bankAccount = bankAccountService.getById(UserContext.currentUserId());return BeanUtil.toBean(bankAccount,BankAccountResDTO.class);}
2.2.2.3 功能测试

当我们提交了一次服务端账户信息后,再次点击账户信息:
在这里插入图片描述
在这里插入图片描述
此功能处理成功

3.机构/服务人员认证模块

3.1 需求

3.1.1 服务端认证

当服务端的服务者注册成功账户,并登录后,会强制进行实名认证:
在这里插入图片描述
点击去认证:
在这里插入图片描述

3.1.2 机构端认证

当新注册的机构账户进行登录后:
在这里插入图片描述
再点击资质认证:
在这里插入图片描述

3.1.1 运营端审核认证

在这里插入图片描述

3.2 服务端提交认证

3.2.0 服务人员认证审核表设计

认证审核表:

CREATE TABLE `worker_certification_audit` (`id` bigint NOT NULL COMMENT '主键',`serve_provider_id` bigint DEFAULT NULL COMMENT '服务人员id',`name` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci DEFAULT NULL COMMENT '姓名',`id_card_no` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci DEFAULT NULL COMMENT '身份证号',`front_img` varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci DEFAULT NULL COMMENT '身份证正面',`back_img` varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci DEFAULT NULL COMMENT '身份证反面',`certification_material` varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci DEFAULT NULL COMMENT '证明资料',`audit_status` int DEFAULT '0' COMMENT '审核状态,0:未审核,1:已审核',`auditor_id` bigint DEFAULT NULL COMMENT '审核人id',`auditor_name` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci DEFAULT NULL COMMENT '审核人姓名',`audit_time` datetime DEFAULT NULL COMMENT '审核时间',`certification_status` int DEFAULT '1' COMMENT '认证状态,1:认证中,2:认证成功,3认证失败',`reject_reason` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci DEFAULT NULL COMMENT '驳回原因',`create_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',`update_time` datetime DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',PRIMARY KEY (`id`)
)

认证表:

create table worker_certification
(id                     bigint   default 0                 not null comment '服务人员id'primary key,name                   varchar(50)                        null comment '姓名',id_card_no             varchar(50)                        null comment '身份证号',front_img              varchar(100)                       null comment '身份证正面',back_img               varchar(100)                       null comment '身份证反面',certification_material varchar(100)                       null comment '证明资料',certification_status   int      default 0                 not null comment '认证状态,0:初始态,1:认证中,2:认证成功,3认证失败',certification_time     datetime                           null comment '认证时间',create_time            datetime default CURRENT_TIMESTAMP not null comment '创建时间',update_time            datetime default CURRENT_TIMESTAMP not null on update CURRENT_TIMESTAMP comment '更新时间'
)

3.2.1 接口设计

接口路径:POST/customer/worker/worker-certification-audit
请求数据类型: application/json
请求参数:
在这里插入图片描述
响应参数:
在这里插入图片描述

3.2.2 接口开发

Controller层开发
@RestController("workerWorkerCertificationAuditController")
@RequestMapping("/worker/worker-certification-audit")
@Api(tags = "服务端人员认证接口")
public class workerWorkerCertificationAuditController {@Autowiredprivate WorkCertificationAuditService workCertificationAuditService;@PostMapping@ApiOperation("提交认证申请")public void auditCertification(@RequestBody WorkerCertificationAuditResDTO workerCertificationAuditResDTO){workerCertificationAuditResDTO.setServeProviderId(UserContext.currentUserId());workCertificationAuditService.applyCertification(workerCertificationAuditResDTO);}
}
Service层开发
@Service
public class WorkCertificationAuditServiceImpl extends ServiceImpl<WorkerCertificationAuditMapper,WorkerCertificationAudit> implements WorkCertificationAuditService {@Autowiredprivate WorkerCertificationAuditMapper workerCertificationAuditMapper;@Autowiredprivate IWorkerCertificationService workerCertificationService;/*** 服务人员提交申请* @param workerCertificationAuditResDTO*/@Overridepublic void applyCertification(WorkerCertificationAuditResDTO workerCertificationAuditResDTO) {WorkerCertificationAudit workerCertificationAudit = BeanUtil.toBean(workerCertificationAuditResDTO, WorkerCertificationAudit.class);//默认未审核workerCertificationAudit.setAuditStatus(0);workerCertificationAuditMapper.insert(workerCertificationAudit);//查询认证状态并且将认证信息存入认证表中Long serveProviderId = workerCertificationAuditResDTO.getServeProviderId();WorkerCertification workerCertification = workerCertificationService.getById(serveProviderId);if(ObjectUtil.isNotEmpty(workerCertification)){//不为空说明之前审核过,只需要修改为审核中即可workerCertification.setCertificationStatus(CertificationStatusEnum.PROGRESSING.getStatus());workerCertificationService.updateById(workerCertification);}else{//为空则说明第一次审核,需要将审核信息存入表中WorkerCertification workerCertification1 = new WorkerCertification();workerCertification1.setCertificationStatus(CertificationStatusEnum.PROGRESSING.getStatus());workerCertification1.setId(serveProviderId);workerCertificationService.save(workerCertification1);}}
}

3.2.3 功能测试

服务端新建账号后点击实名:
在这里插入图片描述
点击提交:
在这里插入图片描述
在这里插入图片描述
功能完成

3.2.4 服务人员查询认证驳回原因设计

接口分析

接口路径:GET/customer/worker/worker-certification-audit/rejectReason
请求数据类型: application/x-www-form-urlencoded
请求参数:

响应参数:
[图片]

Controller层
    @GetMapping("/rejectReason")@ApiOperation("服务人员查询驳回原因")public RejectReasonResDTO queryRejectReason(){return workCertificationAuditService.queryRejectReason();}
Service层
    /*** 查询驳回理由* @return*/@Overridepublic RejectReasonResDTO queryRejectReason() {LambdaQueryWrapper<WorkerCertificationAudit> queryWrapper = Wrappers.lambdaQuery(WorkerCertificationAudit.class);queryWrapper.eq(WorkerCertificationAudit::getServeProviderId, UserContext.currentUserId()).orderByDesc(WorkerCertificationAudit::getCreateTime).last("limit 1");WorkerCertificationAudit workerCertificationAudit = workerCertificationAuditMapper.selectOne(queryWrapper);return new RejectReasonResDTO(workerCertificationAudit.getRejectReason());}

3.3 机构端提交认证

3.3.1 表设计

认证信息提交表:

CREATE TABLE `agency_certification_audit` (`id` bigint NOT NULL COMMENT '主键',`serve_provider_id` bigint DEFAULT NULL COMMENT '机构id',`name` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci DEFAULT NULL COMMENT '企业名称',`id_number` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci DEFAULT NULL COMMENT '统一社会信用代码',`legal_person_name` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci DEFAULT NULL COMMENT '法人姓名',`legal_person_id_card_no` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci DEFAULT NULL COMMENT '法人身份证号',`business_license` varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci DEFAULT NULL COMMENT '营业执照',`audit_status` int NOT NULL DEFAULT '0' COMMENT '审核状态,0:未审核,1:已审核',`auditor_id` bigint DEFAULT NULL COMMENT '审核人id',`auditor_name` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci DEFAULT NULL COMMENT '审核人姓名',`audit_time` datetime DEFAULT NULL COMMENT '审核时间',`certification_status` int NOT NULL DEFAULT '1' COMMENT '认证状态,1:认证中,2:认证成功,3:认证失败',`reject_reason` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci DEFAULT NULL COMMENT '驳回原因',`create_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',`update_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',PRIMARY KEY (`id`)
) 

认证信息表:

create table agency_certification
(id                      bigint auto_increment comment '机构id'primary key,name                    varchar(50)                        null comment '企业名称',id_number               varchar(50)                        null comment '统一社会信用代码',legal_person_name       varchar(50)                        null comment '法人姓名',legal_person_id_card_no varchar(50)                        null comment '法人身份证号',business_license        varchar(100)                       null comment '营业执照',certification_status    int      default 0                 not null comment '认证状态,0:初始态,1:认证中,2:认证成功,3认证失败',certification_time      datetime                           null comment '认证时间',create_time             datetime default CURRENT_TIMESTAMP not null comment '创建时间',update_time             datetime default CURRENT_TIMESTAMP not null on update CURRENT_TIMESTAMP comment '更新时间'
)

3.3.2 接口设计

接口路径:POST/customer/agency/agency-certification-audit
请求数据类型: application/json
在这里插入图片描述
在这里插入图片描述

3.3.3 接口开发

Controller层开发
@RestController("AgencyCertificationAuditController")
@RequestMapping("/agency/agency-certification-audit")
@Api("机构端认证审核相关接口")
public class AgencyCertificationAuditController {@Autowiredprivate IAgencyCertificationAuditService applyCertification;@PostMapping@ApiOperation("提交认证申请")public void auditCertification(@RequestBody AgencyCertificationAuditAddReqDTO agencyCertificationAuditAddReqDTO) {agencyCertificationAuditAddReqDTO.setServeProviderId(UserContext.currentUserId());applyCertification.applyCertification(agencyCertificationAuditAddReqDTO);}
}
Service层开发
    /*** 机构端提交认证申请* @param agencyCertificationAuditAddReqDTO*/@Overridepublic void applyCertification(AgencyCertificationAuditAddReqDTO agencyCertificationAuditAddReqDTO) {AgencyCertificationAudit agencyCertificationAudit = BeanUtil.toBean(agencyCertificationAuditAddReqDTO, AgencyCertificationAudit.class);baseMapper.insert(agencyCertificationAudit);//查询认证记录Long serveProviderId = agencyCertificationAudit.getServeProviderId();AgencyCertification agencyCertification = agencyCertificationService.getById(serveProviderId);if(ObjectUtil.isNotEmpty(agencyCertification)){//不是第一次认证agencyCertification.setCertificationStatus(CertificationStatusEnum.PROGRESSING.getStatus());agencyCertificationService.updateById(agencyCertification);}else{//是第一次认证AgencyCertification agencyCertification1 = new AgencyCertification();agencyCertification1.setCertificationStatus(CertificationStatusEnum.PROGRESSING.getStatus());agencyCertification1.setId(serveProviderId);agencyCertificationService.save(agencyCertification1);}}

3.3.4 功能测试

点击认证之后输入:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
功能开发完成

3.3.5 查询最新的驳回原因

接口分析

接口路径:GET/customer/agency/agency-certification-audit/rejectReason
请求数据类型: application/x-www-form-urlencoded
请求参数:

响应参数:
在这里插入图片描述

接口设计
Controller层
    @GetMapping("/rejectReason")@ApiOperation("查询最新的驳回原因")public RejectReasonResDTO queryCurrentUserLastRejectReason() {return applyCertification.queryCurrentUserLastRejectReason();}
Service层
    /*** 机构端查询最新驳回原因* @return*/@Overridepublic RejectReasonResDTO queryCurrentUserLastRejectReason() {LambdaQueryWrapper<AgencyCertificationAudit> queryWrapper = Wrappers.<AgencyCertificationAudit>lambdaQuery().eq(AgencyCertificationAudit::getServeProviderId, UserContext.currentUserId()).orderByDesc(AgencyCertificationAudit::getCreateTime).last("limit 1");AgencyCertificationAudit agencyCertificationAudit = baseMapper.selectOne(queryWrapper);return new RejectReasonResDTO(agencyCertificationAudit.getRejectReason());}

4.运营端审核认证模块

4.1 需求

运营端管理员需要在后台申请服务人员/机构的认证申请,可以驳回或者通过,驳回后,其可以继续申请,大概就是这样

4.1审核服务人员

4.1.1 分页查询审核信息

4.1.1.1 接口分析

接口路径:GET/customer/operation/worker-certification-audit/page
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

4.1.1.2 接口开发
Controller层
@RestController("operationWorkerCertificationAuditController")
@RequestMapping("/operation/worker-certification-audit")
@Api(tags = "运营端 - 服务端认证审核接口")
public class WorkerCertificationAuditController {@Autowiredprivate WorkCertificationAuditService workCertificationAuditService;@GetMapping("/page")@ApiOperation("服务人员认证信息分页查询")public PageResult<WorkerCertificationAuditResDTO> page(WorkerCertificationAuditPageQueryReqDTO workerCertificationAuditPageQueryReqDTO){return workCertificationAuditService.pageQuery(workerCertificationAuditPageQueryReqDTO);}
}
Service层
    /*** 服务人员认证的分页查询* @param workerCertificationAuditPageQueryReqDTO* @return*/@Overridepublic PageResult<WorkerCertificationAuditResDTO> pageQuery(WorkerCertificationAuditPageQueryReqDTO workerCertificationAuditPageQueryReqDTO) {Page<WorkerCertificationAudit> workerCertificationAuditPage = PageUtils.parsePageQuery(workerCertificationAuditPageQueryReqDTO, WorkerCertificationAudit.class);LambdaQueryWrapper<WorkerCertificationAudit> queryWrapper = Wrappers.lambdaQuery(WorkerCertificationAudit.class);queryWrapper.like(ObjectUtil.isNotEmpty(workerCertificationAuditPageQueryReqDTO.getName()), WorkerCertificationAudit::getName, workerCertificationAuditPageQueryReqDTO.getName()).eq(ObjectUtil.isNotEmpty(workerCertificationAuditPageQueryReqDTO.getIdCardNo()), WorkerCertificationAudit::getIdCardNo, workerCertificationAuditPageQueryReqDTO.getIdCardNo()).eq(ObjectUtil.isNotEmpty(workerCertificationAuditPageQueryReqDTO.getAuditStatus()), WorkerCertificationAudit::getAuditStatus, workerCertificationAuditPageQueryReqDTO.getAuditStatus()).eq(ObjectUtil.isNotEmpty(workerCertificationAuditPageQueryReqDTO.getCertificationStatus()), WorkerCertificationAudit::getCertificationStatus, workerCertificationAuditPageQueryReqDTO.getCertificationStatus());Page<WorkerCertificationAudit> workerCertificationAuditPage1 = baseMapper.selectPage(workerCertificationAuditPage, queryWrapper);return PageUtils.toPage(workerCertificationAuditPage1,WorkerCertificationAuditResDTO.class);}
4.1.1.3 功能测试

在这里插入图片描述

4.1.2 审核信息

4.1.2.1 接口分析

PUT/customer/operation/worker-certification-audit/audit/{id}
在这里插入图片描述
在这里插入图片描述

4.1.2.2 接口开发
Controller层
@PutMapping("/audit/{id}")@ApiOperation("审核服务人员认证信息")@ApiImplicitParams({@ApiImplicitParam(name = "id",value = "认证申请id",required = true,dataTypeClass = Long.class)})public void auditCertification(@PathVariable("id") Long id, CertificationAuditReqDTO certificationAuditReqDTO){workCertificationAuditService.auditCertification(id,certificationAuditReqDTO);}
Service层
    /*** 审核服务人员信息* @param id* @param certificationAuditReqDTO*/@Override@Transactionalpublic void auditCertification(Long id, CertificationAuditReqDTO certificationAuditReqDTO) {CurrentUserInfo currentUserInfo = UserContext.currentUser();LambdaUpdateWrapper<WorkerCertificationAudit> updateWrapper = Wrappers.lambdaUpdate(WorkerCertificationAudit.class);updateWrapper.eq(WorkerCertificationAudit::getId,id).set(WorkerCertificationAudit::getAuditStatus,1).set(WorkerCertificationAudit::getAuditorId,currentUserInfo.getId()).set(WorkerCertificationAudit::getAuditorName,currentUserInfo.getName()).set(WorkerCertificationAudit::getAuditTime, LocalDateTime.now()).set(WorkerCertificationAudit::getCertificationStatus,certificationAuditReqDTO.getCertificationStatus()).set(ObjectUtil.isNotEmpty(certificationAuditReqDTO.getRejectReason()),WorkerCertificationAudit::getRejectReason,certificationAuditReqDTO.getRejectReason());super.update(updateWrapper);}

4.2 审核机构人员

4.2.1 分页查询审核信息

2.2.1.1 接口分析

接口路径:GET/customer/operation/agency-certification-audit/page
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2.2.1.2 接口开发
Controller层
@RestController("operationAgencyCertificationAuditController")
@RequestMapping("/operation/agency-certification-audit")
@Api(tags = "运营端 - 机构认证审核相关接口")
public class AgencyCertificationAuditController {@Resourceprivate IAgencyCertificationAuditService agencyCertificationAuditService;@GetMapping("/page")@ApiOperation("机构认证审核信息分页查询")public PageResult<AgencyCertificationAuditResDTO> page(AgencyCertificationAuditPageQueryReqDTO agencyCertificationAuditPageQueryReqDTO) {return agencyCertificationAuditService.pageQuery(agencyCertificationAuditPageQueryReqDTO);}}
Service层
/*** 审核服务人员信息* @param id* @param certificationAuditReqDTO*/@Override@Transactionalpublic void auditCertification(Long id, CertificationAuditReqDTO certificationAuditReqDTO) {//1.更新申请记录CurrentUserInfo currentUserInfo = UserContext.currentUser();LambdaUpdateWrapper<WorkerCertificationAudit> updateWrapper = Wrappers.lambdaUpdate(WorkerCertificationAudit.class);updateWrapper.eq(WorkerCertificationAudit::getId,id).set(WorkerCertificationAudit::getAuditStatus,1).set(WorkerCertificationAudit::getAuditorId,currentUserInfo.getId()).set(WorkerCertificationAudit::getAuditorName,currentUserInfo.getName()).set(WorkerCertificationAudit::getAuditTime, LocalDateTime.now()).set(WorkerCertificationAudit::getCertificationStatus,certificationAuditReqDTO.getCertificationStatus()).set(ObjectUtil.isNotEmpty(certificationAuditReqDTO.getRejectReason()),WorkerCertificationAudit::getRejectReason,certificationAuditReqDTO.getRejectReason());super.update(updateWrapper);//2.更新认证信息,如果认证成功,需要将各认证属性也更新WorkerCertificationAudit workerCertificationAudit = baseMapper.selectById(id);WorkerCertificationUpdateDTO workerCertificationUpdateDTO = new WorkerCertificationUpdateDTO();workerCertificationUpdateDTO.setId(workerCertificationAudit.getServeProviderId());workerCertificationUpdateDTO.setCertificationStatus(certificationAuditReqDTO.getCertificationStatus());if (ObjectUtil.equal(CertificationStatusEnum.SUCCESS.getStatus(), certificationAuditReqDTO.getCertificationStatus())) {//如果认证成功,需要更新服务人员/机构名称serveProviderService.updateNameById(workerCertificationAudit.getServeProviderId(), workerCertificationAudit.getName());workerCertificationUpdateDTO.setName(workerCertificationAudit.getName());workerCertificationUpdateDTO.setIdCardNo(workerCertificationAudit.getIdCardNo());workerCertificationUpdateDTO.setFrontImg(workerCertificationAudit.getFrontImg());workerCertificationUpdateDTO.setBackImg(workerCertificationAudit.getBackImg());workerCertificationUpdateDTO.setCertificationMaterial(workerCertificationAudit.getCertificationMaterial());workerCertificationUpdateDTO.setCertificationTime(workerCertificationAudit.getAuditTime());}workerCertificationService.updateById(workerCertificationUpdateDTO);}

4.2.2 审核信息

4.2.2.1接口分析
4.2.2.2 接口开发
Controller层
    @PutMapping("/audit/{id}")@ApiOperation("审核机构认证信息")@ApiImplicitParams({@ApiImplicitParam(name = "id", value = "认证申请id", required = true, dataTypeClass = Long.class)})public void auditCertification(@PathVariable("id") Long id, CertificationAuditReqDTO certificationAuditReqDTO) {agencyCertificationAuditService.auditCertification(id, certificationAuditReqDTO);}
Service层
    /*** 审核机构认证信息* @param id* @param certificationAuditReqDTO*/@Overridepublic void auditCertification(Long id, CertificationAuditReqDTO certificationAuditReqDTO) {CurrentUserInfo currentUserInfo = UserContext.currentUser();LambdaUpdateWrapper<AgencyCertificationAudit> updateWrapper = Wrappers.<AgencyCertificationAudit>lambdaUpdate().eq(AgencyCertificationAudit::getId, id).set(AgencyCertificationAudit::getAuditStatus, EnableStatusEnum.ENABLE.getStatus()).set(AgencyCertificationAudit::getAuditorId, currentUserInfo.getId()).set(AgencyCertificationAudit::getAuditorName, currentUserInfo.getName()).set(AgencyCertificationAudit::getAuditTime, LocalDateTime.now()).set(AgencyCertificationAudit::getCertificationStatus, certificationAuditReqDTO.getCertificationStatus()).set(ObjectUtil.isNotEmpty(certificationAuditReqDTO.getRejectReason()), AgencyCertificationAudit::getRejectReason, certificationAuditReqDTO.getRejectReason());super.update(updateWrapper);//更新认证信息,如果认证成功,需要将各认证属性也更新AgencyCertificationAudit agencyCertificationAudit = baseMapper.selectById(id);AgencyCertificationUpdateDTO agencyCertificationUpdateDTO = new AgencyCertificationUpdateDTO();agencyCertificationUpdateDTO.setId(agencyCertificationAudit.getServeProviderId());agencyCertificationUpdateDTO.setCertificationStatus(certificationAuditReqDTO.getCertificationStatus());if (ObjectUtil.equal(CertificationStatusEnum.SUCCESS.getStatus(), certificationAuditReqDTO.getCertificationStatus())) {//如果认证成功,需要更新服务人员/机构名称serveProviderService.updateNameById(agencyCertificationAudit.getServeProviderId(), agencyCertificationAudit.getName());agencyCertificationUpdateDTO.setName(agencyCertificationAudit.getName());agencyCertificationUpdateDTO.setIdNumber(agencyCertificationAudit.getIdNumber());agencyCertificationUpdateDTO.setLegalPersonName(agencyCertificationAudit.getLegalPersonName());agencyCertificationUpdateDTO.setLegalPersonIdCardNo(agencyCertificationAudit.getLegalPersonIdCardNo());agencyCertificationUpdateDTO.setBusinessLicense(agencyCertificationAudit.getBusinessLicense());agencyCertificationUpdateDTO.setCertificationTime(agencyCertificationAudit.getAuditTime());}agencyCertificationService.updateByServeProviderId(agencyCertificationUpdateDTO);}

相关文章:

小熊家务帮day8-day9 客户管理模块2 (用户定位,地址簿,实名认证,银行卡信息上传等功能)

客户管理模块 0.用户定位功能0.1 需求0.2 接口分析0.3 接口开发Controller层开发Service层开发 1.我的地址簿功能1.1 需求1.2 数据库设计1.3 新增地址簿1.3.1 接口设计1.3.2 接口开发Controller层开发Service层开发测试功能 1.4 地址簿查询1.4.1 接口设计1.4.2 接口开发Control…...

amis 事件动作 和 行为按钮 常用用法

行为按钮 action &#xff08;仅是对click事件的处理&#xff09; actionType&#xff1a;这是 action 最核心的配置&#xff0c;来指定该 action 的作用类型&#xff0c;支持&#xff1a;ajax、link、url、drawer、dialog、confirm、cancel、prev、next、copy、close。 Butt…...

4K高刷显示器 - 蚂蚁电竞ANT27VU

可以毫不夸张地说&#xff0c;每一局游戏最终能够取得胜利&#xff0c;实际上都与一套极为优秀的电竞 PC 有着紧密的关联&#xff0c;因为其能够提供强大的性能支持与流畅的体验。同样的道理&#xff0c;一套优秀的电竞 PC 若想发挥出最佳的效果&#xff0c;那也都离不开一台能…...

图解支付系统的渠道路由设计

大家好&#xff0c;我是隐墨星辰&#xff0c;今天和大家聊聊渠道路由设计。 这篇文章主要讲清楚&#xff1a;渠道路由是什么&#xff0c;为什么需要渠道路由&#xff0c;渠道路由的几种形态&#xff0c;一个简洁而实用的基于规则的渠道路由设计。 注&#xff1a;有些公司称渠…...

Leecode---347:输出前k个高频元素(使用unordered_map)

题目&#xff1a; 给你一个整数数组 nums 和一个整数 k &#xff0c;请你返回其中出现频率前 k 高的元素。你可以按 任意顺序 返回答案。 思路&#xff1a; 三步&#xff1a; 1、用map来记录每个元素出现的次数 2、按map中的值大小排序&#xff0c;先让其有序&#xff0c;再逆…...

k8s ceph(静态pvc)

1.在 Kubernetes 节点上安装ceph-common 包。这个包包含了连接到 Ceph 集群所需的工具和库。可以使用以下命令在每个节点上安装&#xff1a; sudo apt-get install ceph-common2.在 Kubernetes 中创建一个 Secret 对象&#xff0c;用于存储连接到 Ceph 集群所需的密钥和配置信息…...

Qt QScript 之 C++/JavaScript相互调用

文章目录 Qt Script什么是ECMAScriptQt 中JavaScriptclass 详解Basic UsageQObject对脚本引擎可用使用信号槽connect 三种模式访问属性, 子对象使c++对象可用于用Qt Script编写的脚本C++ 类成员函数可用于脚本C++ 类属性可用于脚本对脚本中的c++对象信号的反应函数对象和本机函…...

可能会引起空指针

PreparedStatement preparedStatement null; preparedStatement conn.prepareStatement(sql); 如果直接下面这个可能会赋值给空指针 因为要在try{}和catch{}里面都用,所以要定义在try外面为null //如果只是测试,可以PreparedStatement preparedStatement conn.prepareSta…...

Linux input输入子系统

Linux input 更多内容可以查看我的github Linux输入子系统框架 Linux输入子系统由驱动层、核心层、事件处理层三部分组成。 驱动层&#xff1a;输入设备的具体驱动程序&#xff0c;负责与具体的硬件设备进行交互&#xff0c;并将底层的硬件输入转化为统一的事件形式&#xff…...

dataworks调度参数

概述 调度参数是DataWorks任务调度时使用的参数&#xff0c;调度参数会根据任务调度的业务时间及调度参数的取值格式自动替换取值&#xff0c;实现在任务调度时间内参数的动态取值。 调度参数通过赋值方式分为自定义参数&#xff08;推荐&#xff09;和系统内置变量两大类。 …...

JavaScript第五讲:事件,条件循环语句,错误处理

前言 在编程的世界里&#xff0c;事件、条件和循环语句、以及错误处理是构建任何复杂程序或应用的基石。无论是开发一个简单的网页交互&#xff0c;还是构建一个庞大的企业级系统&#xff0c;这些基础概念都扮演着至关重要的角色。今天星途将通过这篇文章&#xff0c;分别深入…...

BrainGPT1,一个帮你b站点歌放视频的多模态多轮对话模型

BrainGPT1&#xff0c;一个帮你b站点歌放视频的多模态多轮对话模型 返回论文目录 项目地址 模型地址 作者&#xff1a;华东师范大学&#xff0c;计算机科学与技术学院&#xff0c;智能教育研究院的小怪兽会微笑。 介绍 BrainGPT1是一个工具调用多轮对话模型&#xff0c;与G…...

带DSP音效处理D类数字功放TAS5805M中文资料

国产替代D类数字功放中文资料访问下方链接 ACM8628 241W立体声182W单通道数字功放中文寄存器表 内置DSP多种音频处理效果ACM8628M-241W立体声或182W单通道数字功放 1 特性 具有增强处理能力和低功率损耗的 TAS5805M 23W、无电感器、数字输入、立体声、闭环 D 类音频放大器 …...

java中BigDecimal的比较

BigDecimal是Java中的一个类&#xff0c;位于java.math包中&#xff0c;它提供了任意精度的有符号十进制数字的表示&#xff0c;以及对这些数字进行算术运算的方法 BigDecimal的主要用途包括&#xff1a; 1.金融计算&#xff1a;金融领域对数值的精度要求非常高&#xff0c;使…...

张大哥笔记:你卖什么,就反着来卖

普通人打工的一生&#xff0c;就是努力工作&#xff0c;买房&#xff0c;买车&#xff0c;送孩子上好的学校&#xff0c;为了孩子不要输在起跑线上&#xff0c;拼命报各种补习班等&#xff0c;这些都是普通人认为的主流价值观文化&#xff0c;也造就了一批批的赚钱机器&#xf…...

Nginx(openresty) 开启gzip压缩功能 提高web网站传输速度

1 开启nginx gzip压缩后&#xff0c;网页的图片&#xff0c;css、js等静态资源的大小会减少&#xff0c;节约带宽&#xff0c;提高传输效率&#xff0c;给用户快的体验,给用户更好的体验. 2 安装 #centos 8.5 yum install gzip 3 配置 #建议统一配置在http段 vim /usr/loca…...

nn.Embedding使用

nn.Embedding使用 Embedding.weight会从标准正态分布中初始化成大小为&#xff08;num_embeddings, embedding_dim&#xff09;的矩阵 PE矩阵的作用就是替换这个标准正态分布 input中的标号表示从矩阵对应行获取权重来表示单词 # 1.设置embedding结构 max_seq_len 1000 # 句…...

Qt6 mathgl数学函数绘图

1. 程序环境 Qt6.5.1, mingw11.2mathgl 8.0.1: https://sourceforge.net/projects/mathgl/,推荐下载mathgl-8.0.LGPL-mingw.win64.7z,Windows环境尝试自己编译mathgl会缺失一些库,补充完整也可以自己编译,路径"D:\mathgl-8.0.LGPL-mingw.win64\bin"添加至系统环境…...

Nginx配置文件中静态资源文件禁止通过目录查看

Nginx配置文件中静态资源文件禁止通过目录查看 nginx作为文件服务器访问静态资源时&#xff0c;默认是可以通过目录路径查看该目录下的所有文件的&#xff0c;这样会被检查出漏洞&#xff0c;容易造成静态资源泄露。 方案 location /images {autoindex off;autoindex_exact_…...

力扣Hot100-有效的括号(栈stack)

给定一个只包括 (&#xff0c;)&#xff0c;{&#xff0c;}&#xff0c;[&#xff0c;] 的字符串 s &#xff0c;判断字符串是否有效。 有效字符串需满足&#xff1a; 左括号必须用相同类型的右括号闭合。左括号必须以正确的顺序闭合。每个右括号都有一个对应的相同类型的左括…...

XML Group端口详解

在XML数据映射过程中&#xff0c;经常需要对数据进行分组聚合操作。例如&#xff0c;当处理包含多个物料明细的XML文件时&#xff0c;可能需要将相同物料号的明细归为一组&#xff0c;或对相同物料号的数量进行求和计算。传统实现方式通常需要编写脚本代码&#xff0c;增加了开…...

Docker 运行 Kafka 带 SASL 认证教程

Docker 运行 Kafka 带 SASL 认证教程 Docker 运行 Kafka 带 SASL 认证教程一、说明二、环境准备三、编写 Docker Compose 和 jaas文件docker-compose.yml代码说明&#xff1a;server_jaas.conf 四、启动服务五、验证服务六、连接kafka服务七、总结 Docker 运行 Kafka 带 SASL 认…...

Go 语言接口详解

Go 语言接口详解 核心概念 接口定义 在 Go 语言中&#xff0c;接口是一种抽象类型&#xff0c;它定义了一组方法的集合&#xff1a; // 定义接口 type Shape interface {Area() float64Perimeter() float64 } 接口实现 Go 接口的实现是隐式的&#xff1a; // 矩形结构体…...

学习STC51单片机31(芯片为STC89C52RCRC)OLED显示屏1

每日一言 生活的美好&#xff0c;总是藏在那些你咬牙坚持的日子里。 硬件&#xff1a;OLED 以后要用到OLED的时候找到这个文件 OLED的设备地址 SSD1306"SSD" 是品牌缩写&#xff0c;"1306" 是产品编号。 驱动 OLED 屏幕的 IIC 总线数据传输格式 示意图 …...

EtherNet/IP转DeviceNet协议网关详解

一&#xff0c;设备主要功能 疆鸿智能JH-DVN-EIP本产品是自主研发的一款EtherNet/IP从站功能的通讯网关。该产品主要功能是连接DeviceNet总线和EtherNet/IP网络&#xff0c;本网关连接到EtherNet/IP总线中做为从站使用&#xff0c;连接到DeviceNet总线中做为从站使用。 在自动…...

算法:模拟

1.替换所有的问号 1576. 替换所有的问号 - 力扣&#xff08;LeetCode&#xff09; ​遍历字符串​&#xff1a;通过外层循环逐一检查每个字符。​遇到 ? 时处理​&#xff1a; 内层循环遍历小写字母&#xff08;a 到 z&#xff09;。对每个字母检查是否满足&#xff1a; ​与…...

LINUX 69 FTP 客服管理系统 man 5 /etc/vsftpd/vsftpd.conf

FTP 客服管理系统 实现kefu123登录&#xff0c;不允许匿名访问&#xff0c;kefu只能访问/data/kefu目录&#xff0c;不能查看其他目录 创建账号密码 useradd kefu echo 123|passwd -stdin kefu [rootcode caozx26420]# echo 123|passwd --stdin kefu 更改用户 kefu 的密码…...

MySQL 部分重点知识篇

一、数据库对象 1. 主键 定义 &#xff1a;主键是用于唯一标识表中每一行记录的字段或字段组合。它具有唯一性和非空性特点。 作用 &#xff1a;确保数据的完整性&#xff0c;便于数据的查询和管理。 示例 &#xff1a;在学生信息表中&#xff0c;学号可以作为主键&#xff…...

Linux部署私有文件管理系统MinIO

最近需要用到一个文件管理服务&#xff0c;但是又不想花钱&#xff0c;所以就想着自己搭建一个&#xff0c;刚好我们用的一个开源框架已经集成了MinIO&#xff0c;所以就选了这个 我这边对文件服务性能要求不是太高&#xff0c;单机版就可以 安装非常简单&#xff0c;几个命令就…...

DBLP数据库是什么?

DBLP&#xff08;Digital Bibliography & Library Project&#xff09;Computer Science Bibliography是全球著名的计算机科学出版物的开放书目数据库。DBLP所收录的期刊和会议论文质量较高&#xff0c;数据库文献更新速度很快&#xff0c;很好地反映了国际计算机科学学术研…...