我的编程空间,编程开发者的网络收藏夹
学习永远不晚

怎么基于JWT实现接口的授权访问

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

怎么基于JWT实现接口的授权访问

本篇内容主要讲解“怎么基于JWT实现接口的授权访问”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么基于JWT实现接口的授权访问”吧!

     什么是JWT

    JWT(JSON Web Token)是一个开放标准(RFC 7519),它定义了一种紧凑且独立的方式,可以在各个系统之间用JSON作为对象安全地传输信息,并且可以保证所传输的信息不会被篡改。

    JWT通常有两种应用场景:

    • 授权。这是最常见的JWT使用场景。一旦用户登录,每个后续请求将包含一个JWT,作为该用户访问资源的令牌。

    • 信息交换。可以利用JWT在各个系统之间安全地传输信息,JWT的特性使得接收方可以验证收到的内容是否被篡改。

    本文讨论第一点,如何利用JWT来实现对API的授权访问。这样就只有经过授权的用户才可以调用API。

    JWT的结构

    怎么基于JWT实现接口的授权访问

    JWT由三部分组成,用.分割开。

    Header

    第一部分为Header,通常由两部分组成:令牌的类型,即JWT,以及所使用的加密算法。

    {  "alg": "HS256",  "typ": "JWT"}

    Base64加密后,就变成了:

    eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9

    Payload

    第二部分为Payload,里面可以放置自定义的信息,以及过期时间、发行人等。

    {  "sub": "1234567890",  "name": "John Doe",  "iat": 1516239022}

    Base64加密后,就变成了:

    eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ

    Signature

    第三部分为Signature,计算此签名需要四部分信息:

    • Header里的算法信息

    • Header

    • Payload

    • 一个自定义的秘钥

    接受到JWT后,利用相同的信息再计算一次签名,然年与JWT中的签名对比,如果不相同则说明JWT中的内容被篡改。

    解码后的JWT

    怎么基于JWT实现接口的授权访问

    将上面三部分都编码后再合在一起就得到了JWT。

    需要注意的是,JWT的内容并不是加密的,只是简单的Base64编码。 也就是说,JWT一旦泄露,里面的信息可以被轻松获取,因此不应该用JWT保存任何敏感信息。

    JWT是怎样工作的

    怎么基于JWT实现接口的授权访问

    • 应用程序或客户端向授权服务器请求授权。这里的授权服务器可以是单独的一个应用,也可以和API集成在同一个应用里。

    • 授权服务器向应用程序返回一个JWT。

    • 应用程序将JWT放入到请求里(通常放在HTTP的Authorization头里)

    • 服务端接收到请求后,验证JWT并执行对应逻辑。

    在JAVA里使用JWT

    引入依赖

    <dependency>    <groupId>io.jsonwebtoken</groupId>    <artifactId>jjwt</artifactId></dependency>

    这里使用了一个叫JJWT(Java JWT)的库。

    JWT Service

    生成JWT
    public String generateToken(String payload) {        return Jwts.builder()                .setSubject(payload)                .setExpiration(new Date(System.currentTimeMillis() + 10000))                .signWith(SignatureAlgorithm.HS256, SECRET_KEY)                .compact();    }
    • 这里设置过期时间为10秒,因此生成的JWT只在10秒内能通过验证。

    • 需要提供一个自定义的秘钥。

    解码JWT
    public String parseToken(String jwt) {        return Jwts.parser()                .setSigningKey(SECRET_KEY)                .parseClaimsJws(jwt)                .getBody()                .getSubject();    }

    解码时会检查JWT的签名,因此需要提供秘钥。

    验证JWT
    public boolean isTokenValid(String jwt) {        try {            parseToken(jwt);        } catch (Throwable e) {            return false;        }        return true;    }

    JWT并没有提供判断JWT是否合法的方法,但是在解码非法JWT时会抛出异常,因此可以通过捕获异常的方式来判断是否合法。

    注册/登录

    @GetMapping("/registration")    public String register(@RequestParam String username, HttpServletResponse response) {        String jwt = jwtService.generateToken(username);        response.setHeader(JWT_HEADER_NAME, jwt);        return String.format("JWT for %s :\n%s", username, jwt);    }
    • 需要为还没有获取到JWT的用户提供一个这样的注册或者登录入口,来获取JWT。

    • 获取到响应里的JWT后,要在后续的请求里包含JWT,这里放在请求的Authorization头里。

    验证JWT

    @Overridepublic void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {        HttpServletRequest httpServletRequest = (HttpServletRequest) request;        HttpServletResponse httpServletResponse = (HttpServletResponse) response;        String jwt = httpServletRequest.getHeader(JWT_HEADER_NAME);        if (WHITE_LIST.contains(httpServletRequest.getRequestURI())) {            chain.doFilter(request, response);        } else if (isTokenValid(jwt)) {            updateToken(httpServletResponse, jwt);            chain.doFilter(request, response);        } else {            httpServletResponse.sendError(HttpServletResponse.SC_UNAUTHORIZED);        }    }private void updateToken(HttpServletResponse httpServletResponse, String jwt) {        String payload = jwtService.parseToken(jwt);        String newToken = jwtService.generateToken(payload);        httpServletResponse.setHeader(JWT_HEADER_NAME, newToken);    }
    • 将验证操作放在Filter里,这样除了登录入口,其它的业务代码将感觉不到JWT的存在。

    • 将登录入口放在WHITE_LIST里,跳过对这些入口的验证。

    • 需要刷新JWT。如果JWT是合法的,那么应该用同样的Payload来生成一个新的JWT,这样新的JWT就会有新的过期时间,用此操作来刷新JWT,以防过期。

    • 如果使用Filter,那么刷新的操作要在调用doFilter()之前,因为调用之后就无法再修改response了。

    API

    private final static String JWT_HEADER_NAME = "Authorization";    @GetMapping("/api")    public String testApi(HttpServletRequest request, HttpServletResponse response) {        String oldJwt = request.getHeader(JWT_HEADER_NAME);        String newJwt = response.getHeader(JWT_HEADER_NAME);        return String.format("Your old JWT is:\n%s \nYour new JWT is:\n%s\n", oldJwt, newJwt);    }

    这时候API就处于JWT的保护下了。API可以完全不用感知到JWT的存在,同时也可以主动获取JWT并解码,以得到JWT里的信息。如上所示。

    到此,相信大家对“怎么基于JWT实现接口的授权访问”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

    免责声明:

    ① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

    ② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

    怎么基于JWT实现接口的授权访问

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档

    猜你喜欢

    怎么基于JWT实现接口的授权访问

    本篇内容主要讲解“怎么基于JWT实现接口的授权访问”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么基于JWT实现接口的授权访问”吧! 什么是JWTJWT(JSON Web Token)是一个开
    2023-06-29

    基于PHP怎么实现JWT登录鉴权

    本文小编为大家详细介绍“基于PHP怎么实现JWT登录鉴权”,内容详细,步骤清晰,细节处理妥当,希望这篇“基于PHP怎么实现JWT登录鉴权”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一、什么是JWT1、简介JWT
    2023-06-30

    Spring Security基于注解的接口角色访问控制怎么实现

    本文小编为大家详细介绍“Spring Security基于注解的接口角色访问控制怎么实现”,内容详细,步骤清晰,细节处理妥当,希望这篇“Spring Security基于注解的接口角色访问控制怎么实现”文章能帮助大家解决疑惑,下面跟着小编的
    2023-06-16

    云服务器ipv6授权体系怎么实现访问

    要实现访问AmazonWebServices的IPv6授权,可以使用以下方式:在终端中安装IPv6密钥管理系统:在Windows操作系统中,可以通过在终端中安装IPv6密钥管理系统来实现。在客户端上安装AzureIPv6密钥管理服务:在Windows操作系统中,可以通过在终端中安装AzureIPv6密钥管理服务来实现。在云平台中配置IPv6密钥管理:在AmazonWebServices中
    2023-10-26

    云服务器ipv6授权体系怎么实现访问功能

    要实现访问功能,需要将IPV6授权协议映射到云服务器的IP地址,并实现访问控制和安全设置功能。以下是使用云服务器实现IPV6访问功能的流程:选择IPV6地址:需要确定云服务器IP地址,可以使用云服务器的IP地址查找器进行查找,或者使用网络爬虫工具进行定位。创建用户账号:在云服务器的用户列表中选择需要进行IPV6授权的用户,并为该用户创建一个账号。创建认证信息:在用户的登录界面,添加认证
    2023-10-26

    ASP.NET Core如何使用JWT自定义角色并实现策略授权需要的接口

    ASP.NET Core如何使用JWT自定义角色并实现策略授权需要的接口,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。① 存储角色/用户所能访问的 API例如使
    2023-06-26

    云服务器ipv6授权体系怎么实现访问功能设置

    在云计算环境中,IPV6协议是最新的协议,也是最重要的协议之一。它的引入使得用户能够使用更加灵活和可靠的资源访问方式,同时也提高了云计算资源的利用率和可扩展性。在本文中,我们将讨论如何实现云服务器IPV6授权体系。云服务器IPV6授权体系的核心是基于角色的访问控制。用户可以创建一个虚拟账户并授权访问云服务器资源。在这个
    云服务器ipv6授权体系怎么实现访问功能设置
    2023-10-27

    laravel怎么实现上传图片的接口并建立软链接访问

    这篇文章主要介绍“laravel怎么实现上传图片的接口并建立软链接访问”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“laravel怎么实现上传图片的接口并建立软链接访问”文章能帮助大家解决问题。我们
    2023-07-04

    Spring Security权限控制的接口怎么实现

    本篇内容主要讲解“Spring Security权限控制的接口怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Spring Security权限控制的接口怎么实现”吧!Introducti
    2023-07-05

    基于SpringSecurity的@PreAuthorize怎么实现自定义权限校验

    这篇文章主要介绍“基于SpringSecurity的@PreAuthorize怎么实现自定义权限校验”,在日常操作中,相信很多人在基于SpringSecurity的@PreAuthorize怎么实现自定义权限校验问题上存在疑惑,小编查阅了各
    2023-07-05

    JS怎么实现基于websocket的多端桥接平台

    这篇文章给大家分享的是有关JS怎么实现基于websocket的多端桥接平台的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1. 要调试什么我们主要要知道调试什么,最终回去到什么样子的结果:1.调试接口,传入接口地址
    2023-06-15

    MySQL基于SSL安全连接的主从复制怎么实现

    本文小编为大家详细介绍“MySQL基于SSL安全连接的主从复制怎么实现”,内容详细,步骤清晰,细节处理妥当,希望这篇“MySQL基于SSL安全连接的主从复制怎么实现”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。生
    2023-07-05

    基于Python怎么实现云服务器的CDN域名远程鉴权配置

    今天小编给大家分享一下基于Python怎么实现云服务器的CDN域名远程鉴权配置的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。
    2023-06-30

    基于C++的摄像头图像采集及拼接程序该怎么实现

    今天给大家介绍一下基于C++的摄像头图像采集及拼接程序该怎么实现。文章的内容小编觉得不错,现在给大家分享一下,觉得有需要的朋友可以了解一下,希望对大家有所帮助,下面跟着小编的思路一起来阅读吧。程序的说明实现从摄像头实时采集单帧图像,之后完成
    2023-06-28

    编程热搜

    • Python 学习之路 - Python
      一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
      Python 学习之路 - Python
    • chatgpt的中文全称是什么
      chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
      chatgpt的中文全称是什么
    • C/C++中extern函数使用详解
    • C/C++可变参数的使用
      可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
      C/C++可变参数的使用
    • css样式文件该放在哪里
    • php中数组下标必须是连续的吗
    • Python 3 教程
      Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
      Python 3 教程
    • Python pip包管理
      一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
      Python pip包管理
    • ubuntu如何重新编译内核
    • 改善Java代码之慎用java动态编译

    目录