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

网站客户端ip做爬虫口碑营销成功案例简短

网站客户端ip做爬虫,口碑营销成功案例简短,wordpress 上传权限,网站链接 动态图怎么做一、概述 JWT全称:**JSON Web Token **(https://jwt.io/)定义了一种简洁的、自包含的格式,用于通信双方以json数据格式安全的传输信息。组成: ①第一部分:Header(头),记录令牌类型、签名算法等。例如: (“alg”:" HS256"," type":“…

一、概述

  • JWT全称:**JSON Web Token **(https://jwt.io/)
  • 定义了一种简洁的、自包含的格式,用于通信双方以json数据格式安全的传输信息。
  • 组成:
    ①第一部分:Header(头),记录令牌类型、签名算法等。例如: (“alg”:" HS256"," type":“JWT”)
    ②第二部分: Payload(有效载荷),携带一些自定义信息、默认信息等。例如: {“id”.“1”,“username”:“Tom”}
    ③第三部分: Signature(签名),防止Token被篡改、确保安全性。将header、payload,并加入指定秘钥,通过指定签名算法计算而来。

在这里插入图片描述

Base64:是一种基于64个可打印字符(A-Z a-z 0-9 +/)来表示二进制数据的编码方式。

二、令牌生成

1、引入坐标

    <!--java-jwt令牌--><dependency><groupId>com.auth0</groupId><artifactId>java-jwt</artifactId><version>4.4.0</version></dependency>

2、调用API生成令牌

    @Testpublic void testGen(){HashMap<String, Object> claims = new HashMap<>();claims.put("id",1);claims.put("username","张三");//生成jwt的String token = JWT.create().withClaim("user", claims)//通过添加载荷的方式将用户信息添加进去.withExpiresAt(new Date(System.currentTimeMillis() + 1000 * 60 * 60 * 12)) //添加过期时间 12h.sign(Algorithm.HMAC256("arata"));//指定加密算法 加密秘钥System.out.println(token);}

在这里插入图片描述

3、验证生成的令牌

    @Testpublic void testParse(){//定义字符串模拟生成的token令牌String token = "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9" +".eyJ1c2VyIjp7ImlkIjoxLCJ1c2VybmFtZSI6IuW8oOS4iSJ9LCJleHAiOjE3NDcxNjc1MjN9" +".KejB84CGQw5r602-wUk-Ew0YE2nLSaLvLHhY2S47GCw";JWTVerifier jwtVerifier = JWT.require(Algorithm.HMAC256("arata")).build();//申请JWt验证器(秘钥与算法和加密时保持一致)DecodedJWT decodedJWT = jwtVerifier.verify(token);//验证token,生成一个解析后的jwt对象Map<String, Claim> claims = decodedJWT.getClaims();//可以从中获取所有载荷System.out.println(claims.get("user")); //获取键名为user的载荷,获取成功的话代表认证成功
//如果篡改了头部和载荷部分的数据,那么验证失败工
//如果秘钥改了,验证失败
//token过期}

在这里插入图片描述

三、封装为JWT工具类

package org.example.utils;import com.auth0.jwt.JWT;
import com.auth0.jwt.algorithms.Algorithm;import java.util.Date;
import java.util.Map;public class JwtUtil {private static final String KEY = "itheima";//接收业务数据,生成token并返回public static String genToken(Map<String, Object> claims) {return JWT.create().withClaim("claims", claims).withExpiresAt(new Date(System.currentTimeMillis() + 1000 * 60 * 60 * 12)).sign(Algorithm.HMAC256(KEY));}//接收token,验证token,并返回业务数据public static Map<String, Object> parseToken(String token) {return JWT.require(Algorithm.HMAC256(KEY)).build().verify(token).getClaim("claims").asMap();}}

四、集成JWT

    @PostMapping("/login")public Result<String> login(@Pattern(regexp = "^\\S{5,16}$")String username,@Pattern(regexp = "^\\S{5,16}$")String password){//根据用户名查询userUser user = userService.findByUserName(username);//判断是否查询到if (user == null){return Result.error("用户不存在");}//判断密码是否正确String md5String = Md5Util.getMD5String(password);if(md5String.equals(user.getPassword())){//登陆成功//生成tokenMap<String, Object> claims = new HashMap<>();claims.put("id",user.getId());claims.put("username",user.getUsername());String token = JwtUtil.genToken(claims);return Result.success(token);}return Result.error("密码错误");}

使用:

    @GetMapping("/list")public Result<String> list(@RequestHeader(name = "Authorization") String token, HttpServletResponse response){//在提供服务之前先验证token//用户登录成功后,系统会自动下发WT令牌,// 然后在后续的每次请求中,浏览器都需要在请求头header中携带到服务端,// 请求头的名称为Authorization,值为登录时下发的JWI令牌。try {Map<String, Object> claims = JwtUtil.parseToken(token);return Result.success("所有的文章数据列表");} catch (Exception e) {//没有验证成功的话会报错,所以这里我们直接抛出异常response.setStatus(401);throw new RuntimeException(e);}}

五、优化(拦截器)

在这里插入图片描述
在程序中会存在很多controller,而每个controller会有很多接口,都要校验吗?使用拦截器
在这里插入图片描述

1、重写方法编写拦截器

在这里插入图片描述

package org.example.interceptors;import jakarta.servlet.http.HttpServletRequest;
import jakarta.servlet.http.HttpServletResponse;
import org.example.pojo.Result;
import org.example.utils.JwtUtil;
import org.springframework.stereotype.Component;
import org.springframework.web.servlet.HandlerInterceptor;import java.util.Map;@Component
public class LoginInterceptor implements HandlerInterceptor {@Overridepublic boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {//拦截下来之后先进行令牌验证//获取tokenString token = request.getHeader("Authorization");//解析Tokentry {Map<String, Object> claims = JwtUtil.parseToken(token);//验证成功,放行return true;} catch (Exception e) {//没有验证成功的话会报错,所以这里我们直接抛出异常response.setStatus(401);//验证不成功,不放行return false;}}
}

2、在配置类中注册拦截器(添加拦截器使其生效)

在这里插入图片描述

package org.example.config;import org.example.interceptors.LoginInterceptor;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;@Configuration
public class WebConfig implements WebMvcConfigurer {@Autowiredprivate LoginInterceptor loginInterceptor;@Overridepublic void addInterceptors(InterceptorRegistry registry) {//登录接口和注册接口不拦截registry.addInterceptor(loginInterceptor).excludePathPatterns("/user/login","/user/register");}
}
http://www.dtcms.com/wzjs/335946.html

相关文章:

  • wordpress 4.6.1 漏洞网站优化方案模板
  • 郑州专业网站建设公司立即优化在哪里
  • 做图网站seo排名优化推广
  • python做网站实例爱链网买链接
  • 东莞做网站网站新东方线下培训机构官网
  • 网站子页面设计百度推广如何计费
  • php做网站需要后台吗可以推广的平台
  • 中小企业网站建设好么百度电脑端网页版入口
  • 哪个公司做网站好苏州免费二级域名分发
  • 做网站怎么接私活seo咨询岳阳
  • 陕西做网站公司有哪些化妆品营销推广方案
  • 黄埔b2b网站建设公司怀来网站seo
  • 有什么网站可以叫人做图软件商店安装
  • 苏华建设集团网站做网络推广有哪些平台
  • 做多语言网站多少钱深圳做推广哪家比较好
  • 购物网站优化的建议百度关键词搜索量统计
  • 区块链媒体网站建设免费的个人主页网页制作网站
  • 青海省建设厅网站东莞网站推广及优化
  • 系统花钱做任务的小说魅网站扬州整站seo
  • 建设企业网站就等于开展网络营销网站建设推广多少钱
  • web开发是做网站吗在线识别图片找原图
  • 自己电脑做网站iis免费seo网站的工具
  • 无锡 网站建设公司网络营销概述ppt
  • 想把自己做的网站放到网上网站单向外链推广工具
  • 小说网站建设目的软文范例大全500字
  • 网站建设佰金手指科捷一app拉新项目
  • 网站店招用什么软件做的五年级上册优化设计答案
  • 山东住房建设部网站网页搜索关键字
  • wordpress显示插件怎么用湘潭seo快速排名
  • 红动中国免费素材网站国外seo工具