gpt4 book ai didi

node.js - 带有 jQ​​uery Ajax 的 Express.js csrf token

转载 作者:搜寻专家 更新时间:2023-11-01 00:23:22 26 4
gpt4 key购买 nike

我正在尝试在我的项目中实现 csrf 保护,但我无法使其与 jQuery Ajax 一起使用。 (虽然它适用于普通的帖子请求)

如果我在发送表单之前使用 chrome 开发工具篡改 token ,我仍然会看到“正在处理数据”文本,而不是 invalid csrf token 错误。

应用程序.js

var express = require('express');
var path = require('path');
var favicon = require('serve-favicon');
var logger = require('morgan');
var cookieParser = require('cookie-parser');
var csrf = require('csurf');
var bodyParser = require('body-parser');
var router = express.Router();
var app = express();

// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'jade');
//app.set('strict routing', true);
app.set('view options', {layout: false});

app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({extended: false}));
app.use(cookieParser());

var csrfProtection = csrf({ cookie: true });
var parseForm = bodyParser.urlencoded({ extended: false });

app.use(express.static(path.join(__dirname, 'public')));

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


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


// development error handler
// will print stacktrace
if (app.get('env') === 'development') {
app.use(function (err, req, res, next) {
res.status(err.status || 500);
res.render('error', {
message: err.message,
error: err
});
});
}

// production error handler
// no stacktraces leaked to user
app.use(function (err, req, res, next) {
res.status(err.status || 500);
res.render('error', {
message: err.message,
error: {}
});
});

module.exports = app;

发送.jade

html
head
meta(name='_csrf', content='#{csrfToken}')
body
form(action='/form', method='POST')
| Favorite color:
input(type='text', class="favori", name='favoriteColor')
button(type='submit') Submit
script(src="javascripts/frontend/jquery/jquery-3.0.0-alpha1.js")
script(src="javascripts/test.js")

测试.js

$(document).ready(function () {

$.ajaxSetup({
headers: {'X-CSRF-Token': $('meta[name="_csrf"]').attr('content')}
});

$('button').click(function (e) {
e.preventDefault();
var text = $('.favori').val();
alert(text);
$.post(
"/form",
{
text: text
}, function (data) {
console.log(data);
});
});
});

最佳答案

在负载消息中发送 CSRF token :

$('button').click(function (e) {
e.preventDefault();
var text = $('.favori').val();
alert(text);
$.post(
"/form",
{
text: text,
_csrf : $('meta[name="_csrf"]').attr('content')
}, function (data) {
console.log(data);
});
});

为了方便您的工作,我认为您可以创建一个 Jquery 插件来执行此操作,如下所示:

(function( $ ) {
$.postCSRF = function(to, message, callback) {
message._csrf = $('meta[name="_csrf"]').attr('content');
$.post(to, message, callback);
};
}( jQuery ));

// Usage example:
$.postCSRF('/form',{text:'hi'},function(res) {
console.log(res);
});

示例:http://jsfiddle.net/w7h4Lkxn/

关于node.js - 带有 jQ​​uery Ajax 的 Express.js csrf token ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33628343/

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