务工者-用户1.0

This commit is contained in:
2025-02-17 09:17:05 +08:00
parent d27512baa4
commit 08e242ce85
16 changed files with 1318 additions and 2 deletions

View File

@ -0,0 +1,64 @@
package com.ruoyi.wgz.bo;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import java.time.LocalDateTime;
import java.time.LocalTime;
import java.time.LocalDate;
import lombok.EqualsAndHashCode;
import java.util.Date;
import com.ruoyi.common.core.domain.BaseEntity;
/**
* APP务工者分页查询对象 wgz_user
*
* @author ruoyi
* @date 2025-02-14
*/
@Data
@EqualsAndHashCode(callSuper = true)
@ApiModel("APP务工者分页查询对象")
public class WgzUserQueryBo extends BaseEntity {
/** 分页大小 */
@ApiModelProperty("分页大小")
private Integer pageSize;
/** 当前页数 */
@ApiModelProperty("当前页数")
private Integer pageNum;
/** 排序列 */
@ApiModelProperty("排序列")
private String orderByColumn;
/** 排序的方向desc或者asc */
@ApiModelProperty(value = "排序的方向", example = "asc,desc")
private String isAsc;
/** 唯一标识 */
@ApiModelProperty("唯一标识")
private Long userId;
/** 姓名 */
@ApiModelProperty("姓名")
private String username;
/** 出生日期 */
@ApiModelProperty("出生日期")
private String birthdate;
/** 身份证号码 */
@ApiModelProperty("身份证号码")
private String identityCard;
/** 联系电话 */
@ApiModelProperty("联系电话")
private String phone;
/** 银行卡号 */
@ApiModelProperty("银行卡号")
private String cardNo;
/** 帐号状态0正常 1停用 */
@ApiModelProperty("帐号状态0正常 1停用")
private String status;
}

View File

@ -0,0 +1,24 @@
package com.ruoyi.wgz.bo.req;
import com.ruoyi.common.core.domain.BaseEntity;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import lombok.EqualsAndHashCode;
import javax.validation.constraints.Pattern;
@Data
@EqualsAndHashCode(callSuper = true)
@ApiModel("务工者APP注册账号对象")
public class WgzAppUserLongInReq extends BaseEntity {
@ApiModelProperty("联系电话")
@Pattern(regexp = "^1[3-9]\\d{9}$", message = "手机号码格式不正确")
private String phone;
@ApiModelProperty("密码")
private String password;
@ApiModelProperty("验证码")
private String verificationCode;
}

View File

@ -0,0 +1,22 @@
package com.ruoyi.wgz.bo.req;
import com.ruoyi.common.core.domain.BaseEntity;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import lombok.EqualsAndHashCode;
import javax.validation.constraints.Pattern;
@Data
@EqualsAndHashCode(callSuper = true)
@ApiModel("务工者APP注册账号对象")
public class WgzAppUserRegisterReq extends BaseEntity {
@ApiModelProperty("联系电话")
@Pattern(regexp = "^1[3-9]\\d{9}$", message = "手机号码格式不正确")
private String phone;
/** 密码 */
@ApiModelProperty("密码")
private String password;
}

View File

@ -0,0 +1,4 @@
package com.ruoyi.wgz.bo.res;
public class WgzAppUserLongInRes {
}

View File

@ -0,0 +1,27 @@
package com.ruoyi.wgz.common;
import cn.hutool.core.lang.Snowflake;
import cn.hutool.core.util.IdUtil;
/**
* 雪花 ID 生成工具类
*/
public class SnowflakeIdUtil {
// 定义静态的 Snowflake 实例
private static final Snowflake snowflake;
// 静态代码块,在类加载时初始化 Snowflake 实例
static {
// 这里的数据中心 ID 和机器 ID 可以根据实际情况进行配置
// 此处假设数据中心 ID 为 1机器 ID 为 1
snowflake = IdUtil.createSnowflake(1, 1);
}
/**
* 生成雪花 ID 的静态方法
* @return 生成的雪花 ID
*/
public static long generateId() {
return snowflake.nextId();
}
}

View File

@ -0,0 +1,159 @@
package com.ruoyi.wgz.domain;
import com.ruoyi.common.annotation.Excel;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import com.baomidou.mybatisplus.annotation.*;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.experimental.Accessors;
import java.io.Serializable;
import java.util.Date;
import java.math.BigDecimal;
import java.time.LocalDateTime;
import java.time.LocalTime;
import java.time.LocalDate;
/**
* APP务工者对象 wgz_user
*
* @author ruoyi
* @date 2025-02-14
*/
@Data
@NoArgsConstructor
@Accessors(chain = true)
@TableName("wgz_user")
@ApiModel("APP务工者视图对象")
public class WgzUser implements Serializable {
private static final long serialVersionUID=1L;
/** 主键ID */
@ApiModelProperty("主键ID")
@TableId(value = "id")
private String id;
/** 唯一标识 */
@Excel(name = "唯一标识")
@ApiModelProperty("唯一标识")
private Long userId;
/** 姓名 */
@Excel(name = "姓名")
@ApiModelProperty("姓名")
private String username;
/** 性别 */
@Excel(name = "性别")
@ApiModelProperty("性别")
private String gender;
/** 民族 */
@Excel(name = "民族")
@ApiModelProperty("民族")
private String nation;
/** 出生日期 */
@Excel(name = "出生日期")
@ApiModelProperty("出生日期")
private String birthdate;
/** 身份证号码 */
@Excel(name = "身份证号码")
@ApiModelProperty("身份证号码")
private String identityCard;
/** 所在区域 */
@Excel(name = "所在区域")
@ApiModelProperty("所在区域")
private String area;
/** 地址 */
@Excel(name = "地址")
@ApiModelProperty("地址")
private String site;
/** 联系电话 */
@Excel(name = "联系电话")
@ApiModelProperty("联系电话")
private String phone;
/** 银行 */
@Excel(name = "银行")
@ApiModelProperty("银行")
private String bank;
/** 银行卡号 */
@Excel(name = "银行卡号")
@ApiModelProperty("银行卡号")
private String cardNo;
/** 头像地址 */
@Excel(name = "头像地址")
@ApiModelProperty("头像地址")
private String avatarName;
/** 密码 */
@Excel(name = "密码")
@ApiModelProperty("密码")
private String password;
/** 身份证正面图路径 */
@Excel(name = "身份证正面图路径")
@ApiModelProperty("身份证正面图路径")
private String frontPath;
/** 身份证反面图路径 */
@Excel(name = "身份证反面图路径")
@ApiModelProperty("身份证反面图路径")
private String reverseSidePath;
/** 银行卡图路径 */
@Excel(name = "银行卡图路径")
@ApiModelProperty("银行卡图路径")
private String bankCardPath;
/** 帐号状态0正常 1停用 */
@Excel(name = "帐号状态" , readConverterExp = "0=正常,1=停用")
@ApiModelProperty("帐号状态0正常 1停用")
private String status;
/** 删除标志0代表存在 2代表删除 */
@Excel(name = "删除标志" , readConverterExp = "0=代表存在,2=代表删除")
@ApiModelProperty("删除标志0代表存在 2代表删除")
@TableLogic
private String delFlag;
/** 创建者 */
@Excel(name = "创建者")
@ApiModelProperty("创建者")
@TableField(fill = FieldFill.INSERT)
private String createBy;
/** 创建时间 */
@Excel(name = "创建时间" , width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss")
@ApiModelProperty("创建时间")
@TableField(fill = FieldFill.INSERT)
private LocalDateTime createTime;
/** 更新者 */
@Excel(name = "更新者")
@ApiModelProperty("更新者")
@TableField(fill = FieldFill.INSERT_UPDATE)
private String updateBy;
/** 更新时间 */
@Excel(name = "更新时间" , width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss")
@ApiModelProperty("更新时间")
@TableField(fill = FieldFill.INSERT_UPDATE)
private LocalDateTime updateTime;
/** 备注 */
@Excel(name = "备注")
@ApiModelProperty("备注")
private String remark;
}

View File

@ -0,0 +1,18 @@
package com.ruoyi.wgz.mapper;
import com.ruoyi.wgz.domain.WgzUser;
import com.ruoyi.common.core.mybatisplus.core.BaseMapperPlus;
import com.ruoyi.common.core.mybatisplus.cache.MybatisPlusRedisCache;
import org.apache.ibatis.annotations.CacheNamespace;
/**
* APP务工者Mapper接口
*
* @author ruoyi
* @date 2025-02-14
*/
// 如使需切换数据源 请勿使用缓存 会造成数据不一致现象
@CacheNamespace(implementation = MybatisPlusRedisCache.class, eviction = MybatisPlusRedisCache.class)
public interface WgzUserMapper extends BaseMapperPlus<WgzUser> {
}

View File

@ -0,0 +1,75 @@
package com.ruoyi.wgz.service;
import com.ruoyi.wgz.bo.req.WgzAppUserLongInReq;
import com.ruoyi.wgz.bo.req.WgzAppUserRegisterReq;
import com.ruoyi.wgz.bo.res.WgzAppUserLongInRes;
import com.ruoyi.wgz.domain.WgzUser;
import com.ruoyi.wgz.bo.WgzUserQueryBo;
import com.ruoyi.common.core.mybatisplus.core.IServicePlus;
import com.ruoyi.common.core.page.TableDataInfo;
import java.util.Collection;
import java.util.List;
/**
* APP务工者Service接口
*
* @author ruoyi
* @date 2025-02-14
*/
public interface IWgzUserService extends IServicePlus<WgzUser> {
/**
* 查询单个
* @return
*/
WgzUser queryById(String id);
/**
* 查询列表
*/
TableDataInfo<WgzUser> queryPageList(WgzUserQueryBo bo);
/**
* 查询列表
*/
List<WgzUser> queryList(WgzUserQueryBo bo);
/**
* 根据新增业务对象插入APP务工者
* @param bo APP务工者新增业务对象
* @return
*/
Boolean insert(WgzUser bo);
/**
* 根据编辑业务对象修改APP务工者
* @param bo APP务工者编辑业务对象
* @return
*/
Boolean update(WgzUser bo);
/**
* 校验并删除数据
* @param ids 主键集合
* @param isValid 是否校验,true-删除前校验,false-不校验
* @return
*/
Boolean deleteWithValidByIds(Collection<String> ids, Boolean isValid);
/**
* 务工者APP相关
* =================================================================================================================
* =================================================================================================================
* =================================================================================================================
*/
/**
* 务工者APP注册账号
* @param bo APP务工者注册业务对象
* @return bool
*/
Boolean userRegister(WgzAppUserRegisterReq bo);
WgzAppUserLongInRes userLongIn(WgzAppUserLongInReq req);
}

View File

@ -0,0 +1,165 @@
package com.ruoyi.wgz.service.impl;
import cn.hutool.core.bean.BeanUtil;
import cn.hutool.core.util.IdUtil;
import cn.hutool.core.util.StrUtil;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.ruoyi.common.constant.Constants;
import com.ruoyi.common.core.domain.model.LoginUser;
import com.ruoyi.common.core.mybatisplus.core.ServicePlusImpl;
import com.ruoyi.common.core.page.TableDataInfo;
import com.ruoyi.common.utils.PageUtils;
import com.ruoyi.common.utils.SecurityUtils;
import com.ruoyi.framework.web.service.TokenService;
import com.ruoyi.wgz.bo.WgzUserQueryBo;
import com.ruoyi.wgz.bo.req.WgzAppUserLongInReq;
import com.ruoyi.wgz.bo.req.WgzAppUserRegisterReq;
import com.ruoyi.wgz.bo.res.WgzAppUserLongInRes;
import com.ruoyi.wgz.common.SnowflakeIdUtil;
import com.ruoyi.wgz.domain.WgzUser;
import com.ruoyi.wgz.mapper.WgzUserMapper;
import com.ruoyi.wgz.service.IWgzUserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.util.Collection;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
/**
* APP务工者Service业务层处理
*
* @author ruoyi
* @date 2025-02-14
*/
@Service
public class WgzUserServiceImpl extends ServicePlusImpl<WgzUserMapper, WgzUser> implements IWgzUserService {
@Autowired
private TokenService tokenService;
@Override
public WgzUser queryById(String id){
return getById(id);
}
@Override
public TableDataInfo<WgzUser> queryPageList(WgzUserQueryBo bo) {
Page<WgzUser> result = page(PageUtils.buildPage(), buildQueryWrapper(bo));
return PageUtils.buildDataInfo(result);
}
@Override
public List<WgzUser> queryList(WgzUserQueryBo bo) {
return list(buildQueryWrapper(bo));
}
private LambdaQueryWrapper<WgzUser> buildQueryWrapper(WgzUserQueryBo bo) {
Map<String, Object> params = bo.getParams();
LambdaQueryWrapper<WgzUser> lqw = Wrappers.lambdaQuery();
lqw.eq(bo.getUserId() != null, WgzUser::getUserId, bo.getUserId());
lqw.like(StrUtil.isNotBlank(bo.getUsername()), WgzUser::getUsername, bo.getUsername());
lqw.eq(StrUtil.isNotBlank(bo.getBirthdate()), WgzUser::getBirthdate, bo.getBirthdate());
lqw.eq(StrUtil.isNotBlank(bo.getIdentityCard()), WgzUser::getIdentityCard, bo.getIdentityCard());
lqw.eq(StrUtil.isNotBlank(bo.getPhone()), WgzUser::getPhone, bo.getPhone());
lqw.eq(StrUtil.isNotBlank(bo.getCardNo()), WgzUser::getCardNo, bo.getCardNo());
lqw.eq(StrUtil.isNotBlank(bo.getStatus()), WgzUser::getStatus, bo.getStatus());
return lqw;
}
@Override
public Boolean insert(WgzUser bo) {
WgzUser add = BeanUtil.toBean(bo, WgzUser.class);
validEntityBeforeSave(add);
return save(add);
}
@Override
public Boolean update(WgzUser bo) {
WgzUser update = BeanUtil.toBean(bo, WgzUser.class);
validEntityBeforeSave(update);
return updateById(update);
}
/**
* 保存前的数据校验
*
* @param entity 实体类数据
*/
private void validEntityBeforeSave(WgzUser entity){
//TODO 做一些数据校验,如唯一约束
}
@Override
public Boolean deleteWithValidByIds(Collection<String> ids, Boolean isValid) {
if(isValid){
//TODO 做一些业务上的校验,判断是否需要校验
}
return removeByIds(ids);
}
/**
* 务工者APP相关
* =================================================================================================================
* =================================================================================================================
* =================================================================================================================
*/
@Override
public Boolean userRegister(WgzAppUserRegisterReq bo) {
WgzUser wgzUser = new WgzUser();
//1、查询手机号是否存在
Integer count = baseMapper.selectCount(
new LambdaQueryWrapper<WgzUser>().
eq(WgzUser::getPhone, wgzUser.getPhone())
);
if (count>0){
throw new RuntimeException("当前手机号已存在!");
}
//2、组装数据 BeanUtils.copyProperties(bo,wgzUser);
wgzUser.setPhone(bo.getPhone());
wgzUser.setUserId(SnowflakeIdUtil.generateId());
wgzUser.setPassword(SecurityUtils.encryptPassword(wgzUser.getPassword()));
//3、保存数据
return baseMapper.insert(wgzUser) > 0;
}
@Override
public WgzAppUserLongInRes userLongIn(WgzAppUserLongInReq req) {
//1、验证验证码是否正确展示忽略
//2、验证账号是否存在
WgzUser wgzUser = baseMapper.selectOne(new LambdaQueryWrapper<WgzUser>().eq(WgzUser::getPhone, req.getPhone()));
if (wgzUser == null){
throw new RuntimeException("账号不存在!");
}
//3、验证密码是否正确
if (!SecurityUtils.matchesPassword(req.getPassword(),wgzUser.getPassword())){
throw new RuntimeException("密码错误!");
}
//4、创建token返回wgzUser
String token = tokenService.createToken(wgzUser);
WgzAppUserLongInRes res = new WgzAppUserLongInRes();
res.setToken(token);
return null;
}
public String createToken(WgzUser wu) {
String token = IdUtil.fastUUID();
loginUser.setToken(token);
setUserAgent(loginUser);
refreshToken(loginUser);
Map<String, Object> claims = new HashMap<>();
claims.put(Constants.LOGIN_USER_KEY, token);
return createToken(claims);
}
}

View File

@ -0,0 +1,35 @@
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.ruoyi.wgz.mapper.WgzUserMapper">
<resultMap type="com.ruoyi.wgz.domain.WgzUser" id="WgzUserResult">
<result property="id" column="id"/>
<result property="userId" column="user_id"/>
<result property="username" column="username"/>
<result property="gender" column="gender"/>
<result property="nation" column="nation"/>
<result property="birthdate" column="birthdate"/>
<result property="identityCard" column="identity_card"/>
<result property="area" column="area"/>
<result property="site" column="site"/>
<result property="phone" column="phone"/>
<result property="bank" column="bank"/>
<result property="cardNo" column="card_no"/>
<result property="avatarName" column="avatar_name"/>
<result property="password" column="password"/>
<result property="frontPath" column="front_path"/>
<result property="reverseSidePath" column="reverse_side_path"/>
<result property="bankCardPath" column="bank_card_path"/>
<result property="status" column="status"/>
<result property="delFlag" column="del_flag"/>
<result property="createBy" column="create_by"/>
<result property="createTime" column="create_time"/>
<result property="updateBy" column="update_by"/>
<result property="updateTime" column="update_time"/>
<result property="remark" column="remark"/>
</resultMap>
</mapper>