110
社区成员
发帖
与我相关
我的任务
分享在 application-dev.yml 文件中,有这么一段 swagger 相关的代码
#是否开启 swagger-ui
swagger:
enabled: true
title: 管理后台API
serverUrl: http://127.0.0.1:8000
version: 2.2
在 IDEA 中,用查找用法搜索 swagger ,可以找到一个叫 SecurityConfig 的类,类中有这么一段 swagger 相关的代码:
// swagger 文档
.antMatchers("/swagger-ui.html").permitAll()
.antMatchers("/swagger-resources/**").permitAll()
.antMatchers("/webjars/**").permitAll()
.antMatchers("/*/api-docs").permitAll()
.antMatchers("/v2/api-docs-ext").permitAll()
//.antMatchers("/api/wxmp/**").permitAll()
按照代码的设置,先启动项目,再访问 localhost:8000/swagger-ui.html,可成功访问,效果如图:

将 AuthController 类中的相关代码编辑为如下:
// 保存
redisUtils.set(uuid, result, expiration, TimeUnit.HOURS);
这样,验证码的失效时间就变为了 1 小时(原为 1 分钟)
在 swagger 页面,系统:系统授权接口 -> try it out -> excute
获取到的响应如下:
{
"uuid": "code-key050d4698495246588e6f46c50a87bf2c",
"img": ""
这其中,uuid 后面的字符串是 uuid,img 后面的字符串是验证码图片的 base64 码,需要转化成图像。
专门写一个 html 文件,用于将 base64 格式的图片编码转化为图像吗,代码如下:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
<meta name="renderer" content="webkit">
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no">
<title>我的前端练习</title>
</head>
<body>
<div>我的前端练习--二进制流图片及RSA加密</div>
<img src=""></img>
</body>
</html>
其中,src 是要转为图片的 base64 码,将刚刚的base64 码填进去,再打开 HTML 页面。
可得到验证码图片:

在刚刚的 html 文件中,添加 RSA 加密的相关脚本:
<!--引入jsencrypt.js-->
<script src="https://cdn.bootcss.com/jsencrypt/3.0.0-beta.1/jsencrypt.js"></script>
<script type="text/javascript">
//公钥
var PUBLIC_KEY = 'MFwwDQYJKoZIhvcNAQEBBQADSwAwSAJBANL378k3RiZHWx5AfJqdH9xRNBmD9wGD\n' +
'2iRe41HdTNF8RUhNnHit5NpMNtGL0NPTSSpPjjI1kJfVorRvaQerUgkCAwEAAQ=='
//私钥
var PRIVATE_KEY = ''
//使用公钥加密
var encrypt = new JSEncrypt();
//encrypt.setPrivateKey('-----BEGIN RSA PRIVATE KEY-----'+PRIVATE_KEY+'-----END RSA PRIVATE KEY-----');
encrypt.setPublicKey('-----BEGIN PUBLIC KEY-----' + PUBLIC_KEY + '-----END PUBLIC KEY-----');
var encrypted = encrypt.encrypt("123456");
console.log('加密前数据:%o', "");
console.log('加密后数据:%o', encrypted);
//使用私钥解密
//var decrypt = new JSEncrypt();
//decrypt.setPublicKey('-----BEGIN PUBLIC KEY-----' + PUBLIC_KEY + '-----END PUBLIC KEY-----');
//decrypt.setPrivateKey('-----BEGIN RSA PRIVATE KEY-----'+PRIVATE_KEY+'-----END RSA PRIVATE KEY-----');
//var uncrypted = decrypt.decrypt(encrypted);
//console.log('解密后数据:%o', uncrypted);
</script>
添加后,在加密前数据后面填写原本的密码。完成后启动浏览器,在控制台可以获取 RSA 加密后的密码。

打开登录接口,然后 try it out:

在 addUser 中,把后面的内容填上,如下:
{
"code": "4",
"password": "dqzr75SJUPUL0MERjBerOHRsRMJRaT27mNIwQL2igJ2G/EB1VdJZ83gesfmwHEBfGGlC51b8LuT6qbXpm81P8w==",
"username": "admin",
"uuid": "code-key050d4698495246588e6f46c50a87bf2c"
}
填写完毕后点击 excute,即可获得一个响应,内容如下:
{
"user": {
"id": 1,
"username": "admin",
"nickName": "管理员",
"sex": "男",
"avatar": null,
"email": "yshop@qq.com",
"phone": "18888888888",
"dept": "研发部",
"job": "全栈开发2",
"enabled": true,
"createTime": 1534986716000,
"roles": [
"YXUSER_SELECT",
"YXSTOREORDER_SELECT",
"YXSTORECOMBINATION_SELECT",
"YXSTORESECKILL_SELECT",
"YXSYSTEMUSERLEVEL_SELECT",
"YXSTORECATEGORY_SELECT",
"admin",
"YXSTOREBARGAIN_SELECT",
"YXSTOREPRODUCT_EDIT",
"YXSTORECOUPONISSUE_SELECT",
"storage:list",
"YXSTOREPRODUCT_CREATE",
"YXSTOREPRODUCTREPLY_SELECT",
"YXEXPRESS_SELECT",
"YXSTOREPRODUCT_SELECT",
"admin,menu:list,roles:list",
"YXSYSTEMUSERTASK_SELECT",
"timing:list",
"YXSTOREPRODUCT_DELETE",
"YXSTORECOUPON_SELECT"
]
},
"token": "Bearer eyJhbGciOiJIUzUxMiJ9.eyJzdWIiOiJhZG1pbiIsImF1dGgiOiJZWFVTRVJfU0VMRUNULFlYU1RPUkVPUkRFUl9TRUxFQ1QsWVhTVE9SRUNPTUJJTkFUSU9OX1NFTEVDVCxZWFNUT1JFU0VDS0lMTF9TRUxFQ1QsWVhTWVNURU1VU0VSTEVWRUxfU0VMRUNULFlYU1RPUkVDQVRFR09SWV9TRUxFQ1QsYWRtaW4sWVhTVE9SRUJBUkdBSU5fU0VMRUNULFlYU1RPUkVQUk9EVUNUX0VESVQsWVhTVE9SRUNPVVBPTklTU1VFX1NFTEVDVCxzdG9yYWdlOmxpc3QsWVhTVE9SRVBST0RVQ1RfQ1JFQVRFLFlYU1RPUkVQUk9EVUNUUkVQTFlfU0VMRUNULFlYRVhQUkVTU19TRUxFQ1QsWVhTVE9SRVBST0RVQ1RfU0VMRUNULGFkbWluLG1lbnU6bGlzdCxyb2xlczpsaXN0LFlYU1lTVEVNVVNFUlRBU0tfU0VMRUNULHRpbWluZzpsaXN0LFlYU1RPUkVQUk9EVUNUX0RFTEVURSxZWFNUT1JFQ09VUE9OX1NFTEVDVCIsImV4cCI6MTY0MjUxMjQ2OH0.TxPFNiFuQdETy4t5Ax5-j_9ZuB2TEn3vYinZOUgI3B7jHvfXotxETLqUJOB78o6n3Z1UrzOvYtuT1iTxn2mIxw"
}
说明登录成功,并且成功拿到了 token。
拿到 token 之后,就可以访问其他接口了,以获取用户信息为例。
进入 系统:系统授权接口,点击 try it out

在 Authorization 栏内填入刚刚的 token:

点击 excute,即可获得用户信息:

/*
Navicat MySQL Data Transfer
Source Server : localhost
Source Server Version : 80015
Source Host : 127.0.0.1:3306
Source Database : lab_mall_db
Target Server Type : MYSQL
Target Server Version : 80015
File Encoding : 65001
Date: 2022-01-18 20:26:43
*/
SET FOREIGN_KEY_CHECKS=0;
-- ----------------------------
-- Table structure for myinfo
-- ----------------------------
DROP TABLE IF EXISTS `xxminfo`;
CREATE TABLE `xxminfo` (
`id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '我的ID',
`name` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL COMMENT '我的姓名',
`remark` varchar(2000) DEFAULT NULL COMMENT '我的备注',
`create_time` datetime DEFAULT NULL COMMENT '创建时间',
`update_time` datetime DEFAULT NULL COMMENT '最后修改时间',
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci COMMENT='我的信息';
-- ----------------------------
-- Records of myinfo
-- ----------------------------
INSERT INTO `xxminfo` VALUES ('1', '嘘嘘喵', '备注1', '2022年1月19日15:37:52', '2022年1月19日15:37:55');
INSERT INTO `xxminfo` VALUES ('2', '嘘嘘喵22', '备注222', '2022年1月19日15:38:02', '2022年1月19日15:37:59');
项目直接沿用前面的项目,在 yshop-system 模块,/src/main/java/co.yixiang/modules 下创建文件夹 xxm ,以用作这次练习。
创建好三个文件夹:

domain :用于存放实体类
在 domain 文件夹下创建一个类 XxmInfo ,内容如下:
package co.yixiang.modules.xxm.domain;
import com.baomidou.mybatisplus.annotation.FieldFill;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import lombok.Data;
import javax.validation.constraints.NotBlank;
import java.io.Serializable;
import java.security.Timestamp;
/**
* @author: xxm
* @Date: 2022/1/19 16:49
* xxminfo 表对应的实体类
*/
@Data
@TableName("xxminfo")
public class XxmInfo implements Serializable {
/**
* ID
*/
@TableId
private long id;
/**
* 姓名
*/
@NotBlank(message = "姓名不能为空")
private String name;
/**
* 备注
*/
private String remark;
/**
* 创建日期(自动填充)
*/
@TableField(fill = FieldFill.INSERT)
private Timestamp createTime;
/**
* 最后修改日期(自动填充)
*/
@TableField(fill = FieldFill.INSERT_UPDATE)
private Timestamp updateTime;
}
在 dto 文件夹中创建一个新类:XxmInfoDto
答:
package co.yixiang.modules.xxm.service.dto;
import java.security.Timestamp;
/**
* @author: xxm
* @Date: 2022/1/20 10:56
* Dto类,一般用于与前端交互
*/
public class XxmInfoDto {
/**
* ID
*/
private long id;
/**
* 姓名
*/
private String name;
/**
* 备注
*/
private String remark;
/**
* 创建日期(自动填充)
*/
private Timestamp createTime;
/**
* 最后修改日期(自动填充)
*/
private Timestamp updateTime;
}
在 rest 文件夹下创建类 XxmInfoCrontroller。
内容如下:
package co.yixiang.modules.xxm.rest;
import co.yixiang.logging.aop.log.Log;
import co.yixiang.modules.xxm.service.XxmInfoService;
import co.yixiang.modules.xxm.service.dto.XxmInfoQueryCriteria;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
import org.springframework.security.access.prepost.PreAuthorize;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
/**
* @author: xxm
* @Date: 2022/1/19 18:52
* xxminfo 接口
*/
@Api(tags = "xxm:用户信息")
@RestController
@RequestMapping("/api/xxminfo")
public class XxmInfoController {
private final XxmInfoService xxmInfoService;
public XxmInfoController(XxmInfoService xxmInfoService){
this.xxmInfoService = xxmInfoService;
}
/**
* 查询用户信息
*/
@Log("查询用户信息")
@ApiOperation("查询用户信息")
@GetMapping(value = "/all")
@PreAuthorize("@el.check('admin','xxminfo:list')")
public ResponseEntity<Object> all() {
return new ResponseEntity<>(xxmInfoService.queryAll(new XxmInfoQueryCriteria()), HttpStatus.OK);
}
}
在 service 文件夹下创建 dto 文件夹,并创建 XxmInfoQueryCriteria 类。
代码如下:
package co.yixiang.modules.xxm.service.dto;
import co.yixiang.annotation.Query;
import lombok.Data;
/**
* @author: xxm
* @Date: 2022/1/19 21:05
* 查询条件
*/
@Data
public class XxmInfoQueryCriteria {
@Query
private String name;
}
在 service 文件夹下创建 mapper 文件夹,并创建 XxmInfoMapper 类。
代码如下:
package co.yixiang.modules.xxm.service.mapper;
import co.yixiang.common.mapper.CoreMapper;
import co.yixiang.modules.xxm.domain.XxmInfo;
import org.apache.ibatis.annotations.Mapper;
import org.springframework.stereotype.Repository;
/**
* @author: xxm
* @Date: 2022/1/19 21:28
* xxminfo 的 mapper 接口
*/
@Repository
@Mapper
public interface XxmInfoMapper extends CoreMapper<XxmInfo> {
}
创建 XxmInfoService 类,作为接口。
代码如下:
package co.yixiang.modules.xxm.service;
import co.yixiang.common.service.BaseService;
import co.yixiang.modules.my.service.dto.MyInfoQueryCriteria;
import co.yixiang.modules.xxm.domain.XxmInfo;
import co.yixiang.modules.xxm.service.dto.XxmInfoDto;
import co.yixiang.modules.xxm.service.dto.XxmInfoQueryCriteria;
import org.springframework.data.domain.Pageable;
import java.util.List;
import java.util.Map;
/**
* @author: xxm
* @Date: 2022/1/19 20:08
* xxminfo 的 service 接口
*/
public interface XxmInfoService extends BaseService<XxmInfo> {
List<XxmInfoDto> queryAll(XxmInfoQueryCriteria criteria);
}
在 service 文件夹下创建 dto 文件夹,并创建 XxmInfoServiceImpl 类。
代码如下:
package co.yixiang.modules.xxm.service.impl;
import co.yixiang.common.service.impl.BaseServiceImpl;
import co.yixiang.common.utils.QueryHelpPlus;
import co.yixiang.dozer.service.IGenerator;
import co.yixiang.modules.xxm.domain.XxmInfo;
import co.yixiang.modules.xxm.service.XxmInfoService;
import co.yixiang.modules.xxm.service.dto.XxmInfoDto;
import co.yixiang.modules.xxm.service.dto.XxmInfoQueryCriteria;
import co.yixiang.modules.xxm.service.mapper.XxmInfoMapper;
import lombok.AllArgsConstructor;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Propagation;
import org.springframework.transaction.annotation.Transactional;
import java.util.List;
/**
* @author: xxm
* @Date: 2022/1/19 21:11
*/
@Service
@AllArgsConstructor
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true, rollbackFor = Exception.class)
public class XxmInfoServiceImpl extends BaseServiceImpl<XxmInfoMapper, XxmInfo> implements XxmInfoService {
private final IGenerator generator;
// @Override
// public Map<String, Object> queryAll(MyInfoQueryCriteria criteria, Pageable pageable) {
// getPage(pageable);
// PageInfo page = new PageInfo(queryAll(criteria));
// Map<String, Object> map = new LinkedHashMap<>(2);
// map.put("content", generator.convert(page.getList(), XxmInfoDto.class));
// map.put("totalElements", page.getTotal());
// return map;
// }
@Override
public List<XxmInfoDto> queryAll(XxmInfoQueryCriteria criteria) {
return baseMapper.selectList(QueryHelpPlus.getPredicate(XxmInfoDto.class, criteria));
}
}
在 swagger 中 ,访问 xxm:用户信息接口,执行后可以得到响应:

按照第三章中的内容,给项目添加增、删、改的功能。
过程忽略,这边直接放上编辑过后的代码:
package co.yixiang.modules.xxm.domain;
import com.baomidou.mybatisplus.annotation.FieldFill;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import lombok.Data;
import javax.validation.constraints.NotBlank;
import java.io.Serializable;
import java.security.Timestamp;
import java.util.Date;
/**
* @author: xxm
* @Date: 2022/1/19 16:49
* xxminfo 表对应的实体类
*/
@Data
@TableName("xxminfo")
public class XxmInfo implements Serializable {
/**
* ID
*/
@TableId
private Long id;
/**
* 姓名
*/
@NotBlank(message = "姓名不能为空")
private String name;
/**
* 备注
*/
private String remark;
/**
* 创建日期(自动填充)
*/
@TableField(fill= FieldFill.INSERT)
private Date createTime;
/**
* 最后修改日期(自动填充)
*/
@TableField(fill = FieldFill.INSERT_UPDATE)
private Date updateTime;
}
package co.yixiang.modules.xxm.service.dto;
import java.security.Timestamp;
/**
* @author: xxm
* @Date: 2022/1/20 10:56
* Dto类,一般用于与前端交互
*/
public class XxmInfoDto {
/**
* ID
*/
private long id;
/**
* 姓名
*/
private String name;
/**
* 备注
*/
private String remark;
/**
* 创建日期(自动填充)
*/
private Timestamp createTime;
/**
* 最后修改日期(自动填充)
*/
private Timestamp updateTime;
}
package co.yixiang.modules.xxm.rest;
import co.yixiang.exception.BadRequestException;
import co.yixiang.logging.aop.log.Log;
import co.yixiang.modules.xxm.domain.XxmInfo;
import co.yixiang.modules.xxm.service.XxmInfoService;
import co.yixiang.modules.xxm.service.dto.XxmInfoQueryCriteria;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
import org.springframework.security.access.prepost.PreAuthorize;
import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.*;
/**
* @author: xxm
* @Date: 2022/1/19 18:52
* xxminfo 接口
*/
@Api(tags = "xxm:用户信息")
@RestController
@RequestMapping("/api/xxminfo")
public class XxmInfoController {
private final XxmInfoService xxmInfoService;
public static final String ENTITY_NAME = "xxminfo";
public XxmInfoController(XxmInfoService xxmInfoService){
this.xxmInfoService = xxmInfoService;
}
/**
* 查询用户信息
*/
@Log("查询全部用户信息")
@ApiOperation("查询全部用户信息")
@GetMapping(value = "/all")
@PreAuthorize("@el.check('admin','xxminfo:list')")
public ResponseEntity<Object> all() {
return new ResponseEntity<>(xxmInfoService.queryAll(new XxmInfoQueryCriteria()), HttpStatus.OK);
}
// @Log("查询字典")
// @ApiOperation("查询字典")
// @GetMapping
// @PreAuthorize("@el.check('admin','dict:list')")
// public ResponseEntity<Object> getDicts(DictQueryCriteria resources, Pageable pageable) {
// return new ResponseEntity<>(dictService.queryAll(resources, pageable), HttpStatus.OK);
// }
//
@Log("新增用户")
@ApiOperation("新增用户")
@PostMapping
@PreAuthorize("@el.check('admin','xxminfo:add')")
public ResponseEntity<Object> create(@Validated @RequestBody XxmInfo resources) {
if (resources.getId() != null) {
throw new BadRequestException("A new " + ENTITY_NAME + " cannot already have an ID");
}
return new ResponseEntity<>(xxmInfoService.save(resources), HttpStatus.CREATED);
}
@Log("修改用户信息")
@ApiOperation("修改用户信息")
@PutMapping
@PreAuthorize("@el.check('admin','xxminfo:edit')")
public ResponseEntity<Object> update(@Validated @RequestBody XxmInfo resources) {
xxmInfoService.saveOrUpdate(resources);
return new ResponseEntity<>(HttpStatus.NO_CONTENT);
}
@Log("删除用户")
@ApiOperation("删除用户")
@DeleteMapping(value = "/{id}")
@PreAuthorize("@el.check('admin','xxminfo:del')")
public ResponseEntity<Object> delete(@PathVariable Long id) {
xxmInfoService.removeById(id);
return new ResponseEntity<>(HttpStatus.OK);
}
}
package co.yixiang.modules.xxm.service.dto;
import co.yixiang.annotation.Query;
import lombok.Data;
/**
* @author: xxm
* @Date: 2022/1/19 21:05
* 查询条件
*/
@Data
public class XxmInfoQueryCriteria {
@Query
private String name;
}
package co.yixiang.modules.xxm.service.mapper;
import co.yixiang.common.mapper.CoreMapper;
import co.yixiang.modules.xxm.domain.XxmInfo;
import org.apache.ibatis.annotations.Mapper;
import org.springframework.stereotype.Repository;
/**
* @author: xxm
* @Date: 2022/1/19 21:28
* xxminfo 的 mapper 接口
*/
@Repository
@Mapper
public interface XxmInfoMapper extends CoreMapper<XxmInfo> {
}
package co.yixiang.modules.xxm.service;
import co.yixiang.common.service.BaseService;
import co.yixiang.modules.my.service.dto.MyInfoQueryCriteria;
import co.yixiang.modules.xxm.domain.XxmInfo;
import co.yixiang.modules.xxm.service.dto.XxmInfoDto;
import co.yixiang.modules.xxm.service.dto.XxmInfoQueryCriteria;
import org.springframework.data.domain.Pageable;
import java.util.List;
import java.util.Map;
/**
* @author: xxm
* @Date: 2022/1/19 20:08
* xxminfo 的 service 接口
*/
public interface XxmInfoService extends BaseService<XxmInfo> {
// /**
// * 查询数据分页
// *
// * @param criteria 条件
// * @param pageable 分页参数
// * @return Map<String, Object>
// */
// Map<String, Object> queryAll(MyInfoQueryCriteria criteria, Pageable pageable);
/**
* 查询
*
* @param criteria
* @return
*/
List<XxmInfoDto> queryAll(XxmInfoQueryCriteria criteria);
/**
* 新增用户
*
* @param xxmInfo
*/
XxmInfoDto create(XxmInfo xxmInfo);
/**
* 编辑用户信息
*
* @param xxmInfo
*/
void update(XxmInfo xxmInfo);
// /**
// * 删除用户信息
// *
// * @param xxmInfo
// */
// void delete(XxmInfo xxmInfo);
}
package co.yixiang.modules.xxm.service.impl;
import co.yixiang.common.service.impl.BaseServiceImpl;
import co.yixiang.common.utils.QueryHelpPlus;
import co.yixiang.dozer.service.IGenerator;
import co.yixiang.exception.EntityExistException;
import co.yixiang.modules.xxm.domain.XxmInfo;
import co.yixiang.modules.xxm.service.XxmInfoService;
import co.yixiang.modules.xxm.service.dto.XxmInfoDto;
import co.yixiang.modules.xxm.service.dto.XxmInfoQueryCriteria;
import co.yixiang.modules.xxm.service.mapper.XxmInfoMapper;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import lombok.AllArgsConstructor;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Propagation;
import org.springframework.transaction.annotation.Transactional;
import java.util.List;
/**
* @author: xxm
* @Date: 2022/1/19 21:11
*/
@Service
@AllArgsConstructor
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true, rollbackFor = Exception.class)
public class XxmInfoServiceImpl extends BaseServiceImpl<XxmInfoMapper, XxmInfo> implements XxmInfoService {
private final IGenerator generator;
// @Override
// public Map<String, Object> queryAll(MyInfoQueryCriteria criteria, Pageable pageable) {
// getPage(pageable);
// PageInfo page = new PageInfo(queryAll(criteria));
// Map<String, Object> map = new LinkedHashMap<>(2);
// map.put("content", generator.convert(page.getList(), XxmInfoDto.class));
// map.put("totalElements", page.getTotal());
// return map;
// }
/**
* 查询所有用户信息
*
* @param criteria
* @return
*/
@Override
public List<XxmInfoDto> queryAll(XxmInfoQueryCriteria criteria) {
return baseMapper.selectList(QueryHelpPlus.getPredicate(XxmInfoDto.class, criteria));
}
/**
* 增加用户
*
* @param resources
* @return
*/
@Override
@Transactional(rollbackFor = Exception.class)
public XxmInfoDto create(XxmInfo resources) {
if (this.getOne(new QueryWrapper<XxmInfo>().lambda().eq(XxmInfo::getName, resources.getName())) != null) {
throw new EntityExistException(XxmInfo.class, "username", resources.getName());
}
this.save(resources);
return generator.convert(resources, XxmInfoDto.class);
}
/**
* 修改用户信息
*
* @param resources
*/
@Override
public void update(XxmInfo resources) {
XxmInfo xxm1 = this.getById(resources.getId());
XxmInfo xxm2 = this.getOne(new QueryWrapper<XxmInfo>().lambda().eq(XxmInfo::getName, resources.getName()));
if (xxm2 != null && !xxm2.getId().equals(xxm1.getId())) {
throw new EntityExistException(XxmInfo.class, "username", resources.getName());
}
xxm2 = this.getOne(new QueryWrapper<XxmInfo>().lambda().eq(XxmInfo::getName, resources.getName()));
if (xxm2 != null && xxm2.getId().equals(xxm1.getId())) {
throw new EntityExistException(XxmInfo.class, "username", resources.getName());
}
xxm1.setName(resources.getName());
xxm1.setRemark(resources.getRemark());
this.saveOrUpdate(xxm1);
}
//
// /**
// * 删除用户
// * @param xxmInfo
// */
// @Override
// public void delete(XxmInfo xxmInfo) {
//
// }
}