插件使用文档
import cors from "@fastify/cors";
fastify.register(cors, (instance) => {
return (req, callback) => {
const hostIp = getClientIp(req);
if (/^127.0.0.1$/m.test(hostIp)) {
callback('not Allow', {
origin: false,
});
}
callback(null, {
origin: true,
});
};
});
fastify.register(AutoLoad, {
dir: path.join(__dirname, "plugins"),
});
fastify.register(AutoLoad, {
dir: path.join(__dirname, "routes"),
options: { prefix: "/api" },
});
fasttify的重要安全标头。
nodejs提高工程安全、效率相关的中间件
Helmet是一系列帮助增强Node.JS之Express/Connect等Javascript Web应用安全的中间件。
一些著名的对Web攻击有XSS跨站脚本, 脚本注入 clickjacking 以及各种非安全的请求等对Node.js的Web应用构成各种威胁,使用Helmet能帮助你的应用避免这些攻击。
crossdomain是用来服务crossdomain.xml
contentSecurityPolicy是设置Content Security Policy,防止XSS攻击。
hidePoweredBy可以移除 X-Powered-By 头部
hsts用于 HTTP Strict Transport Security
ieNoOpen设置IE8+的 sets X-Download-Options
noCache 失效客户端缓存
noSniff能避免客户端进行MIME类型进行嗅探。
frameguard阻止clickjacking
xssFilter能够增加一些小的XSS保护功能。
npm i @fastify/helmet
import helmet from '@fastify/helmet'
fastify.register(helmet)
// or
fastify.register(helmet, { global: true })
下面代码中:
const express = require('express');
const csrf = require('csurf');
const cookieParser = require('cookie-parser');
const bodyParser = require('body-parser');
var csrfProtection = csrf({ cookie: true });
var parseForm = bodyParser.urlencoded({ extended: false });
var app = express();
app.set('view engine','ejs')
app.use(cookieParser());
app.get('/form', csrfProtection, function (req, res) {
// pass the csrfToken to the view
res.render('login', { csrfToken: req.csrfToken() });
});
app.post('/process', parseForm,
csrfProtection, function (req, res) {
res.send('Successfully Validated!!');
});
app.listen(3000, (err) => {
if (err) console.log(err);
console.log('Server Running');
});
欢迎大家指出文章需要改正之处~
学无止境,合作共赢