美文网首页
【原创】flutter之发布插件包到pub.dev离线在线两套大

【原创】flutter之发布插件包到pub.dev离线在线两套大

作者: 吉凶以情迁 | 来源:发表于2022-03-05 22:30 被阅读0次

    发布何种包?

    首先 包分2种一种是纯dart包,不包含android. ios桥接代码, 另外一种 是 插件包,根据需求创建不同的包
    (模块是另外一种,主要是用于安卓引用flutter模块的,是需要指定ios android包名的,因为它直接运行的时候会产生临时的.android文件夹来配置一个包名,而且clear会删掉缓存。)


    image.png

    创建插件

    在android studio 配置了flutter插件后可以看到 plugin和package, 对应android ios这种需要桥接的模板,和 纯package包。
    选择下一步就行了。

    首先在根目录配置插件,其实也是正常的写代码,把类创建好,main.dart可删除,

    创建子项目(案例)

    然后再基于此目录flutter create example 创建样例文件夹
    然后在里面的main.dart写上代码

    在此exmaple的pubspec.yaml引用根目录(插件)

    dependencies:
      smart_gridded_pageview:
        path: ../
    

    当然如果你觉得这样蛋疼你可以复制同样的代码到里面写,但是你不觉得这样很奇怪吗?
    或者你觉得这个包一定会发布,你直接先在线引用写死也行,当然这些方法统统不方便,加入你升级版本呢?

    插件种引用其他插件?

    同样在根目录的yaml下插入即可

    dependencies:
    

    包名版本

    name: smart_gridded_pageview
    description: Automatically wrap the content, produce the height according to the content, and support page turning custom indicator
    version: 0.0.3
    homepage: https://https://github.com/qssq/smart_grid_pageview
    

    hompage最好指定源码目录,方便用户定位反馈。

    图片显示

    在插件目录也就是根目录结构的Readme.md里面

    的图片要正常显示不能使用相对路径,所以我发布了2次都无法显示图片,所以我直接用github的图片作为显示

    https://raw.githubusercontent.com/qssq/smart_grid_pageview/master/example/assets/pic.png
    

    预发布

    flutter pub publish --dry-run -v --server=https://pub.dartlang.org
    不会真正发布,但是会检测是否有一些错误问题

    发布包到pub.dev

    1.如果你能在命令行ping 通google.com则不需要设置代理。

    2.记得修改代码
    LICENSE里面的TODO无论如何都必须干掉,
    3.如果ping不同google.com则设置http代理
    window mac linux 都类似,下面是window的方法,linux方法也是设置变量名http_proxy 和https_proxy window应该不区分大小写的,

    set HTTP_PROXY=127.0.0.1:1080
    set HTTPS_PROXY=127.0.0.1:1080
    

    window shell

    $Env:http_proxy="http://127.0.0.1:1080";$Env:https_proxy="http://127.0.0.1:1080"
    

    执行发布
    【本地发布法】
    flutter pub publish --server=https://pub.dartlang.org -v
    因为国内普遍都设置了镜像的环境便利,这里必须指定服务器server为pub.dartlang.org

    此方法没坑还好,有坑就死翘翘了,我分别使用了cla,v2之类的都不行,设置了代理端口不生效,而cla开启tun模式,在cmd下可以不输入直接ping通google的,但是依然有错误,可能是我的vpn没给钱的原因。。。
    如果已经可以ping通大概率会看到一个网址,需要复制进行打开,登录谷歌授权就行了,这时候会在本地产生一个credentials.json文件,自动发布的时候就比较有用了,我本地大法没成功,但是这一步是走通了的。

    另外pub.dev还有信任开发者一说,这个我也弄好了,弄好之后就可以把发布的包移动到信任开发者域名下了,

    认证域名必须dns解析大法,用github子站法是行不通了,虽然能认证但是过不了pub.dev大法认证,我特意整了一个域名lozn.top 我给为了防止过期,我给续费10年比较便宜就300,

    【自动发布法】
    使用自动发布法可以实现提交代码就自动发布,设置tag就自动发布。
    action语法大概
    on: create表示创建标签就出发action任务 进行发布。

    on:
      push:
        branches: [ master ]
      pull_request:
        branches: [ master ]
    

    表示推送代码就会执行action任务 进行发布。

    ${{ secrets.DART_PUB_CREDENTIAL_JSON }}
    

    表示引用serret变量,
    DART_PUB_CREDENTIAL_JSON 的提取方法:

    全局搜索 pub-credentials.json或者 credentials.json

    我电脑在如下目录

    C:\Users\Administrator\AppData\Roaming\dart
    

    格式如下

    {"accessToken":"xxxN4uofsg","refreshToken":"xxxxxxx","tokenEndpoint":"https://accounts.google.com/o/oauth2/token","scopes":["openid","https://www.googleapis.com/auth/userinfo.email"],"expiration":1646488878682}
    在当前github项目下进入设置找到secret找到变量的英文单词,定义变量名为DART_PUB_CREDENTIAL_JSON把json的内容复制进去就行,

    image.png

    下面是完整action代码

    
    name: Publish to Pub.dev
    
    on:
      push:
        branches: [ master ]
      pull_request:
        branches: [ master ]
    
    jobs:
      build:
        runs-on: ubuntu-latest
        #if: github.ref != 'refs/heads/master'
        steps:
          - name: Checkout
            uses: actions/checkout@v1
          - name: Publish Dart/Flutter package
            uses: k-paxian/dart-package-publisher@master
            with:
              flutter: true
              skipTests: true
              dryRunOnly: true
              credentialJson: ${{ secrets.DART_PUB_CREDENTIAL_JSON }}
      deploy:
        runs-on: ubuntu-latest
        #if: github.ref == 'refs/heads/master'
        steps:
          - name: Checkout
            uses: actions/checkout@v1
          - name: Publish Dart/Flutter package
            uses: k-paxian/dart-package-publisher@master
            with:
              flutter: true
              skipTests: true
              credentialJson: ${{ secrets.DART_PUB_CREDENTIAL_JSON }}
    
    image.png

    另外网上也有其它大法,不需要传递credentialJson 而是传递accessToken和 refreshToken,但是我这边反正是没成功,我用此方法就成功了,另外我还给dart-package-publisher的作者提了一个issue,不过我感觉是没戏。。
    反正我研究发布可是研究了3天,本地发布法怎么搞都失败了,网络发布法,我尝试过 直接在action里面指定命令,出现y的地方输入echo y|命令名但是都失败告终了,终于苦苦在github搜索找到了可以用的代码。

    下面是我发布的包
    ···
    https://pub.dev/packages/smart_gridded_pageview
    ···

    由于我创建了信任开发者,因此我的旗下包目录结构是这样的
    https://pub.dev/publishers/lozn.top/packages

    image.png

    其中lozn.top是我认证的域名,所以得到的结果是这样的路径,
    但是在pub.dev里面是这样显示的,由于我把包移动到我的信任开发者域名下了,所以在pub.dev登录的这个界面的包就看不到了哈! 认证开发者可以添加多个开发者邮箱,邮箱为谷歌邮箱。


    image.png

    发布成功后,一般会收到邮件,


    image.png

    补充

    另外一种写法

        name: Publish Package CheckUp
    env:
      FLUTTER_VERSION: "3.0.2"
    
    #on:
    on:
      push:
        branches: [ master ]
      pull_request:
        branches: [ master ]
      #release:
      #  types: [published]
    
    jobs:
      build:
        runs-on: ubuntu-latest
    
        steps:
          - name: checkout
            uses: actions/checkout@v3
          - name: Install Flutter
            uses: subosito/flutter-action@v2
            with:
              flutter-version: $FLUTTER_VERSION
          - name: Install dependencies
            run: flutter pub get
         # - name: Analyze
        #  run: flutter analyze
    
          - name: Setup Pub Credentials
            shell: bash
            env:
              PUB_DEV_PUBLISH_ACCESS_TOKEN: ${{ secrets.ACCESSTOKEN }}
              PUB_DEV_PUBLISH_REFRESH_TOKEN: ${{ secrets.REFRESHTOKEN }}
              PUB_DEV_PUBLISH_ID_TOKEN: ${{ secrets.IDTOKEN }}
              PUB_DEV_PUBLISH_TOKEN_ENDPOINT: ${{ secrets.TOKENENDPOINT }}
              PUB_DEV_PUBLISH_EXPIRATION: ${{ secrets.EXPIRATION }}
            run: |
              sh ./pub_login.sh
          - name: Check Publish Warnings
            run: flutter pub publish --dry-run
          - name: Publish Package
            run: flutter pub publish -f
    ``
    
    然后再你的项目根目录创建pub_login.sh
    
                # This script creates/updates pub-credentials.json file which is used
                # to authorize publisher when publishing packages to pub.dev
    
                # Checking whether the secrets are available as environment
                # variables or not.
                if [ -z "${PUB_DEV_PUBLISH_ACCESS_TOKEN}" ]; then
                echo "Missing PUB_DEV_PUBLISH_ACCESS_TOKEN environment variable"
                exit 1
                fi
    
                if [ -z "${PUB_DEV_PUBLISH_REFRESH_TOKEN}" ]; then
                echo "Missing PUB_DEV_PUBLISH_REFRESH_TOKEN environment variable"
                exit 1
                fi
    
                if [ -z "${PUB_DEV_PUBLISH_ID_TOKEN}" ]; then
                echo "Missing PUB_DEV_PUBLISH_ID_TOKEN environment variable"
                exit 1
                fi
    
                #if [ -z "${PUB_DEV_PUBLISH_TOKEN_ENDPOINT}" ]; then
                #echo "Missing PUB_DEV_PUBLISH_TOKEN_ENDPOINT environment variable"
                # exit 1
                #fi
    
                #if [ -z "${PUB_DEV_PUBLISH_EXPIRATION}" ]; then
                # exit 1
                #fi
    
                # Create pub-credentials.json file.
                mkdir ~/.config
                mkdir ~/.config/dart
    
                cat <<EOF > ~/.config/dart/pub-credentials.json
                {
                "accessToken": "${PUB_DEV_PUBLISH_ACCESS_TOKEN}",
                "refreshToken": "${PUB_DEV_PUBLISH_REFRESH_TOKEN}",
                "idToken": "eyJhbGciOiJSUzI1NiIsImtpZCI6IjU4MGFkYjBjMzJhMTc1ZDk1MGExYzE5MDFjMTgyZmMxNzM0MWRkYzQiLCJ0eXAiOiJKV1QifQ.eyJpc3MiOiJhY2NvdW50cy5nb29nbGUuY29tIiwiYXpwIjoiODE4MzY4ODU1MTA4LThncmQyZWc5dGo5ZjM4b3M2ZjF1cmJjdnNxMzk5dThuLmFwcHMuZ29vZ2xldXNlcmNvbnRlbnQuY29tIiwiYXVkIjoiODE4MzY4ODU1MTA4LThncmQyZWc5dGo5ZjM4b3M2ZjF1cmJjdnNxMzk5dThuLmFwcHMuZ29vZ2xldXNlcmNvbnRlbnQuY29tIiwic3ViIjoiMTAzMDE3MDY5MTAxODQxNzUwMzA4IiwiZW1haWwiOiJxc3NxNTIxQGdtYWlsLmNvbSIsImVtYWlsX3ZlcmlmaWVkIjp0cnVlLCJhdF9oYXNoIjoibzNqX2tkZFc5MENLOFN5M3hTZ085QSIsImlhdCI6MTY1NTI4OTYzMywiZXhwIjoxNjU1MjkzMjMzfQ.OvXjZui_KPG_OM6KFDalcJ4KZE87I3t53CRWmtU_bi642ZBXmoAlZFm-QdZhpg7mzMo-W7qw39nRNrfkYyLH1TRNHwqKNyL29UnfrXagN-nQjRmnO5eS_JrsQWhWr0CGsuPyaewBC4WSE8CYPz3YtBEtCllvVq5jwx_Pj2kPpEfLuHrDoFpK2b8PH1jLRWMPbv3-mJb8XCOvvbY0-UbHrawWW53ntl46zE49Hgb-fby_Re071iIDWkLy-EPv2X2GpXUVKgjjwc5Osa63uMQRqmuFrkCyWN2ZFcihOwMfR7w4KC6c-pRy20Ed9LcEDjWR7NwZu-FseOWNE371PgzwmA",
                "tokenEndpoint": "https://accounts.google.com/o/oauth2/token",
                "scopes": ["https://www.googleapis.com/auth/userinfo.email", "openid"],
                "expiration": 1655293221820
                }
    
    具体参考 https://github.com/qssq/flutterswitcher_new/actions/runs/2506395380/workflow
    https://github.com/qssq/flutterswitcher_new/runs/6911478289?check_suite_focus=true
    ![image.png](https://img.haomeiwen.com/i2815884/8d1bc2faab526da1.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
    ![image.png](https://img.haomeiwen.com/i2815884/39bdd4a126fc5dbd.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
    
    
    参考资料
    https://dart.dev/tools/pub/publishing
    https://flutter.io/developing-packages/
    这2个链接在pub.dev登录后的右上角菜单就有,可以自己打开,都有哪些好玩的东西吧!
    

    相关文章

      网友评论

          本文标题:【原创】flutter之发布插件包到pub.dev离线在线两套大

          本文链接:https://www.haomeiwen.com/subject/xwnbrrtx.html