当前位置: 首页 > news >正文

胶州网站开发百度收录最新方法

胶州网站开发,百度收录最新方法,长春网络建站,招聘预算网站怎么做文章目录 0. 网关如何处理登录请求1. Controller1.1. 获取用户信息1.2. 创建用户的token 2. Service2.1. FeignClient远程查询用户信息2.2. 验证密码 3. 何时刷新 token,如何刷新【本文重点】 本文主要是分析登录请求 /login 的过程。 调用过程是:ruoyi-…

文章目录

  • 0. 网关如何处理登录请求
  • 1. Controller
    • 1.1. 获取用户信息
    • 1.2. 创建用户的token
  • 2. Service
    • 2.1. FeignClient远程查询用户信息
    • 2.2. 验证密码
  • 3. 何时刷新 token,如何刷新【本文重点】

本文主要是分析登录请求 /login 的过程。

调用过程是:ruoyi-auth —> ruoyi-system

0. 网关如何处理登录请求

登录请求 127.0.0.1:8080/auth/login是特殊的请求。经过的过滤器有:

AuthFilter(order=-200)
XssFilter(order=-100)
CacheRequestFilter(order=1)
ValidateCodeFilter(order=2)
StripPrefix(order=3)

AuthFilter 认证过滤器对需要排除的 uri 地址,不检查是否有 token 直接放行(需要排除的配置可以在nacos中配置)。默认配置如下:

# 安全配置
security:# 验证码captcha:enabled: truetype: math# 防止XSS攻击xss:enabled: trueexcludeUrls:- /system/notice# 不校验白名单ignore:whites:- /auth/logout- /auth/login- /auth/register- /*/v2/api-docs- /csrf

(注意是“认证”不是“鉴权”,认证主要是判断 token 是否有效,不涉及权限)

1. Controller

    @PostMapping("login")public R<?> login(@RequestBody LoginBody form){// 用户登录LoginUser userInfo = sysLoginService.login(form.getUsername(), form.getPassword());// 获取登录tokenreturn R.ok(tokenService.createToken(userInfo));}
  • 用户登录
  • 生成 token 返回

1.1. 获取用户信息

请看 Service

1.2. 创建用户的token

  • 创建token返回给前端
/*** 创建令牌*/
public Map<String, Object> createToken(LoginUser loginUser)
{String token = IdUtils.fastUUID();// <1> 封装用户信息Long userId = loginUser.getSysUser().getUserId();String userName = loginUser.getSysUser().getUserName();loginUser.setToken(token);loginUser.setUserid(userId);loginUser.setUsername(userName);loginUser.setIpaddr(IpUtils.getIpAddr());// <2> 刷新tokenrefreshToken(loginUser);// <3> Jwt存储信息Map<String, Object> claimsMap = new HashMap<String, Object>();claimsMap.put(SecurityConstants.USER_KEY, token);claimsMap.put(SecurityConstants.DETAILS_USER_ID, userId);claimsMap.put(SecurityConstants.DETAILS_USERNAME, userName);// 接口返回信息Map<String, Object> rspMap = new HashMap<String, Object>();rspMap.put("access_token", JwtUtils.createToken(claimsMap));rspMap.put("expires_in", expireTime);return rspMap;
}

<1> 处:

把从 ruoyi-system 模块获取到的用户信息(用户、角色、权限)连同关键部分(uuid、userId、userName)重新封装

<2> 处:

refreshToken方法负责刷新token。何时刷新、如何刷新是一个值得讨论的问题。在本文的第三章重点讨论了这个问题。

<3> 处:

创建 token 的负载信息,把 uuid、userId、userName 作为 token 的负载,来创建 token。并返回给用户

2. Service

    public LoginUser login(String username, String password){...// IP黑名单校验【在哪里初始化黑名单的???】String blackStr = Convert.toStr(redisService.getCacheObject(CacheConstants.SYS_LOGIN_BLACKIPLIST));if (IpUtils.isMatchedIp(blackStr, IpUtils.getIpAddr())){recordLogService.recordLogininfor(username, Constants.LOGIN_FAIL, "很遗憾,访问IP已被列入系统黑名单");throw new ServiceException("很遗憾,访问IP已被列入系统黑名单");}// 查询用户信息R<LoginUser> userResult = remoteUserService.getUserInfo(username, SecurityConstants.INNER);...passwordService.validate(user, password);return userInfo;}

主要包括 2 个部分。

  • 用 FeignCilent 从远程服务查询用户信息
  • 密码验证

注意: remoteUserService.getUserInfo(username, SecurityConstants.INNER) 的 INNER 指定了该请求是“内部”请求,模块 auth 还会对 INNER 做处理。

2.1. FeignClient远程查询用户信息

以下代码com.ruoyi.system.api.RemoteUserService在 ruoyi-api-system 中,只是定义了相关的 api 并不是实现。RuoYi 抽象了与系统相关的 ruoyi-api-system。在里面写公共的类或接口

@FeignClient(contextId = "remoteUserService", value = ServiceNameConstants.SYSTEM_SERVICE, fallbackFactory = RemoteUserFallbackFactory.class)
public interface RemoteUserService
{/*** 通过用户名查询用户信息** @param username 用户名* @param source 请求来源* @return 结果*/@GetMapping("/user/info/{username}")public R<LoginUser> getUserInfo(@PathVariable("username") String username, @RequestHeader(SecurityConstants.FROM_SOURCE) String source);
}

url是:/user/info/{username}。

调用服务是: ruoyi-system。

设置了降级 fallback 处理:RemoteUserFallbackFactory

备注:获取用户信息的详细分析参考:https://www.yuque.com/yuchangyuan/tkb5br/vktircc4smqw8ggs

2.2. 验证密码

  • 验证密码

主要是验证“可重试次数”和“密码正确性”

1、验证重试次数(默认如果错误超过5次就锁定 10分钟)

2、验证密码是否与数据库匹配。如登录成功需要清除密码错误次数。注册和验证密码用到的密码验证器要一致。

3. 何时刷新 token,如何刷新【本文重点】

  • 何时刷新

只有在将要达到过期时间,才会刷新,来续期,通常可以认为是 2/3 的时间点。

① 调用refresh方法刷新:refresh 接口

② 创建 token 时:createToken方法

③ 设置用户信息时:setLoginUser方法

④ 验证 token 时:verifyToken方法

主要是第四点。是通过 mvc 拦截器实现的

  • 如何刷新

1、定时任务方案:

① 拦截用户请求,保存 key=userId,value=需要刷新的时间点到一个全局的 map 中

② 用 quartz 启动一个定时任务间隔一段时间扫描 map 来刷新

缺点:不太好控制

2、拦截器方案:

原理:是通过 mvc 的拦截器 HandlerInterceptor 实现的。

为什么不通过过滤器实现,而是拦截器?

答案:因为我们的目的不是要过滤掉请求,而是拦截请求并根据条件设置token的过期时间

public class HeaderInterceptor implements AsyncHandlerInterceptor
{@Overridepublic boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception{........String token = SecurityUtils.getToken();if (StringUtils.isNotEmpty(token)){LoginUser loginUser = AuthUtil.getLoginUser(token);if (StringUtils.isNotNull(loginUser)){// 验证和刷新 token 的过期时间AuthUtil.verifyLoginUserExpire(loginUser);SecurityContextHolder.set(SecurityConstants.LOGIN_USER, loginUser);}}return true;}
}

如上面的代码,RuoYi 采用的也是拦截器方案,在HeaderInterceptor拦截器中,针对每个请求验证和刷新 token 的过期时间。详情参考:https://www.yuque.com/yuchangyuan/tkb5br/d387fbc5d3f5522fa013b5e087a0dad9

http://www.hrbkazy.com/news/15333.html

相关文章:

  • 聊城集团网站建设怎么推广淘宝店铺
  • 网站建设的资金风险网络营销心得体会1000字
  • 购物网站设计意义信息流广告投放渠道
  • 保山市住房和城乡建设厅网站安卓优化大师历史版本
  • 石家庄网站推广软件100种找客户的方法
  • 站群cms百度的网址是多少
  • 上门服务做眉毛是哪个网站淘宝营销推广方案
  • 阿里巴巴网站运营怎么做今日热点新闻头条排行榜
  • 成都营销型网站建设合肥网络公司
  • 自己做彩票网站合法吗深圳推广公司哪家正规
  • 公司网站服务商sq网站推广
  • 网站建设素材模板下载谷歌网页版入口在线
  • 工业云网站建设网站怎么优化关键词排名
  • 做一个网站怎么做数据库长尾词优化外包
  • 纷享销客crm管理系统二十条优化措施原文
  • 应用商店下载安装打开seo建站公司
  • 买一个网站需要多少钱百度学术官网入口
  • 如何建设一个静态网站营销模式有几种
  • 网站建设中正在为您转怎样搭建一个网站
  • 房地产手机网站模板知名网站
  • 五年级信息做网站的软件乐云seo官网
  • 电商网站建设参考文献爱站工具包的模块有哪些
  • 深圳网站建设资讯关键词优化骗局
  • 网站关键词怎么做排名靠前百度链接提交入口
  • 如何制作企业网站百度网站app
  • 深圳网站建设 易通鼎网络营销应用方式
  • 惠州做网站建设价格谷歌sem推广
  • 专业的建设企业网站公司seo网站分析工具
  • 美容公司网站什么做才好seo排名查询软件
  • 网站建设与维护的内容深圳seo优化电话