- hapi 框架,用官网的简介来说就是:Hapi 是构建应用程序和服务的丰富框架,它使开发人员能够专注于编写可重用的应用程序逻辑,而不是花时间构建基础设施。
- 用自己的话简单来说,就是个类似 express,koa 之类的 node 服务基础框架。
- 此篇博客是在阅读过掘金小册的《基于 hapi 的 Node.js 小程序后端开发实践指南》并实践操作后,以此记录实践过程和踩过的坑。感兴趣读者可支持阅读掘金小册原版的内容。
第一个 helloworld
1. 在新建项目目录中初始化配置文件
npm init
2. 安装 hapi
npm i hapi
3. 全局安装热部署工具 supervisor(类似 nodemon)
npm install supervisor -g
4. 新建 app.js,可从官网案例中抄示例代码
'use strict';
const Hapi = require('hapi');
const init = async () => {
const server = Hapi.server({
port: 3000,
host: 'localhost'
});
server.route({
method: 'GET',
path:'/',
handler: (request, h) => {return 'Hello World!';}
});
await server.start();
console.log('Server running on %ss', server.info.uri);
};
process.on('unhandledRejection', (err) => {console.log(err);
process.exit(1);
});
init();
5. 终端运行项目
6. 浏览器测试效果
目录结构划分
(PS: 根据需要可以将业务逻辑代码再划分到 controllers 层)
├── config # 项目配置目录
├── logs # 输出日志
├── migrations # 创建数据库文件
├── models # 数据库 model
├── node_modules # node.js 的依赖目录
├── plugins # 插件目录
├── routes # 路由目录
├── seeders # 初始化表数据文件
├── test # 测试类
├── utils # 工具类相关目录
├── .env # 配置文件
├── app.js # 项目入口文件
├── package.json # JS 项目工程依赖库
├── readme.md # 项目工程如何被使用的说明手册
配置全局环境信息
1. env 配置示例
配置 env 的意义在于,不同的环境下域名数据库等信息不一定一致,通过配置手段加载读取更灵活。同时全局环境直接获取。
# 域名配置信息
HOST = 127.0.0.1
PORT = 3303
# MySQL 数据库连接配置信息
MYSQL_HOST = 127.0.0.1
MYSQL_PORT = 3306
MYSQL_DB_NAME = database_name
MYSQL_USERNAME = database_username
MYSQL_PASSWORD = database_password
# JWT 自定义 secret
JWT_SECRET = your_secret
# 微信小程序配置
WX_APPID = your-app-id # 微信小程序 appid
WX_SECRET = your-secret # 微信小程序密码
WX_MCHID = your-mchid # 支付商户号
WX_PAY_API_KEY = your-pay-api-key # 微信支付的 api key
2. 安装 env2
通过此依赖可在 js 代码中直接读取.env 配置的参数信息(如:读取端口号 process.env.PORT)
npm i env2
3. 示例获取
4. 效果