搭建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
相关推荐
小雨下雨的雨1 天前
Flutter 框架跨平台鸿蒙开发 —— Icon 控件之图标交互美学
flutter·华为·交互·harmonyos·鸿蒙系统
小雨下雨的雨1 天前
Flutter 框架跨平台鸿蒙开发 —— Placeholder 控件之布局雏形美学
flutter·ui·华为·harmonyos·鸿蒙系统
行者961 天前
OpenHarmony Flutter弹出菜单组件深度实践:从基础到高级的完整指南
flutter·harmonyos·鸿蒙
前端不太难1 天前
Flutter / RN / iOS,在长期维护下的性能差异本质
flutter·ios
小雨下雨的雨1 天前
Flutter 框架跨平台鸿蒙开发 —— Padding 控件之空间呼吸艺术
flutter·ui·华为·harmonyos·鸿蒙系统
行者961 天前
Flutter到OpenHarmony:横竖屏自适应布局深度实践
flutter·harmonyos·鸿蒙
小雨下雨的雨1 天前
Flutter 框架跨平台鸿蒙开发 —— Align 控件之精准定位美学
flutter·ui·华为·harmonyos·鸿蒙
行者961 天前
Flutter与OpenHarmony集成:跨平台开关组件的实践与优化
flutter·harmonyos·鸿蒙
行者962 天前
Flutter适配OpenHarmony:国际化i18n实现中的常见陷阱与解决方案
开发语言·javascript·flutter·harmonyos·鸿蒙
wey6082 天前
fiuckjs 基于react的flutter动态化方案
flutter