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

做电商要注册网站吗毕设网站代做一般预算多少钱

做电商要注册网站吗,毕设网站代做一般预算多少钱,推广下载app,淇县住房和城乡建设局网站JWT(JSON Web Token)是一种用于实现身份验证和授权的开放标准。它是一种基于JSON的安全传输数据的方式,由三部分组成:头部、载荷和签名。 使用jsonwebtoken模块,你可以在Node.js应用程序中轻松生成和验证JWT。以下是j…

JWT(JSON Web Token)是一种用于实现身份验证和授权的开放标准。它是一种基于JSON的安全传输数据的方式,由三部分组成:头部、载荷和签名。

使用jsonwebtoken模块,你可以在Node.js应用程序中轻松生成和验证JWT。以下是jsonwebtoken库的使用步骤:

  1. 安装jsonwebtoken模块:在命令行中运行npm install jsonwebtoken来安装jsonwebtoken模块。

  2. 导入jsonwebtoken模块:在你的Node.js应用程序中,使用require语句导入jsonwebtoken模块。

const jwt = require('jsonwebtoken');
  1. 生成JWT:使用jsonwebtoken的sign方法生成JWT。该方法接受三个参数:载荷(Payload)、密钥和可选的配置对象。载荷是一个包含有关用户/客户端的信息的对象。
const payload = {userId: '123456789',username: 'example_user'
};const secretKey = 'your_secret_key';const token = jwt.sign(payload, secretKey, { expiresIn: '1h' });

上述代码将生成一个JWT,其中包含了userId和username信息,使用了一个密钥进行签名,并设置了过期时间为1小时。生成的JWT将作为一个字符串存储在token变量中。

  1. 验证JWT:使用jsonwebtoken的verify方法验证JWT的有效性。该方法接受三个参数:要验证的JWT、密钥和一个可选的回调函数。
const token = 'your_generated_jwt';jwt.verify(token, secretKey, (err, decoded) => {if (err) {// JWT验证失败console.log('JWT verification failed.');} else {// JWT验证成功console.log('JWT verified successfully.');console.log(decoded); // 解码后的JWT负载}
});

上述代码将验证传入的JWT是否有效,并使用提供的密钥进行签名验证。如果JWT有效,verify方法回调函数中的decoded参数将包含解码后的JWT负载信息。如果JWT无效,则会在回调函数中得到一个错误。

以下是 JWT 的一个简单的封装:

//jsonwebtoken 封装const jsonwebtoken = require("jsonwebtoken")
// 设置密钥
const secret = "anydata"
const JWT = {// 生成 tokengenerate(value,exprires){// value 数据,expires 过期时间return jsonwebtoken.sign(value,secret,{expiresIn:exprires})},// 校验 tokenverify(token){// 放在 try...catch... 中,防止报错try{return jsonwebtoken.verify(token,secret)}catch(error){return false}}
}module.exports = JWT
const token = JWT.generate('xx', '10s')
// eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJkYXRhIjoieHgiLCJpYXQiOjE2OTc0Mzk3MTEsImV4cCI6MTY5NzQzOTcyMX0.vfcaK_tHfbD-58nqcDRopg516jngqWJhw6zr229zACM
// header.数据.签名
console.log(JWT.verify(token))
// node 中间件校验
app.use((req,res,next)=>{// 如果token有效 ,next() // 如果token过期了, 返回401错误if(req.url==="/login"){next()return;}const token = req.headers["authorization"]?.split(" ")[1]if(token){var payload = JWT.verify(token)// console.log(payload)if(payload){const newToken = JWT.generate({_id:payload._id,username:payload.username},"1d")res.header("Authorization",newToken)next()}else{// errCode 和 errInfo 是 network 的 preview 中返回的数据res.status(401).send({errCode:"-1",errInfo:"token过期"})}}
})
 //生成token
const token = JWT.generate({_id: result[0]._id,username: result[0].username
}, "1d")res.header("Authorization", token)
//前端拦截
import axios from 'axios'
// Add a request interceptor
axios.interceptors.request.use(function (config) {const token = localStorage.getItem("token")config.headers.Authorization = `Bearer ${token}`return config;}, function (error) {return Promise.reject(error);});// Add a response interceptor
axios.interceptors.response.use(function (response) {const {authorization } = response.headersauthorization && localStorage.setItem("token",authorization)return response;}, function (error) {const {status} = error.responseif(status===401){// 移除本地失效的 token 值,由于过期而失效localStorage.removeItem("token")window.location.href="/login"}return Promise.reject(error);});

业务逻辑:

  1. 后端下载、导入模块 npm i jsonwebtoken
  2. 封装生成token、验证token方法
  3. 登录接口中将前端提供的字段生成token并放到登录接口响应头中
  4. 前端将token存储(并在每个请求的请求头中加入token,请求拦截添加token,响应拦截存储token)
  5. 后端设置应用级中间件
    5.1. 排除登录接口、路由
    5.2. 获取前端传过来的请求头并判断状态
    5.2.1. 有token:重新设置token并放在响应头传给前端(刷新过期时间)
    5.2.2. 无token:返回401给前端
  6. 前端响应拦截:无401跳转登录页并置空本地token
http://www.yayakq.cn/news/965124/

相关文章:

  • 模板建站是什么意思asp.net 怎样生成网站
  • 制作简易网站模板免费网站无需下载直接观看
  • 可信网站认证 费用国外免费iphone网站
  • 网站代码 输入文字 跳出内容wordpress页面显示标签代码
  • 网站设计公司手机好看网站模板免费下载
  • python 网站开发 案例重庆网站搜索排名
  • wordpress 建站简单吗哈尔滨网站建设云聚达
  • 保定网站公司那家好seo网站外链专发
  • 网站点击率深圳网站开发antnw
  • 网站建设维护管理软件最新国际热点新闻事件
  • 银川市建设工程质量监督站网站广告设计公司清晨必发图片
  • 如何做网站的教程二维码创意设计理念
  • 沈阳网站制作机构代理平台注册网站建设
  • 网站建设各模块功能简述网站租用服务器费用
  • 电子商务网站建设的平台搭建网站都需要什么
  • 哪个网站做废旧好h5建站网站
  • 安顺建设局网站使网站有流量
  • 网站建设和管理情况自己怎么建个免费网站吗
  • 常州网站建设乛薇学前端什么网站好
  • 2017 上海网站备案威宁建设局网站
  • 延庆免费网站建设那个网站做二手车好
  • 建立网站可以赚钱吗jquery个人网站开发
  • 上海美容论坛网站建设wordpress图片上传压缩
  • 网站建设分金手指科捷11成都网站建设全平台
  • 茶业网站设计方案潍坊企业网站
  • lovefort表白网站制作上海金融网站建设公司
  • 免费素材网站排行榜做个人网站
  • 聊城网站推广品牌网站建设论证方案
  • 建设常规的网站报价是多少钱手机网站建设价格
  • 网站开发网站建设公司网站浏览历史记录恢复方法是什么