搭建Flutter本地私有库

一、下载mongodb

| 📌

需要下载6.x.x版本以下,否则会报错

历史版本下载链接:https://www.mongodb.com/try/download/community-edition/releases/archive

假设下载后放到:/usr/local/

二、配置环境变量

~/.bash_profile~/.zshrc中添加如下

bash 复制代码
# mongodb
export PATH="/usr/local/mongodb-macos-x86_64-5.0.31/bin:$PATH"

操作完记得sorce

bash 复制代码
source ~/.bash_profile && source ~/.zshrc

三、启动mongodb服务

1. 创建目录

bash 复制代码
/usr/local/var/mongodb/、/usr/local/var/log/mongodb/

2. 开启服务

  1. 命令行输入mongod --dbpath /usr/local/var/mongodb --logpath /usr/local/var/log/mongodb/mongo.log
  2. 新开命令行输入:mongo

四、安装unpub

1. 下载unpub

bash 复制代码
flutter pub global activate unpub

2. 去掉unpub的google校验

需修改的文件路径:~/.pub-cache/hosted/pub.dev/unpub-2.1.0/lib/src/app.dart

需要将调用_getUploaderEmail的地方去掉,一共三处。

  1. L241修改成如下
dart 复制代码
  @Route.post('/api/packages/versions/newUpload')
  Future<shelf.Response> upload(shelf.Request req) async {
    try {
      // var uploader = await _getUploaderEmail(req);
      var uploader = "";
  1. L366修改成如下
dart 复制代码
  @Route.post('/api/packages/<name>/uploaders')
  Future<shelf.Response> addUploader(shelf.Request req, String name) async {
    var body = await req.readAsString();
    var email = Uri.splitQueryString(body)['email']!; // TODO: null
    // var operatorEmail = await _getUploaderEmail(req);
    // var package = await metaStore.queryPackage(name);

    // if (package?.uploaders?.contains(operatorEmail) == false) {
    //   return _badRequest('no permission', status: HttpStatus.forbidden);
    // }
    // if (package?.uploaders?.contains(email) == true) {
    //   return _badRequest('email already exists');
    // }

    await metaStore.addUploader(name, email);
    return _successMessage('uploader added');
  }
  1. L384修改成如下
dart 复制代码
  @Route.delete('/api/packages/<name>/uploaders/<email>')
  Future<shelf.Response> removeUploader(
      shelf.Request req, String name, String email) async {
    email = Uri.decodeComponent(email);
    // var operatorEmail = await _getUploaderEmail(req);
    // var package = await metaStore.queryPackage(name);

    // TODO: null
    // if (package?.uploaders?.contains(operatorEmail) == false) {
      return _badRequest('no permission', status: HttpStatus.forbidden);
    // }
    // if (package?.uploaders?.contains(email) == false) {
    //   return _badRequest('email not uploader');
    // }

    await metaStore.removeUploader(name, email);
    return _successMessage('uploader removed');
  }

3. 启动unpub

mongod --dbpath /usr/local/var/mongodb --logpath /usr/local/var/log/mongodb/mongo.log

只要有这个输出,则代表成功

bash 复制代码
Serving at http://0.0.0.0:4000

4. 访问

地址:http:localhost:4000
| 📌

最好用Chrome访问

五、推送本地插件到私有库

pubspec.yaml中添加如下:

yaml 复制代码
publish_to: http://localhost:4000

六、使用私有库插件

yaml 复制代码
test_pub_plugin:
    hosted:
      name: test_pub_plugin
      url: http://localhost:4000
    version: ^0.0.1
相关推荐
ujainu1 小时前
Flutter + OpenHarmony 实现经典打砖块游戏开发实战—— 物理反弹、碰撞检测与关卡系统
flutter·游戏·openharmony·arkanoid·breakout
微祎_2 小时前
构建一个 Flutter 点击速度测试器:深入解析实时交互、性能度量与响应式 UI 设计
flutter·ui·交互
王码码20352 小时前
Flutter for OpenHarmony 实战之基础组件:第二十七篇 BottomSheet — 动态底部弹窗与底部栏菜单
android·flutter·harmonyos
ZH15455891312 小时前
Flutter for OpenHarmony Python学习助手实战:Web开发框架应用的实现
python·学习·flutter
晚霞的不甘2 小时前
Flutter for OpenHarmony 构建简洁高效的待办事项应用 实战解析
flutter·ui·前端框架·交互·鸿蒙
百锦再3 小时前
Vue高阶知识:利用 defineModel 特性开发搜索组件组合
前端·vue.js·学习·flutter·typescript·前端框架
廖松洋(Alina)3 小时前
【收尾以及复盘】flutter开发鸿蒙APP之成就徽章页面
flutter·华为·开源·harmonyos·鸿蒙
ZH15455891314 小时前
Flutter for OpenHarmony Python学习助手实战:机器学习算法实现的实现
python·学习·flutter
廖松洋(Alina)4 小时前
【收尾以及复盘】flutter开发鸿蒙APP之打卡日历页面
flutter·华为·开源·harmonyos·鸿蒙
廖松洋(Alina)4 小时前
【收尾以及复盘】flutter开发鸿蒙APP之本月数据统计页面
flutter·华为·开源·harmonyos·鸿蒙