SpringBoot 登录认证(一)

SpringBoot 登录认证(一)-CSDN博客

SpringBoot 登录认证(二)-CSDN博客

SpringBoot登录校验(三)-CSDN博客

本节实现基础的登录认证功能,只进行数据库的判断。这种方法有一个巨大的问题是用户如果访问系统的其他功能,系统不会识别出用户是未登录的,即界面并不会自动跳转到登录界面

接口文档

我们参照接口文档来开发登录功能

  • 基本信息

    请求路径:/login ​ 
    请求方式:POST ​ 
    接口描述:该接口用于员工登录Tlias智能学习辅助系统,登录完毕后,系统下发JWT令牌。 
    
  • 请求参数

    参数格式:application/json

    参数说明:

    名称类型是否必须备注
    usernamestring必须用户名
    passwordstring必须密码

    请求数据样例:

    {
        "username": "jinyong",
        "password": "123456"
    }

  • 响应数据

    参数格式:application/json

    参数说明:

    名称类型是否必须默认值备注其他信息
    codenumber必须响应码, 1 成功 ; 0 失败
    msgstring非必须提示信息
    datastring必须返回的数据 , jwt令牌

    响应数据样例:

    {
      "code": 1,
      "msg": "success",
      "data": "eyJhbGciOiJIUzI1NiJ9.eyJuYW1lIjoi6YeR5bq4IiwiaWQiOjEsInVzZXJuYW1lIjoiamlueW9uZyIsImV4cCI6MTY2MjIwNzA0OH0.KkUc_CXJZJ8Dd063eImx4H9Ojfrr6XMJ-yVzaWCVZCo"
    }

实现思路

 

 注意事项:

  1. 需要新定义一个LoginController
  2. post类型的请求,要用@RequestBody将客户端传送的Json数据封装到类中
  3. 客户端发送的Json数据包括username和password,所以可以使用Emp员工类封装
  4. 无需新定义Service和Mapper,因为本质还是查询员工的信息

实现代码

LoginController:

@Slf4j
@RestController
public class LoginController {

    @Autowired
    private EmpService empService;

    @PostMapping("/login")
    //注意用@RequestBody将Json数据映射到封装类中
    public Result login(@RequestBody Emp emp){
        log.info("登录注册");
        //查询返回的是一条员工信息,即一个员工对象
        Emp e = empService.login(emp);
        return Result.success(e);
    }

}

EmpServiceImpl:

 @Override
    public Emp login(Emp emp) {
        Emp e = empMapper.getByUsernameAndPassword(emp);
        return e;
    }

EmpMapper:

     /**
     * 根据用户名和密码查询员工信息
     * @param emp
     * @return
     */
    @Select("select * from emp where username = #{username} and password = #{password}")
    Emp getByUsernameAndPassword(Emp emp);

Postman测试(Json格式)

需要选中raw 

  • 6
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值