当前位置:   article > 正文

前端必备token令牌的使用_网页的管理员令牌

网页的管理员令牌

token的意思是“令牌”,是服务端生成的一串字符串,作为客户端进行请求的一个标识。

JWT(json web token) 的原理是,服务器认证以后,生成一个 JSON 对象,发回给用户,就像下面这样。

  1. {
  2. "姓名": "张三",
  3. "角色": "管理员",
  4. "到期时间": "2021年10月11日0点0分"
  5. }

以后,用户与服务端通信的时候,都要发回这个 JSON 对象。服务器完全只靠这个对象认定用户身份。

当然,为了防止用户篡改数据,服务器在生成这个对象的时候,会给他加密一下,就是我们看到的一个长长的字符串

初始代码

前端

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4.    <meta charset="UTF-8">
  5.    <meta name="viewport" content="width=device-width, initial-scale=1.0">
  6.    <meta http-equiv="X-UA-Compatible" content="ie=edge">
  7.    <title>Document</title>
  8. </head>
  9. <body>
  10.    <h1>token</h1>
  11.    <input type="text" id="username" name="name" value="admin"/>
  12.    <input type="text" id="password" name="password" value="123456"/>
  13.    <button id="btn_login">登录,获取token</button>
  14.    <button id="btn_testToken">没有token,不能访问</button>
  15.    <button id="btn_delToken">删除token</button>
  16.    <script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.0/jquery.min.js"></script>
  17.    <script>
  18.        
  19.        $('#btn_delToken').click(function(){
  20.       })
  21.       $('#btn_testToken').click(function(){
  22.          $.ajax({
  23.               type:'get',
  24.               url:'http://localhost:3000/test',
  25.               success(res){
  26.                   console.log(res);
  27.               }
  28.           })
  29.       })
  30.       $('#btn_login').click(function(){
  31.          $.ajax({
  32.               type:'post',
  33.               url:'http://localhost:3000/login',
  34.               data:{name:$('#username').val(),password:$('#password').val()},
  35.               success(res){
  36.                   console.log(res);
  37.               }
  38.           })
  39.       })
  40.      
  41.    </script>
  42. </body>
  43. </html>

后端代码

  1. const express = require('express')
  2. const cors = require('cors')
  3. const app = express();
  4. app.use(cors({origin:true,credentials:true}))
  5. app.use(express.urlencoded())
  6. app.post('/login',(req,res)=>{
  7.    console.log('接收到的数据是', req.body)
  8.    const {name, password} = req.body
  9.    if(password === '123456') {
  10.        res.json({msg:'登录成功'})
  11.   } else {
  12.        res.json({msg:'登录失败'})
  13.   }
  14. })
  15. app.get('/test',(req,res) => {
  16.    res.json({msg: '测试tokenOk'})
  17. })
  18. app.listen(3000, ()=>{
  19.    console.log(3000);
  20. })

服务器端:登录成功创建token

使用第三方模块 jsonwebtoken 创建token字符串。

基本步骤

  1. 在项目中下载安装 npm i jsonwebtoken

  2. 加载模块 const jwt = require('jsonwebtoken');

  3. 在用户登陆成功之后,调用 jwt.sign() 方法创建token, 它有如下4个参数:

  • 参数1:必填,对象形式;希望在token中保存的数据

  • 参数2:必填,字符串形式;加密的钥匙;后续验证token的时候,还需要使用

  • 参数3:可选,对象形式;配置项,比如可以配置token的有效期

  • 参数4:可选,函数形式;生成token之后的回调

  • 生成的token前面,必须拼接 Bearer 这个字符串。

参考代码

  1. const express = require('express')
  2. const multer = require('multer')
  3. const cors = require('cors')
  4. const app = express();
  5. app.use(cors({origin:true,credentials:true}))
  6. const jwt = require('jsonwebtoken');
  7. app.use(express.urlencoded())
  8. app.post('/login',(req,res)=>{
  9.    console.log('接收到的数据是', req.body)
  10.    const {name, password} = req.body
  11.    if(password === '123456') {
  12.        // 调用生成 token 的方法
  13.        const tokenStr = jwt.sign({name: name }, 'heima61', { expiresIn: 5 });
  14.        const token = 'Bearer ' + tokenStr
  15.        res.json({msg:'登录成功', token})
  16.   } else {
  17.        res.json({msg:'登录失败'})
  18.   }
  19. })
  20. app.get('/test',(req,res) => {
  21.    res.json({msg: '测试tokenOk'})
  22. })
  23. app.listen(3000, ()=>{
  24.    console.log(3000);
  25. })

浏览器端:

保存在localStorage

  1. $('#btn_login').click(function(){
  2.  $.ajax({
  3.    type:'post',
  4.    url:'http://localhost:3000/login',
  5.    data:{name:$('#username').val(),password:$('#password').val()},
  6.    success(res){
  7.      console.log(res);
  8. +      localStorage.setItem('token', res.token)
  9.   }
  10. })
  11. })

浏览器端:发请求时手动携带token

必须放置在Authorization中

  1. $('#btn_testToken').click(function(){
  2.  $.ajax({
  3.    type:'get',
  4.    url:'http://localhost:3000/test',
  5.    headers: {
  6. +      Authorization: localStorage.getItem('token'),
  7.   },
  8.    success(res){
  9.      console.log(res);
  10.   }
  11. })
  12. })

服务器端:实现token认证

选择使用 express-jwt 第三方模块进行身份认证。从模块名可以看出,该模块是专门配合express使用的。

下载安装

npm i express-jwt

中间件技术-验证token

  1. const expressJwt = require('express-jwt');
  2. // app.use(jwt().unless());
  3. // jwt() 用于解析token,并将 token 中保存的数据 赋值给 req.user
  4. // unless() 约定某个接口不需要身份认证
  5. app.use(expressJwt({
  6.  secret: 'heima61', // 生成token时的 钥匙,必须统一
  7.  algorithms: ['HS256'] // 必填,加密算法,无需了解
  8. }).unless({
  9.  path: ['/login'] // 除了个接口,其他都需要认证
  10. }));

上述代码完成后,当一个接口请求到了服务器后,它会自动验证请求头中的 Authorization 字段了,并且会自动完成:

  • 如果没有问题

    1. 将token中保存的 数据 赋值给 req.user

    2. next()。

  • 如果有问题,则抛出错误 next(错误信息)

 


声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/很楠不爱3/article/detail/547719
推荐阅读
相关标签
  

闽ICP备14008679号