项目地址:github.com/ocubexo/spr…
项目已更新至2.0.0 Beta 查看更新内容
简介
这是一个基于SpringBoot 2.1.1 RELEASE,用于搭建RESTful API工程的脚手架,只需三分钟你就可以开始编写业务代码,不再烦恼于构建项目与风格统一。
快速开始
- 构建数据库
- 运行
/src/test
下的CodeGenerator.java
进行代码生成 - 开始编写业务代码
内置功能与使用方法
RESTful风格Result生成器
1.成功且不带数据的结果
// 不带数据的成功结果
return new Result().success();
复制代码
返回结果示例:
{
"code": 200,
"message": "Success",
"data": null
}
复制代码
2.成功且带返回数据的结果
return new Result().success("Hello,world");
// 当然你也可以返回对象或其他类型的数据
User user = new User();
return new Result().success(user);
复制代码
返回结果示例:
{
"code": 200,
"message": "Success",
"data": "Hello,world"
}
复制代码
或者是:
{
"code": 200,
"message": "Success",
"data": {
"name": "jack",
"age": 20
}
}
复制代码
3.错误结果:
// fail方法的参数(错误代码,错误信息)
return new Result().fail(10400, "登陆失败,密码错误");
// 你还可以自定义错误结果的code
return new Result().fail(null, "未登录", 401);
复制代码
返回结果示例:
{
"code": 400,
"message": "登陆失败,密码错误",
"data": 10400
}
复制代码
或者:
{
"code": 401,
"message": "未登录",
"data": null
}
复制代码
RESTful风格的异常接管
// 参数说明(错误信息, 错误Code)
throw new ServiceException("未登录", 401);
// 你也可以返回错误代码
throw new ServiceException(10404, "服务器维护中", 404);
复制代码
返回结果示例:
{
"code": 401,
"message": "未登录",
"data": null
}
复制代码
或者:
{
"code": 404,
"message": "服务器维护中",
"data": 10404
}
复制代码
基于JWT的认证机制
@Autowired
private TokenService tokenService;
// 生成Payload
Map payload = new HashMap();
payload.put("id",1);
// 生成Token
tokenService.generate(TokenType.ACCESS, payload, 1);
// 格式化Token
String token = getYourToken();
tokenService.parse(token); // 返回的结果是一个Jwt对象,详见JJWT文档
复制代码
Auth注解
Auth注解用于获取当前用户的Token中的userId,在获取的同时会自动校验用户Token,若用户未登录则会抛出未登录的异常。
// 在controller中使用
@PostMapping("/user/1/edit")
public Result edit(@Auth int userId, @RequestBody sthPosted) {
// 根据ID判断权限
}
复制代码
更新内容:
- 更加详细全面的功能文档
- 重构部分代码
- 添加更多的异常接管
- 添加自动插入创建与更新日期功能(基于MybatisPlus 特性)
- 优化代码结构,将功能性的部分模块化,便于后期的维护或升级为 SpringCloud 项目
- 增强@Auth 注解的代码健壮性