第七课(3)—— swagger、RESTful api_嘘嘘喵

嘘嘘喵 社区会员 2022-01-21 20:50:55

Swagger

1. 定位相关代码

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()

2. 访问 swagger 文档

按照代码的设置,先启动项目,再访问 localhost:8000/swagger-ui.html,可成功访问,效果如图:

image-20220117204243712

3. 更改 redis 相关设置

AuthController 类中的相关代码编辑为如下:

// 保存
redisUtils.set(uuid, result, expiration, TimeUnit.HOURS);

这样,验证码的失效时间就变为了 1 小时(原为 1 分钟)

4. 获取 token

在 swagger 页面,系统:系统授权接口 -> try it out -> excute

4.1 验证码源码

获取到的响应如下:

{
  "uuid": "code-key050d4698495246588e6f46c50a87bf2c",
  "img": ""

这其中,uuid 后面的字符串是 uuid,img 后面的字符串是验证码图片的 base64 码,需要转化成图像。

4.2 验证码图像

专门写一个 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 页面。

可得到验证码图片:

image-20220118171820755

4.3 获取 RSA 加密后的密码

在刚刚的 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 加密后的密码。

image-20220118172631897

4.4 登录

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

image-20220118172248037

在 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。

4.5 使用 token 访问其他接口

拿到 token 之后,就可以访问其他接口了,以获取用户信息为例。

进入 系统:系统授权接口,点击 try it out

image-20220118173133196

Authorization 栏内填入刚刚的 token:

image-20220118174403275

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

image-20220118174616190

RESTful api

一、初始化数据库

/*
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 ,以用作这次练习。

创建好三个文件夹:

image-20220119164154200

domain :用于存放实体类

三、编写内容

1. 实体类

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;

}

2. Dto 类

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;


}

3. Controller类

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);
    }

}

4. 查询条件类

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;

}

5. mapper 接口

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> {

}

6. service 接口

创建 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);
}

7. service 实现类

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));
    }
}

8. 测试

在 swagger 中 ,访问 xxm:用户信息接口,执行后可以得到响应:

image-20220121171201759

四、 完善项目

按照第三章中的内容,给项目添加增、删、改的功能。

过程忽略,这边直接放上编辑过后的代码:

1. 实体类

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;

}

2. Dto 类

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;


}

3. Controller 类

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);

    }
}

4. 查询条件类

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;

}

5. mapper 接口

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> {

}

6. service 接口

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);

}

7. service 实现类

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) {
//
//    }
}
...全文
13528 回复 打赏 收藏 转发到动态 举报
写回复
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复

110

社区成员

发帖
与我相关
我的任务
社区描述
训练、训练、训练!
其他 其他
社区管理员
  • 实训001
  • 非鱼up
  • andy421
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

自律训练,自信挑战!

试试用AI创作助手写篇文章吧