• 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.1PORT = 3303# MySQL 数据库连接配置信息MYSQL_HOST = 127.0.0.1MYSQL_PORT = 3306MYSQL_DB_NAME = database_nameMYSQL_USERNAME = database_usernameMYSQL_PASSWORD = database_password# JWT 自定义secretJWT_SECRET = your_secret# 微信小程序配置WX_APPID = your-app-id # 微信小程序appidWX_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.效果