egg插件编写
发布于 7 年前 作者 dmodaii 3599 次浏览 来自 分享

代码地址 https://github.com/MoceptWeb/egg-passport-portal 看之前确定至少了解了egg的文档了, 不然看下面是浪费时间哈;本人只写了重点需要注意的地方!不对的地方请多多指教

npm包方式

如果代码还不完善还不想发布,可以直接在项目文件中 npm link npm包目录文件夹

package.json

name和eggPlugin字段

  "name": "@node/egg-passport-jyb",  // 包名
  "eggPlugin": {
    "name": "passportJyb"   这里是在egg中真正用到的name
  },

项目中使用插件和配置

  • {app_root}/app/config/plugin.js
  config.passportJyb = {
    'menu_code': 'loan_manage'
  };
  • {app_root}/app/config/config.{env}.js
exports.passportJyb = {
  enable: true,
  package: '@node/egg-passport-jyb'
};

npm中代码

extend

个人建议extend中的方法尽量当前插件相关的加前缀, 防止互相干扰

  • context.js 暴露方法给外部项目直接调用
  • helper.js 统一封装了内部请求和mysql连接(多数据和单数据库连接的区分),操作
  async passportMysqlConnect() {
    const portalConfig= this.app.config['passportJyb']
    let mysqlConnect = null;
    if(portalConfig.userDBClient) {
      mysqlConnect = this.app.mysql.get(portalConfig.userDBClient)
    } else {
      mysqlConnect = this.app.mysql
    } 
    if(!mysqlConnect) {
      this.ctx.logger.error('数据库连接数据');
    }
    return mysqlConnect;
  }

service

则是一些数据相关的操作

middleware

  • middleware位置 在app.js入口控制插件中的所有middleware执行顺序

当然可以加入配置项目, 指定在哪个外部项目中的middleware之后, 看各项目需求

module.exports = app => {
  // 将 static 中间件放到 bodyParser 之前
  const index = app.config.coreMiddleware.length;
  // const index = app.config.coreMiddleware.indexOf('bodyParser');
//   assert(index >= 0, 'bodyParser 中间件必须存在');

  app.config.coreMiddleware.splice(index, 0, 'passportJybAuth');
};

config

  • 配置noAuth正则url 在passportJybAuth中间件中 可以无需auth即可请求, 插件尽量可拓展
  • 以及登录后和单点(被动)登录后的跳转地址的配置
2 回复

个人建议extend中的方法尽量当前插件相关的加前缀, 防止互相干扰

挂一个你的对象,方法在它上面即可,如 app.passport.xx

@atian25 对, 应该加对象类似命名空间隔离啊! 谢谢

回到顶部