gpt4 book ai didi

node.js - 快速 CSRF token 验证

转载 作者:搜寻专家 更新时间:2023-10-31 22:22:34 24 4
gpt4 key购买 nike

我在使用 CSRF token 时遇到问题。当我提交表单时,会生成一个新的 XSRF-TOKEN,但我想我生成了两个不同的 token ,我有点困惑。还有一个名为 _csrf 的 token ,所以我在开发人员工具中看到两个不同的 cookie(XSRF-TOKEN 和 _csrf),_csrf 在发布后不会更改。

我想做的是为每个发布请求生成一个新的 token 并检查它是否有效。有一件事我知道为了安全我应该这样做,但我坚持了下来。

这是漫长的一天,我是 Express 和 NodeJS 的新手。

这是我当前的设置。

var express = require('express')
, passport = require('passport')
, flash = require('connect-flash')
, utils = require('./utils')
, csrf = require('csurf')
// setup route middlewares
,csrfProtection = csrf({ cookie: true })
, methodOverride = require('method-override')
, bodyParser = require("body-parser")
, parseForm = bodyParser.urlencoded({ extended: false })
, cookieParser = require('cookie-parser')
, cookieSession = require('cookie-session')
, LocalStrategy = require('passport-local').Strategy
, RememberMeStrategy = require('../..').Strategy;


var app = express();

app.set('views', __dirname + '/views');
app.set('view engine', 'ejs');
app.engine('ejs', require('ejs-locals'));
app.use(express.logger());
app.use(express.static(__dirname + '/../../public'));
app.use(cookieParser());
app.use(bodyParser.urlencoded({ extended: false }));
app.use(bodyParser.json());
app.use(methodOverride());
app.use(express.session({ secret: 'keyboard cat' }));
app.use(flash());
// Initialize Passport! Also use passport.session() middleware, to support
// persistent login sessions (recommended).
app.use(passport.initialize());
app.use(passport.session());
app.use(passport.authenticate('remember-me'));
app.use(app.router);
app.use(csrf());

app.use(function (req, res, next) {
res.cookie('XSRF-TOKEN', req.csrfToken());
res.locals.csrftoken = req.csrfToken();
next();
});

路线

app.get('/form', csrfProtection, function(req, res) {
// pass the csrfToken to the view
res.render('send', { csrfToken: req.csrfToken()});
});

app.post('/process', parseForm, csrfProtection, function(req, res) {
res.send('data is being processed');
});

send.ejs (/form GET)

<form action="/process" method="POST">
<input type="hidden" name="_csrf" value="<%= csrfToken %>">

Favorite color: <input type="text" name="favoriteColor">
<button type="submit">Submit</button>
</form>

最佳答案

根据你分享的代码量,我会提到一些我觉得不太合适的地方:

1 。您可能需要交换下面的行,以便 csrf 在路由之前运行。

app.use(csrf());
app.use(app.router);

2。 csrftoken 设置也需要放在路由之前。

app.use(csrf());
app.use(function (req, res, next) {
res.cookie('XSRF-TOKEN', req.csrfToken());
res.locals.csrftoken = req.csrfToken();
next();
});
app.use(app.router);

3。您需要在表单中使用 locals.csrftoken:

<form action="/process" method="POST">
<input type="hidden" name="_csrf" value="<%= csrftoken %>">

Favorite color: <input type="text" name="favoriteColor">
<button type="submit">Submit</button>
</form>

关于node.js - 快速 CSRF token 验证,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33060044/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com