软件编程
位置:首页>> 软件编程>> java编程>> Java登录功能实现token生成与验证

Java登录功能实现token生成与验证

作者:穆晟铭  发布时间:2023-11-30 07:57:28 

标签:Java,token,生成,验证

一、token与cookie相比较的优势

  • 1、支持跨域访问,将token置于请求头中,而cookie是不支持跨域访问的;

  • 2、无状态化,服务端无需存储token,只需要验证token信息是否正确即可,而session需要在服务端存储,一般是通过cookie中的sessionID在服务端查找对应的session;

  • 3、无需绑定到一个特殊的身份验证方案(传统的用户名密码登陆),只需要生成的token是符合我们预期设定的即可;

  • 4、更适用于移动端(Android,iOS,小程序等等),像这种原生平台不支持cookie,比如说微信小程序,每一次请求都是一次会话,当然我们可以每次去手动为他添加cookie,详情请查看博主另一篇博客;

  • 5、避免CSRF跨站伪造攻击,还是因为不依赖cookie;

二、基于JWT的token认证实现

JWT:JSON Web Token,其实token就是一段字符串,由三部分组成:Header,Payload,Signature

1、引入依赖


<dependency>
     <groupId>com.auth0</groupId>
     <artifactId>java-jwt</artifactId>
     <version>3.8.2</version>
</dependency>

2、设置密钥和生存时间


//设置过期时间
private static final long EXPIRE_DATE=30*60*100000;
//token秘钥
private static final String TOKEN_SECRET = "ZCEQIUBFKSJBFJH2020BQWE";

3、实现签名方法


public static String token (String username,String password){

String token = "";
       try {
           //过期时间
           Date date = new Date(System.currentTimeMillis()+EXPIRE_DATE);
           //秘钥及加密算法
           Algorithm algorithm = Algorithm.HMAC256(TOKEN_SECRET);
           //设置头部信息
           Map<String,Object> header = new HashMap<>();
           header.put("typ","JWT");
           header.put("alg","HS256");
           //携带username,password信息,生成签名
           token = JWT.create()
                   .withHeader(header)
                   .withClaim("username",username)
                   .withClaim("password",password).withExpiresAt(date)
                   .sign(algorithm);
       }catch (Exception e){
           e.printStackTrace();
           return  null;
       }
       return token;
   }

4、验证token


public static boolean verify(String token){
       /**
        * @desc   验证token,通过返回true
        * @create 2019/1/18/018 9:39
        * @params [token]需要校验的串
        **/
       try {
           Algorithm algorithm = Algorithm.HMAC256(TOKEN_SECRET);
           JWTVerifier verifier = JWT.require(algorithm).build();
           DecodedJWT jwt = verifier.verify(token);
           return true;
       }catch (Exception e){
           e.printStackTrace();
           return  false;
       }
   }

5、测试

直接用生成的token去验证,成功


public static void main(String[] args) {
      String username ="zhangsan";
       String password = "123";
       String token = token(username,password);
       System.out.println(token);
       boolean b = verify(token);
       System.out.println(b);
   }

Java登录功能实现token生成与验证

三、完整的Token工具类代码


package xxx.utils; //你的包

import com.auth0.jwt.JWT;
import com.auth0.jwt.JWTVerifier;
import com.auth0.jwt.algorithms.Algorithm;
import com.auth0.jwt.interfaces.DecodedJWT;

import java.util.Date;
import java.util.HashMap;
import java.util.Map;
/**
* @desc   使用token验证用户是否登录
* @author zm
**/
public class TokenUtils {
   //设置过期时间
   private static final long EXPIRE_DATE=30*60*100000;
   //token秘钥
   private static final String TOKEN_SECRET = "ZCfasfhuaUUHufguGuwu2020BQWE";

public static String token (String username,String password){

String token = "";
       try {
           //过期时间
           Date date = new Date(System.currentTimeMillis()+EXPIRE_DATE);
           //秘钥及加密算法
           Algorithm algorithm = Algorithm.HMAC256(TOKEN_SECRET);
           //设置头部信息
           Map<String,Object> header = new HashMap<>();
           header.put("typ","JWT");
           header.put("alg","HS256");
           //携带username,password信息,生成签名
           token = JWT.create()
                   .withHeader(header)
                   .withClaim("username",username)
                   .withClaim("password",password).withExpiresAt(date)
                   .sign(algorithm);
       }catch (Exception e){
           e.printStackTrace();
           return  null;
       }
       return token;
   }

public static boolean verify(String token){
       /**
        * @desc   验证token,通过返回true
        * @params [token]需要校验的串
        **/
       try {
           Algorithm algorithm = Algorithm.HMAC256(TOKEN_SECRET);
           JWTVerifier verifier = JWT.require(algorithm).build();
           DecodedJWT jwt = verifier.verify(token);
           return true;
       }catch (Exception e){
           e.printStackTrace();
           return  false;
       }
   }
   public static void main(String[] args) {
      String username ="zhangsan";
       String password = "123";
       String token = token(username,password);
       System.out.println(token);
       boolean b = verify("eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXNzd22yZCI6IjEyMyIsImV4cCI6MTU3ODE5NzQxMywidXNlcm5hbWUiOiJ6aGFuZ3NhbiJ9.IyTZT0tISQQZhGhsNuaqHGV8LD7idjUYjn3MGbulmJg");
       System.out.println(b);
   }
}

来源:https://www.cnblogs.com/achengmu/p/12693260.html

0
投稿

猜你喜欢

  • 首先我们如果要使用Java中存在的包,可以程序中使用import语句导入包。包说通俗点就是一个文件夹,为了方便管理。在程序中声明包的语法:p
  • 您可以通过为LINQ库不提供的操作添加新运算符,或者通过创建自己的标准查询运算符实现来提高可读性和性能,从而扩展Rx。 编写自定义版本的标准
  • 笔者语录: 我发现我喜欢捣鼓一些小玩意儿,虽然官网(见文末)写得很明白了,但是咱们对感兴趣的部分来敲一遍代码好吧。过滤器简介:简介logba
  • 本文实例为大家分享了Unity Shader实现动态过场切换图片的具体代码,供大家参考,具体内容如下一、简单介绍Shader Languag
  • 简单的日历实现,只是显示了每一个月,没有显示当天和记事这些功能主要是计算月初是周几,月末是周几,然后相应的显示上一月多少天和下一月多少天。先
  •  性能优化的帮助工具:MAT,Memory Monitor(属于AndroidMonitor中一个模块),HeapTool(查看堆
  • Spring的 * 缓存Spring * 缓存是为了解决对象间的循环依赖问题。A依赖B,B依赖A,这就是一个简单的循环依赖。我们来先看看 * 缓存
  • 本文实例讲述了C#转换日期类型的方法。分享给大家供大家参考。具体分析如下:如:将日期1999-5-31 11:20转换成 /Date(928
  • 在编程的时候或者写网络爬虫的时候,经常需要对html进行解析,抽取其中有用的数据。一款好的工具是特别有用的,能提供很多的帮助,网上有很多这样
  • Consul是什么Consul是一个基于HTTP的服务发现工具,用于配置和管理系统和服务之间的依赖关系。它提供了一个简单的方式来注册、发现和
  • 在阻塞队里中,除了对元素进行增加和删除外,我们可以把元素的删除做一个延迟的处理,即使用DelayQueue的方法。本文就来和大家聊聊Java
  • Android标题栏最右边添加按钮的实例step1:重写activity的onCreateOptionsMenu方法@Override pu
  • 在日常的app使用中,我们会在android 的app中看见 热门标签等自动换行的流式布局,今天,我们就来看看如何自定义一个类似热门标签那样
  •  本文设计一个简单的班级管理系统,满足如下要求:1、设计学生类Student,包含学号(String型)、姓名(String型)、
  • 1、判断实体对象是否为空2、判断对象所有属性是否为空3、特别注意,实体类中如果有基本数据类型,会影响判断package com.liuxd.
  • 我们很多时候会碰到这样的问题,使用多线程刷一个表的数据时需要多个线程不能重复提取数据,那么这个时候就需要使用到线程的排他锁了。在c#里面其实
  • 简介前提条件:确保本机已经安装 VS Code。确保本机已安装 SSH client, 并且确保远程主机已安装 SSH server。VSC
  • Unity Shader学习:水墨效果偶然在网上看到9级铁甲蛹大神的水墨风格后处理觉得挺有意思,参照着实现一下,还是涉及到之前油画效果的算法
  • 本文是vhr系列的第十二篇,项目地址 https://github.com/lenve/vhr邮件发送也是一个老生常谈的问题了,代码虽然简单
  • 在C#中,可以使用一些第三方库或内置类库实现动态执行脚本的功能。以下是几个常用的方案:1.使用Roslyn编译器Roslyn是微软推出的一个
手机版 软件编程 asp之家 www.aspxhome.com