小天管理 发表于 2024年9月30日 发表于 2024年9月30日 什么是 fast-qjs ?它能做什么? fast-qjs 是一个基于 fastify 框架使用约定式进行路由约束的轻量框架,完全继承 fastfiy 的优点,当你想要快速实现一个功能模块的 crud ,那么 fast-qjs 就能让你在 10 分钟以内完成 fast-qjs 优点: 内置数据库:无需繁琐的数据库配置,即可直接使用。 集成 JWT:方便且安全的用户身份验证功能。 便捷的文件上传接口:轻松处理文件,自动化存储管理。 公共目录支持:提供静态资源的管理和访问。 约定式路由管理:简洁的路由设置,高效的资源调度。 项目地址:fast-qjs 下面以 fast-qjs 提供的files接口进行一个案例 第一步,确保已经安装了nodejs,终端运行: npx create-qjs qjs-app 执行成功你将看到如下项目结构 qjs-app/ ├── node_modules/ # 依赖包目录 │ ├── package.json # 项目配置文件 │ ├── package-lock.json # 依赖版本信息 紧接着执行下面的命令 cd qjs-app && npm run start 执行完你将看到如下结构 qjs-app/ │ ├── db/ │ ├── functions/ │ ├── public/ │ ├── node_modules/ │ ├── package.json │ ├── package-lock.json 现在进入functions目录,你将看到一个默认的qjs.mjs文件,根据终端提示你的项目运行在http://localhost:5173。紧接着你的 api 已经创建,浏览器访问 http://localhost:5173/api/qjs 你将看 qjs.mjs 默认插入数据库的信息 我们打开qjs.mjs文件你将看到如下信息: // functions/qjs.mjs // @see https://github.com/allmors/qjs/ // import qjs from '@allmors/qjs/core'; export default async function (params, ctx) { // const User = await qjs.db.collection('user'); // const user = await User.insertOne({ name: "Sam", email: 'sam@codingsamrat.com' }) // or const User = await this.db.collection('user'); const user = await User.insertOne({ name: "Sam", email: 'sam@codingsamrat.com' }) // ...... return ctx.reply.send({ message: 'Hello from qjs API', method: context.method, params: { ...user } }); } 默认代码不用管,直接粘贴下面代码全部替换 export default async function (params, ctx) { try { const { file } = params let result = {} if (ctx.method === 'POST') { const res = await this.files.upload(file) result = res } return ctx.reply.send({ message: 'Hello from qjs API', method: ctx.method, result: result }); } catch (error) { throw new Error(error) } } 现在打开 apifox 或者其它工具,我以 apifox 为例 现在你的文件上传接口已经开发完成,回到你的项目目录你将会看到uploads,里面就是你上传的文件,你可用通过 nginx 获取 caddy 反代该目录即可访问你的文件,当然了,如果你不想这么麻烦,那么,修改 package.json 中如下配置: 找到QJS_STATIC,把QJS_STATIC修改为uploads即可,然后访问:http:0.0.0.0:5173/public/你的 uploads 目录里面的文件名 比如:http://0.0.0.0:5173/public/61f1adee-08ea-45-1727658693615/deKGMl9.jpg 更多信息请查阅文档fast-qjs
已推荐帖子