added code
This commit is contained in:
3
cors/README.md
Normal file
3
cors/README.md
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
# Related Blog Posts
|
||||||
|
|
||||||
|
* [Complete guide to CORS](https://reflectoring.io/complete-guide-to-cors/)
|
||||||
3
csrf/README.md
Normal file
3
csrf/README.md
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
# Related Blog Posts
|
||||||
|
|
||||||
|
* [Complete guide to CSRF](https://reflectoring.io/complete-guide-to-csrf/)
|
||||||
28
csrf/index.js
Normal file
28
csrf/index.js
Normal file
@@ -0,0 +1,28 @@
|
|||||||
|
const express = require('express');
|
||||||
|
const csrf = require('csurf');
|
||||||
|
const cookieParser = require('cookie-parser');
|
||||||
|
|
||||||
|
var csrfProtection = csrf({ cookie: true });
|
||||||
|
var parseForm = express.urlencoded({ extended: false });
|
||||||
|
|
||||||
|
var app = express();
|
||||||
|
app.set('view engine','ejs')
|
||||||
|
|
||||||
|
app.use(cookieParser());
|
||||||
|
|
||||||
|
app.get('/transfer', csrfProtection, function (req, res) {
|
||||||
|
// pass the csrfToken to the view
|
||||||
|
res.render('transfer', { csrfToken: req.csrfToken() });
|
||||||
|
});
|
||||||
|
|
||||||
|
app.post('/process', parseForm,
|
||||||
|
csrfProtection, function (req, res) {
|
||||||
|
res.send('Transfer Successful!!');
|
||||||
|
});
|
||||||
|
|
||||||
|
app.listen(3000, (err) => {
|
||||||
|
if (err) console.log(err);
|
||||||
|
console.log('Server listening on 3000');
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
23
csrf/package.json
Normal file
23
csrf/package.json
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
{
|
||||||
|
"name": "csrfapp",
|
||||||
|
"version": "1.0.0",
|
||||||
|
"description": "CSRF mitigation example",
|
||||||
|
"main": "index.js",
|
||||||
|
"scripts": {
|
||||||
|
"test": "echo \"Error: no test specified\" && exit 1"
|
||||||
|
},
|
||||||
|
"keywords": [
|
||||||
|
"csrf"
|
||||||
|
],
|
||||||
|
"author": "Pratik Das",
|
||||||
|
"license": "ISC",
|
||||||
|
"dependencies": {
|
||||||
|
"body-parser": "^1.19.0",
|
||||||
|
"cookie-parser": "^1.4.5",
|
||||||
|
"cookie-session": "^1.4.0",
|
||||||
|
"csurf": "^1.11.0",
|
||||||
|
"ejs": "^3.1.6",
|
||||||
|
"express": "^4.17.1",
|
||||||
|
"pug": "^3.0.2"
|
||||||
|
}
|
||||||
|
}
|
||||||
23
csrf/views/transfer.ejs
Normal file
23
csrf/views/transfer.ejs
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<title>CSRF Token Demo</title>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<form action="process" method="POST">
|
||||||
|
<input type="hidden" name="_csrf" value="<%= csrfToken %>">
|
||||||
|
<div>
|
||||||
|
<label>Amount:</label><input type="text" name="amount">
|
||||||
|
</div>
|
||||||
|
<br/>
|
||||||
|
<div>
|
||||||
|
<label>Transfer To:</label><input type="text" name="account">
|
||||||
|
</div>
|
||||||
|
<br/>
|
||||||
|
<div>
|
||||||
|
<input type="submit" value="Transfer">
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
|
|
||||||
|
|
||||||
Reference in New Issue
Block a user