Csrf
CSRF tokens for koa
Install / Use
/learn @koajs/CsrfREADME
koa-csrf
CSRF tokens for Koa
NOTE: As of v5.0.0+
ctx.csrf,ctx_csrf, andctx.response.csrfare removed – instead usectx.state._csrf. Furthermore we have droppedinvalidTokenMessageandinvalidTokenStatusCodein favor of anerrorHandlerfunction option.
Table of Contents
Install
npm:
npm install koa-csrf
Usage
-
Add middleware in Koa app (see options below):
const Koa = require('koa'); const bodyParser = require('koa-bodyparser'); const session = require('koa-generic-session'); const convert = require('koa-convert'); const CSRF = require('koa-csrf'); const app = new Koa(); // set the session keys app.keys = [ 'a', 'b' ]; // add session support app.use(convert(session())); // add body parsing app.use(bodyParser()); // add the CSRF middleware app.use(new CSRF()); // your middleware here (e.g. parse a form submit) app.use((ctx, next) => { if (![ 'GET', 'POST' ].includes(ctx.method)) return next(); if (ctx.method === 'GET') { ctx.body = ctx.state._csrf; return; } ctx.body = 'OK'; }); app.listen(); -
Add the CSRF token in your template forms:
Jade Template:
form(action='/register', method='POST') input(type='hidden', name='_csrf', value=_csrf) input(type='email', name='email', placeholder='Email') input(type='password', name='password', placeholder='Password') button(type='submit') RegisterEJS Template:
<form action="/register" method="POST"> <input type="hidden" name="_csrf" value="<%= _csrf %>" /> <input type="email" name="email" placeholder="Email" /> <input type="password" name="password" placeholder="Password" /> <button type="submit">Register</button> </form>
Options
errorHandler(Function) - defaults to a function that returnsctx.throw(403, 'Invalid CSRF token')excludedMethods(Array) - defaults to[ 'GET', 'HEAD', 'OPTIONS' ]disableQuery(Boolean) - defaults tofalseignoredPathGlobs(Array) - defaults to an empty Array, but you can pass an Array of glob paths to ignore
Contributors
| Name | Website | | --------------- | --------------------------------- | | Nick Baugh | https://github.com/niftylettuce | | Imed Jaberi | https://www.3imed-jaberi.com/ |
License
Related Skills
node-connect
344.1kDiagnose OpenClaw node connection and pairing failures for Android, iOS, and macOS companion apps
frontend-design
96.8kCreate distinctive, production-grade frontend interfaces with high design quality. Use this skill when the user asks to build web components, pages, or applications. Generates creative, polished code that avoids generic AI aesthetics.
openai-whisper-api
344.1kTranscribe audio via OpenAI Audio Transcriptions API (Whisper).
qqbot-media
344.1kQQBot 富媒体收发能力。使用 <qqmedia> 标签,系统根据文件扩展名自动识别类型(图片/语音/视频/文件)。
