Angular/NodeJs Webapp,JWT验证还是会话验证?
创始人
2024-10-21 12:31:34
0

在Angular/Node.js Web应用中,可以使用JWT(JSON Web Token)或会话验证来验证用户身份。下面是使用两种验证方法的代码示例:

使用JWT验证: 在Node.js服务器端,可以使用jsonwebtoken库来生成和验证JWT令牌。以下是一个示例:

const jwt = require('jsonwebtoken');
const secretKey = 'your-secret-key';

// 生成JWT令牌
const generateToken = (user) => {
  const payload = {
    id: user.id,
    username: user.username
  };
  const options = {
    expiresIn: '1h' // 令牌有效期为1小时
  };
  return jwt.sign(payload, secretKey, options);
};

// 验证JWT令牌
const verifyToken = (token) => {
  try {
    return jwt.verify(token, secretKey);
  } catch (error) {
    return null; // 令牌无效
  }
};

// 在路由中使用JWT验证
app.get('/api/protected', (req, res) => {
  const token = req.headers.authorization;

  if (!token) {
    return res.status(401).json({ message: '未提供令牌' });
  }

  const decodedToken = verifyToken(token);

  if (!decodedToken) {
    return res.status(401).json({ message: '令牌无效' });
  }

  // 令牌验证通过,执行受保护的操作
  // ...
});

在Angular前端,可以使用Angular的HttpClient来发送包含JWT令牌的请求。以下是一个示例:

import { HttpClient, HttpHeaders } from '@angular/common/http';

const apiUrl = 'http://localhost:3000/api/protected';
const authToken = 'your-jwt-token';

// 发送带JWT令牌的请求
const httpOptions = {
  headers: new HttpHeaders({
    'Content-Type': 'application/json',
    'Authorization': `Bearer ${authToken}`
  })
};

this.http.get(apiUrl, httpOptions).subscribe(
  (response) => {
    // 请求成功,执行操作
    // ...
  },
  (error) => {
    // 请求失败,处理错误
    // ...
  }
);

使用会话验证: 在Node.js服务器端,可以使用express-session库来处理会话验证。以下是一个示例:

const express = require('express');
const session = require('express-session');

const app = express();

// 配置会话
app.use(session({
  secret: 'your-session-secret',
  resave: false,
  saveUninitialized: true,
  cookie: { secure: false } // 仅在HTTPS上使用secure cookie
}));

// 在路由中使用会话验证
app.get('/api/protected', (req, res) => {
  if (!req.session.user) {
    return res.status(401).json({ message: '未登录' });
  }

  // 会话验证通过,执行受保护的操作
  // ...
});

// 进行登录
app.post('/api/login', (req, res) => {
  // 验证用户凭据

  const user = {
    id: 1,
    username: 'john'
  };

  req.session.user = user;

  res.json({ message: '登录成功' });
});

在Angular前端,可以使用Angular的HttpClient来发送带会话验证的请求。以下是一个示例:

import { HttpClient } from '@angular/common/http';

const apiUrl = 'http://localhost:3000/api/protected';

// 发送带会话验证的请求
this.http.get(apiUrl).subscribe(
  (response) => {
    // 请求成功,执行操作
    // ...
  },
  (error) => {
    // 请求失败,处理错误
    // ...
  }
);

以上是使用JWT验证和会话验证的示例代码。你可以根据自己的需求选择其中一种验证方法来实现身份验证。

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...