今回は、ルーティング認証のための nuxt フレームワークの操作と、Koa と Session の使用方法を説明します。 ルーティング認証のための nuxt フレームワークの操作と、Koa と Session を使用する際の 注意事項 は何ですか? 以下は実践的なケースです。 、一緒に見てみましょう。
はじめに
ブログのバックエンド管理ページにはログインシステムが必要なので、ルーティング認証を行うことを検討してください。 ちなみに、実装方法もNuxt公式サイトに記載されているものから書き換えています。フロントエンドとバックエンドのルーティングも統合されています。ルートインターセプト
フロントエンドは主にNuxtのミドルウェアを使用してルートインターセプトを行います。ここではVuexステートツリーも必要です。
ミドルウェア
middleware/auth.jsexport default function ({ store, redirect }) { if (!store.state.user) { return redirect('/login') } }
export default { middleware: 'auth', components: { AdminAside } }
nuxtServerInit
NuxtJsのレンダリング処理では、リクエストが来ると最初にnuxtServerInitメソッドが呼び出され、このメソッドを通じてサーバーデータを事前に保存することができます。 このメソッドを使用して、ユーザー情報を格納するセッション情報を受信できます。nuxtServerInit ({ commit }, { req, res }) { if (req.session && req.session.user) { const { username, password } = req.session.user const user = { username, password } commit('SET_USER', user) } },
Koa と koa- を使用します。 session
Koa と koa-session
バックエンド コードでは、Koa フレームワークと koa-session を使用してセッションを処理します。 新しい nuxt プロジェクトを作成するときに、Koa フレームワークを直接使用できますvue init nuxt/koa
npm install koa-session
import Koa from 'koa' import { Nuxt, Builder } from 'nuxt' // after end import session from 'koa-session' async function start () { const app = new Koa() const host = process.env.HOST || '127.0.0.1' const port = process.env.PORT || 7998 // Import and Set Nuxt.js options let config = require('../nuxt.config.js') config.dev = !(app.env === 'production') // Instantiate nuxt.js const nuxt = new Nuxt(config) // Build in development if (config.dev) { const builder = new Builder(nuxt) await builder.build() } // body-parser app.use(bodyParser()) // mongodb // session app.keys = ['some session'] const CONFIG = { key: 'SESSION', /** (string) cookie key (default is koa:sess) */ /** (number || 'session') maxAge in ms (default is 1 days) */ /** 'session' will result in a cookie that expires when session/browser is closed */ /** Warning: If a session cookie is stolen, this cookie will never expire */ maxAge: 86400000, overwrite: true, /** (boolean) can overwrite or not (default true) */ httpOnly: true, /** (boolean) httpOnly or not (default true) */ signed: true, /** (boolean) signed or not (default true) */ rolling: false /** (boolean) Force a session identifier cookie to be set on every response. The expiration is reset to the original maxAge, resetting the expiration countdown. default is false **/ } app.use(session(CONFIG, app)) // routes app.use(async (ctx, next) => { await next() ctx.status = 200 // koa defaults to 404 when it sees that status is unset return new Promise((resolve, reject) => { ctx.res.on('close', resolve) ctx.res.on('finish', resolve) nuxt.render(ctx.req, ctx.res, promise => { // nuxt.render passes a rejected promise into callback on error. promise.then(resolve).catch(reject) }) }) }) app.listen(port, host) console.log('Server listening on ' + host + ':' + port) // eslint-disable-line no-console } start()
ログインルーティング
// 登录 router.post('/api/login', async (ctx, next) => { const { username, password } = ctx.request.body let user, match try { user = await Admin.findOne({ user: username }).exec() if (user) { match = await user.comparePassword(password, user.password) } } catch (e) { throw new Error(e) } if (match) { ctx.session.user = { _id: user._id, username: user.user, nickname: user.nickname, role: user.role } console.log(ctx.session) return (ctx.body = { success: true, data: { username: user.user, nickname: user.nickname } }) } return (ctx.body = { success: false, err: '密码错误' }) })
sessionが定義されていません
問題nuxtServerInit ({ commit }, { req, res }) { if (req.session && req.session.user) { // res.session is not defined const { username, password } = req.session.user const user = { username, password } commit('SET_USER', user) } }
理由
公式ウェブサイトで示されているように、最後の問題は依然として私の不注意といくつかの詳細の無視によるものです:app.post('/api/login', function (req, res) { if (req.body.username === 'demo' && req.body.password === 'demo') { req.session.authUser = { username: 'demo' } return res.json({ username: 'demo' }) } res.status(401).json({ error: 'Bad credentials' }) })
解決策
そのため、nuxt.render を挿入するときに、リクエストにセッションを追加しますapp.use(async (ctx, next) => { await next() ctx.status = 200 // koa defaults to 404 when it sees that status is unset ctx.req.session = ctx.session return new Promise((resolve, reject) => { ctx.res.on('close', resolve) ctx.res.on('finish', resolve) nuxt.render(ctx.req, ctx.res, promise => { // nuxt.render passes a rejected promise into callback on error. promise.then(resolve).catch(reject) }) }) })
以上がルーティング認証のためのnuxtフレームワークの操作方法とKoaとSessionの使用方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。