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

网站前台怎么做wordpress支付通道

网站前台怎么做,wordpress支付通道,dede做购物网站,2008发布asp网站1. 什么是Token? 身份验证令牌(Authentication Token):在身份验证过程中,“token” 可以表示一个包含用户身份信息的令牌。 例如 Token(JWT)是一种常见的身份验证令牌,它包含用户的…

1. 什么是Token?

在这里插入图片描述

身份验证令牌(Authentication Token):在身份验证过程中,“token”
可以表示一个包含用户身份信息的令牌。

例如

  1. Token(JWT)是一种常见的身份验证令牌,它包含用户的身份信息(例如用户名或用户ID)以及其他相关信息,如权限或过期时间。
  2. 无意义令牌token,这种一般在获取后通过nosql查询token对应的用户信息。

当然,设计token网上大多有现成的解决方案,但是通过token如何拿个人信息呢?

2. 如何优雅的获取用户信息?

虽然token是用户凭证,但是在后端中,token是不能直接和数据进行交互的,我们需要转换成token用户信息。

解决思路:

我们大多会在过滤器filter进行token检验,在这里我们已经已经从header中解析并且验证了token了。如果我们要是再在Controller中获取header,在解决,感觉一点也不优雅。
在这里插入图片描述
我们的两种解决方案:

  1. 通过header进行解析(推荐):

哈哈哈,没想到我们还是从这种low的方法里弄的吧。 实际上nosql性能很不错,再查一次也无伤大雅,并且这种方式耦合度较低,符合代码规范。

我们可以通过注解的方式,可以尽量美观很多
1.1. 创建CurrentUserUuid接口

@Target(ElementType.PARAMETER)
@Retention(RetentionPolicy.RUNTIME)
public @interface CurrentUserUuid {
}

1.2. 创建oginUserHandlerMethodArgumentResolver解析器
在这里插入图片描述

@Component
public class LoginUserHandlerMethodArgumentResolver implements HandlerMethodArgumentResolver {@Resourceprivate TokenUtil tokenUtil;@Overridepublic boolean supportsParameter(MethodParameter parameter) {return parameter.hasParameterAnnotation(CurrentUserUuid.class) &&parameter.getParameterType().isAssignableFrom(String.class);}@Overridepublic Object resolveArgument(MethodParameter parameter, ModelAndViewContainer container,NativeWebRequest request, WebDataBinderFactory factory) {// header中获取用户tokenString token = request.getHeader("Authorization");// TODO 根据userId获取User信息,这里省略,直接创建一个User对象。return tokenUtil.getUserToken(token);}
}
  1. 过滤器二次封装请求体

我们可以在第一次过滤器查的时候,把对应的信息封装到请求中,但是请求多变,get,post参数一般在不同的位置上,需要写更复杂的结构

@Override	
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)	throws IOException, ServletException {	HttpServletRequest httpRequest = (HttpServletRequest) request;	HttpServletResponse httpResponse = (HttpServletResponse) response;	String token = request.getHeader("token");	JWTResult result = JWTUtils.checkToken(token);	Long userId = result.getUserId();	HttpServletRequestWrapper requestWrapper = new HttpServletRequestWrapper(httpRequest) {	@Override	public String[] getParameterValues(String name) {	if (name.equals("loginUserId")) {	return new String[] { userId .toString() };	}	return super.getParameterValues(name);	}	@Override	public Enumeration<String> getParameterNames() {	Set<String> paramNames = new LinkedHashSet<>();	paramNames.add("loginUserId");	Enumeration<String> names =  super.getParameterNames();	while(names.hasMoreElements()) {	paramNames.add(names.nextElement());	}	return Collections.enumeration(paramNames);	}	};	chain.doFilter(requestWrapper, httpResponse);	
}

这种好处是只需要查一次,但是请求参数多变,需要写很多额外的解构去处理,并且增加了耦合度

3. 总结

我还是推荐方法1,无疑,虽然多查一次,但是结构简单,耦合度低,并且代码较为简洁。

http://www.yayakq.cn/news/867578/

相关文章:

  • 织梦cms可以做外贸网站吗网站建设项目规划书目录
  • 网站需要维护吗专业建设工作计划
  • 广西建设厅查询网站如何注册网站免费的
  • 免费网站后台模版php网站如何编辑
  • 嘉兴网络推广企业网站的优化和推广方法
  • 国内永久免费crm系统网站推荐重庆江津做网站
  • 建网站挣钱 优帮云北京做网站找谁
  • 电商网站 网站服务内容南通网站建设规划书
  • 高校文明建设网站山东网站seo设计
  • 贵阳两学一做网站苏州公司网站建站
  • 网站一般需要怎么推广河南省级建设主管部门网站
  • 江苏建设厅网站长沙网页设计培训机构
  • 麦积区城乡建设局网站广东网站建设哪家有
  • 开封市做网站的公司lnmp快速安装wordpress
  • 网站联系我们页面高新企业建设网站价格
  • 有哪些网站可以做电子邀请函小说 wordpress
  • 重庆网站建设培训WordPress的数据库在哪
  • 乐安网站建设织梦网站开发语言
  • 本溪做网站的沧州网络营销推广方案
  • 网站后台打开慢贵州网络营销公司
  • 做网站好还是做安卓app好网站集约化建设意见和建议
  • 网站建设方面的珠宝网站设计文案
  • 国家电网交流建设分公司网站如何使用云服务建设网站
  • 现在为什么网站都打不开了怎么办啊大连在哪儿地图
  • 完整网站开发步骤网站建设公司落寞
  • 网站源码下载 app国外开源商城系统
  • 优质企业网站推广提供网站建设找哪家公司好
  • 北京建网站 优帮云个人网页设计论文免费
  • 网站关键字推广沈阳发布最新通告
  • 重庆网站seo设计可以设计制作网页的软件