1.新建一个jwttest.router.js
引入toast
const {success,fail} = require("../toast");
const jwt = require("jsonwebtoken");
const key="web";
module.exports = function (router){
router.post("/login",async ctx=>{
const {name,pwd} = ctx.request.body;
if(name==="admin" && pwd==="123456"){
const token = jwt.sign({name:"admin"},key,{expiresIn:300})
return success(ctx, "Bearer " + token);
}else{
return fail(ctx,"账号和密码不正确");
}
}).get("/data",async ctx=>{
return success(ctx,{});
})
};
在app.js中引入jwttest
// 引入类
const Koa =require('koa');
// 引入koa-router
const Router =require('koa-router');
// 引入koa-body
const koaBody=require('koa-body');
const tagRouter =require("./routers/tag.router");
const userRouter =require("./routers/user.router");
const contentRouter =require("./routers/content.router");
const jwtRouter =require("./routers/jwttest.router");
const {fail} = require("./toast");
const jwt = require("jsonwebtoken");
const key="web";
// 创建对象
const app =new Koa();
app.use(koaBody({
strict:false
}));
app.use(async (ctx,next) =>{
const exp = [
'/login',
'/',
'register',
]; //不需要验证的地址
if(exp.includes(ctx.url)){
await next();
return;
}
console.log(ctx.headers)
const authorization = ctx.headers.authorization;
if(!authorization){
return fail(ctx,"请添加 token 信息");
}
const token = authorization.split(' ')[1];
try{
const user =jwt.verify(token,key);
if(user.name==="admin"){
await next();
}else{
return fail(ctx,"权限不足");
}
}catch(error){
return fail(ctx,error);
}
})
const router =new Router({// 可以传递参数配置路由前缀
});
tagRouter(router);
userRouter(router);
contentRouter(router);
jwtRouter(router);
app.use(router.routes());
app.use(router.allowedMethods({
}));
// localhost:3000
app.listen(8000,()=>{
console.log("http://localhost:8000");
});
最后通过text.http查看是否显示正确
@url =http://localhost:8000
@json=Content-Type: application/json
@auth=Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJuYW1lIjoiYWRtaW4iLCJpYXQiOjE2Mzg1MjA5MDAsImV4cCI6MTYzODUyMTIwMH0.PAvCI6TsrzYs7_P4e4v_ieLlLJY-iT0ro42oTYFhV1Q
### 登录
POST {{url}}/login
{{json}}
{
"name":"admin",
"pwd":"123456"
}
### 获取数据
GET {{url}}/data
{{auth}}
### 查询
GET {{url}}/tag
{{auth}}
### 添加
POST {{url}}/tag
{{auth}}
{{json}}
#content
//表单方式
# id=1000&name="张三"
{
"text":"6234"
}
### 删除
DELETE {{url}}/tag
{{auth}}
{{json}}
{
"_id":"61a887ada8457be730ee21d6"
}
### content 查询
GET {{url}}/content
{{auth}}
### content 添加
POST {{url}}/content HTTP/1.1
{{auth}}
{{json}}
{
"title":"孤独的根号三",
"content":"一个孤独的根号三七八九"
}
### 删除
DELETE {{url}}/content
{{auth}}
{{json}}
{
"_id":"61a889f2116f2745d91ff7e6"
}
### 修改
PUT {{url}}/content?_id=61a88dcf1509ffac77824c93
{{auth}}
{{json}}
{
"top":"true"
}
### user 查询
GET {{url}}/user HTTP/1.1
{{auth}}
### user 添加
POST {{url}}/user HTTP/1.1
{{auth}}
{{json}}
{
"name":"小明",
"password":"12233yfr",
"email":"1637743640@qq.com",
"namegrop":"限制会员"
}
### user删除
DELETE {{url}}/user
{{auth}}
{{json}}
{
"_id":"61a88c540d6c4ff5952338c6"
}
### user修改
PUT {{url}}/user?_id=61a88df389ca9f8a670616ef
{{auth}}
{{json}}
{
"name":"小红"
}
- easyui+nodejs+sqlserver增删改查实现
用到的模块或者技术: Express: http://www.expressjs.com.cn/4x/api.html#express Easyui: http://www.jeasyui.com/d ...
- nodejs+express+mysql 增删改查
之前,一直使用的是nodejs+thinkjs来完成自己所需的项目需求,而对于nodejs中另外一中应用框架express却了解的少之又少,这两天就简单的了解了一下如何使用express来做一些数据库 ...
- nodejs+express+mysql实现restful风格的增删改查示例
首先,放上项目github地址:https://github.com/codethereforam/express-mysql-demo 一.前言 之前学的java,一直用的ssm框架写后台.前段时间 ...
- nodejs+express+mysql 增删改查(二)
1.最早一篇关于express框架简单的增删改查文章,http://www.cnblogs.com/zhengyeye/p/nodejs.html#3947308:意外走红博客园,无奈自己之前一直没有 ...
- nodejs对mongodb数据库的增删改查操作(转载)
首先要确保mongodb的正确安装,安装参照:http://docs.mongodb.org/manual/tutorial/install-mongodb-on-debian-or-ubuntu-l ...
- 进入全屏 nodejs+express+mysql实现restful风格的增删改查示例
首先,放上项目github地址:https://github.com/codethereforam/express-mysql-demo 一.前言 之前学的java,一直用的ssm框架写后台.前段时间 ...
- 69.nodejs对mongodb数据库的增删改查操作
转自:https://www.cnblogs.com/sexintercourse/p/6485381.html 首先要确保mongodb的正确安装,安装参照:http://docs.mongodb. ...
- 使用nodejs连接mysql数据库实现增删改查
首先要有数据库 使用xampp 或者 phpstudy 可以傻瓜式安装 新建一个项目文件夹 之后在这个目录下初始化package.json (npm init) 先在项目中安装mysql 和 ex ...
- 基于nodejs+express+mysql+webstorm+html的 增删改查
一.工具准备 Nodejs框架,WebStorm.Mysql服务.Navicat.此篇文章只讲项目的搭建过程,至于Nodejs,WebStorm.Mysql的下载.安装与配置网上资源很多,请自行查阅, ...
- 简单实现 nodejs koa2 mysql 增删改查 制作接口
1.首先 在电脑上安装 nodejs (此处略过) 2.全局安装 koa2 (这里使用的淘宝镜像cnpm,有兴趣的同学可以自行搜索下) cnpm install koa-generator -g 3. ...
随机推荐
- 远程过程调用失败0x800706be
今天用数据库突然发生了<远程过程调用失败0x800706be>,参考一下网站解决 https://www.cnblogs.com/guohenghai/p/3533091.html 今天在 ...
- JIT和AOT的区别
http://net-informations.com/faq/qk/jit.htm Compilers are tools that convert human readable text into ...
- PaddlePaddleOCR安装教程
1.首先下载并安装python3.7.8 链接地址: 注:安装时Add path勾选 2.进入命令提示符界面 3.升级pip版本 python -m pip install --upgrade pip ...
- Jmeter接口测试+Jmeter性能测试项目实战+Jmeter性能监控分析调优01
Jmeter P1 性能测试关键指标 1,这些指标大家看到后有什么感觉呢?对于功能测试,一般结果就两种,成功的或者是不通过的,有问题的和没问题的,有毛病的和没毛病的,比如打开网页,能打开就打开,打不开 ...
- Abp框架使用Swgger注释加分组
1.在ConfigureSwaggerServices中配置SwaggerDoc,并options.DocInclusionPredicate((doc, desc) => { return d ...
- 前端vue的JsPDF html2canvas 生成pdf并以文件流形式上传到后端(转载)
原文地址 1.首先在文件内引入htmlToPdf.js这里代码引入了html2canvas和jspdf//需要 npm i html2Canvas 和 npm i jspdf 在这里将getPdf 这 ...
- (四)kafka基础术语
1 Topic Kafka消息分类的标签,是一个逻辑概念. 2 Partion 主题作为消息的归类,可以细分为一个或多个分区,分区可以看做是对消息的二次归类.分区可以有一个至多个副本,每个副本对应一个 ...
- NPOI 导出 EXCEL
1. 2.创建NPOIHelper using System;using System.Collections.Generic;using System.Data;using System.IO;us ...
- [NepCTF2022]中学数学
中学数学 p.q挣扎很久没分解出来,wp出来了赶紧复现试试. 题目 from gmpy2 import * from Crypto.Util.number import * from secret i ...
- ZIP文件操作工具类
2 3 import lombok.extern.slf4j.Slf4j; 4 import org.apache.commons.io.FilenameUtils; 5 6 import java. ...