热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Koa&Mongoose&Vue实现前后端分离04注册&登录:用户路由配置

上节回顾mongoose工作内容后端:路由拦截Postman:测试接口准备工作npmi-S@koarouter安装路由路由拦截基本用法修改文件:serverapp.jsconstk


上节回顾


mongoose

工作内容



  • 后端:路由拦截

  • Postman:测试接口


准备工作



  • npm i -S @koa/router //安装路由


路由拦截


基本用法


// 修改文件:/server/app.js
const koa = require('koa');
const Router = require('@koa/router'); //引入NPM包
const router = new Router() // 创建实例
const app = new koa();
app.use((ctx, next) => {
ctx.body = '测试测试测试'; //该中间件任何时候都会走,GET请求'/'路径时,返回被后续的返回覆盖了,所以,没有展示。
next();
})
router.get('/', (ctx, next) => { //拦截GET访问'/'路径的请求
ctx.body = `访问路径:${ctx.originalUrl}`
});
app
.use(router.routes())
.use(router.allowedMethods()); // 嵌入中间件
app.on('error', err => {
log.error('server error', err)
});
module.exports = app;

nodemon 配置的 launch.json 运行



浏览器输入 localhost:3000localhost:3000/any 查看输出结果。


优化代码


这里希望将所有的路由配置提取到 /server/router 文件中(注意还原 /server/app.js )。


// 新建文件:/server/control/users.js————预定义处理路由处理函数
async function list (ctx) {
ctx.body = 'list'
}
async function register (ctx) {
ctx.body = 'register'
}
async function login (ctx) {
ctx.body = 'login'
}
async function update (ctx) {
ctx.body = 'update'
}
module.exports = {
list,
register,
login,
update
}

// 新建文件:/server/router/users.js
const Router = require('@koa/router');
const routerUtils = require('../utils/router');
const { list, register, login, update } = require('../control/users');
const router = new Router({
prefix: '/users' //路由前缀,该文件下的路由路径,追加'/users'为前缀
});
// 配置路由
const routes = [
{
path: '/',
method: 'GET',
handle: list
},
{
path: '/',
method: 'POST',
handle: login
},
{
path: '/:id',
method: 'PATCH',
handle: update
},
];
routerUtils.register.call(router, routes); // 注册路由
module.exports = router; //导出User的路由实例

// 新建文件:/server/utils/router.js
function register(routes) {
// 转换为'@koa/router'拦截路由的形式:router.get(, )
routes.forEach((route, idx) => {
const { path, method, handle } = route;
this[method.toLowerCase()](path, async (ctx, next) => {
await handle(ctx);
})
})
}
module.exports = {
register,
}

// 新建文件:/server/router/index.js
const userRouter = require('./users');
// 导出User路由相关的中间件,后续可追加其它的中间件
module.exports = [
userRouter.routes(),
userRouter.allowedMethods()
];

// 更新文件:/server/app.js
const koa = require('koa');
const routes = require('./router');
const app = new koa();
app.use((ctx, next) => {
ctx.body = '测试测试测试';
next();
})
//中间件: 路由 --> 不支持一次性注册多个中间件
// app.use(...router.routes).use(...router.allowedMethods);
routes.forEach(route => {
app.use(route);
});
app.on('error', err => {
log.error('server error', err)
});
module.exports = app;

Postman测试接口



  • 可以建立一个文件夹存放同系列的请求,也可以直接新建一个请求





  • 测试Get请求/users接口

  • 可以通过断点查看拦截请求


参考文档


@koa/router




推荐阅读
  • VueCLI多页分目录打包的步骤记录
    本文介绍了使用VueCLI进行多页分目录打包的步骤,包括页面目录结构、安装依赖、获取Vue CLI需要的多页对象等内容。同时还提供了自定义不同模块页面标题的方法。 ... [详细]
  • vue使用
    关键词: ... [详细]
  • 本文讨论了在Windows 8上安装gvim中插件时出现的错误加载问题。作者将EasyMotion插件放在了正确的位置,但加载时却出现了错误。作者提供了下载链接和之前放置插件的位置,并列出了出现的错误信息。 ... [详细]
  • 本文介绍了PE文件结构中的导出表的解析方法,包括获取区段头表、遍历查找所在的区段等步骤。通过该方法可以准确地解析PE文件中的导出表信息。 ... [详细]
  • PHP反射API的功能和用途详解
    本文详细介绍了PHP反射API的功能和用途,包括动态获取信息和调用对象方法的功能,以及自动加载插件、生成文档、扩充PHP语言等用途。通过反射API,可以获取类的元数据,创建类的实例,调用方法,传递参数,动态调用类的静态方法等。PHP反射API是一种内建的OOP技术扩展,通过使用Reflection、ReflectionClass和ReflectionMethod等类,可以帮助我们分析其他类、接口、方法、属性和扩展。 ... [详细]
  • 前段时间做一个项目,需求是对每个视频添加预览图,这个问题最终选择方案是:用canvas.toDataYRL();来做转换获取视频的一个截图,添加到页面中,达到自动添加预览图的目的。 ... [详细]
  • 本文介绍了一个Magento模块,其主要功能是实现前台用户利用表单给管理员发送邮件。通过阅读该模块的代码,可以了解到一些有关Magento的细节,例如如何获取系统标签id、如何使用Magento默认的提示信息以及如何使用smtp服务等。文章还提到了安装SMTP Pro插件的方法,并给出了前台页面的代码示例。 ... [详细]
  • 一、路由首先需要配置路由,就是点击good组件进入goodDetail组件配置路由如下{path:goodDetail,component:goodDetail}同时在good组件中写入如下点击事件,路由中加入 ... [详细]
  • 在本教程中,我们将看到如何使用FLASK制作第一个用于机器学习模型的RESTAPI。我们将从创建机器学习模型开始。然后,我们将看到使用Flask创建AP ... [详细]
  • ReactJSUIAnt设计空组件原文:https://w ... [详细]
  • sklearn数据集库中的常用数据集类型介绍
    本文介绍了sklearn数据集库中常用的数据集类型,包括玩具数据集和样本生成器。其中详细介绍了波士顿房价数据集,包含了波士顿506处房屋的13种不同特征以及房屋价格,适用于回归任务。 ... [详细]
  • 本文详细介绍了Android中的坐标系以及与View相关的方法。首先介绍了Android坐标系和视图坐标系的概念,并通过图示进行了解释。接着提到了View的大小可以超过手机屏幕,并且只有在手机屏幕内才能看到。最后,作者表示将在后续文章中继续探讨与View相关的内容。 ... [详细]
  • node.jsrequire和ES6导入导出的区别原 ... [详细]
  • Python已成为全球最受欢迎的编程语言之一,然而Python程序的安全运行存在一定的风险。本文介绍了Python程序安全运行需要满足的三个条件,即系统路径上的每个条目都处于安全的位置、"主脚本"所在的目录始终位于系统路径中、若python命令使用-c和-m选项,调用程序的目录也必须是安全的。同时,文章还提出了一些预防措施,如避免将下载文件夹作为当前工作目录、使用pip所在路径而不是直接使用python命令等。对于初学Python的读者来说,这些内容将有所帮助。 ... [详细]
  • Vue基础一、什么是Vue1.1概念Vue(读音vjuː,类似于view)是一套用于构建用户界面的渐进式JavaScript框架,与其它大型框架不 ... [详细]
author-avatar
危亚丽
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有