Soul网关源码学习系列之【admin后台管理Ⅰ-login】

本文深入分析了soul-admin模块的用户登录源码,详细阐述了登录过程中如何根据用户名和密码查找用户,以及使用AES加密处理密码。登录成功后,探讨了如何获取用户权限,通过JWT令牌验证机制获取有权限的菜单。文章引用了javax.crypto的Cipher加密和JWT接口验证的相关知识。
摘要由CSDN通过智能技术生成

soul-admin模块源码分析

用户登录

  • 在登录页面点击登录,通过浏览器控制台可以看到请求的地址是http://localhost:9095/platform/login?userName={username}&password={pwd}

  • 然后找到方法入口:这里通过dashboardUserService.login拿到一个返回的VO。

    	@GetMapping("/login")
        public SoulAdminResult loginDashboardUser(final String userName, final String password) {
         
            LoginDashboardUserVO loginVO = dashboardUserService.login(userName, password);
            return Optional.ofNullable(loginVO).map(item -> SoulAdminResult.success(SoulResultMessage.PLATFORM_LOGIN_SUCCESS, loginVO))
                    .orElse(SoulAdminResult.error(SoulResultMessage.PLATFORM_LOGIN_ERROR));
        }
    	
    
  • 主要看一下这个login方法:这里首先会根据用户名和明文密码去数据库找,如果找到了,会把这个用户的密码加密后更新数据库;如果明文密码找不到就使用加密密码去找。

    	@Override
        @Transactional(rollbackFor = Exception.class)
        public LoginDashboardUserVO login(final String userName, final String password) {
         
            String key = secretProperties.getKey();
            DashboardUserVO dashboardUserVO = findByQuery(userName, password);
            if (!ObjectUtils.isEmpty(dashboardUserVO)) {
         
                DashboardUserDTO dashboardUserDTO = DashboardUserDTO.builder()
                        .id(dashboardUserVO.getId(<
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值