Flutter 插件开发之引入aar到安卓部分 并使用本地maven

文章目录

本篇主题: 在 flutter 插件中引入 aar

本篇只包含 android 部分, iOS 的 framework 直接在 podspec 中引入就可以了,所以本篇略过不表

做过安卓开发的朋友可能知道, aar 文件如果作为本地文件直接引入 library, 然后 app 引用 library 是会报找不到aar的, 需要在 app 中使用 flatDir 进行引入, 这种方式的缺点在于, 你必须在每个项目去配置, 很有侵入性

熟悉 flutter 插件开发的朋友都知道,在我们开发 flutter 插件时, 插件是以 library module 的形式引入到项目中的

这时如果 sdk 方对于安卓只提供了 aar, 在这种大前提下,我们有如下几种方法:

  1. 使用 maven 公开服, 比如 jcenter, 或其他的 maven 仓库
  2. 使用本地 maven 仓库

本篇就使用这种本地 maven 仓库的方案来做

完成本地 maven 的步骤

创建插件项目

第一步肯定是创建一个 flutter 插件

1flutter create -t plugin example_for_flutter_plugin_local_maven

置入 aar

我这里用蒲公英的的 aar 举例:

下载下来放在 android 目录下

https://github.com/Pgyer/mvn_repo_pgyer/blob/master/com/pgyersdk/sdk/3.0.9/sdk-3.0.9.aar

在插件的 android 目录下创建一个文件夹,把 aar 放进去, 我这里取名为 aar

1mkdir android/aar
2cd android/aar
3wget https://github.com/Pgyer/mvn_repo_pgyer/blob/master/com/pgyersdk/sdk/3.0.9/sdk-3.0.9.aar?raw=true #下载
4mv sdk-3.0.9.aar?raw=true sdk.aar #改名

使用 aar 文件创建本地 maven 仓库

  1. 需要一个 maven 二进制程序, mac 的话是用$ brew install maven即可, 其他系统自行搜索 maven 安装
  2. 验证安装$ mvn -v
  3. 使用命令行创建
 1mvn deploy:deploy-file -Dfile=sdk.aar -Durl="file://." # 这步会报错
 2
 3[ERROR] Failed to execute goal org.apache.maven.plugins:maven-deploy-plugin:2.7:deploy-file (default-cli) on project standalone-pom: The artifact information is incomplete or not valid:
 4[ERROR]   [0]  'groupId' is missing.
 5[ERROR]   [1]  'artifactId' is missing.
 6[ERROR]   [2]  'version' is missing.
 7[ERROR]
 8[ERROR] -> [Help 1]
 9[ERROR]
10[ERROR] To see the full stack trace of the errors, re-run Maven with the -e switch.
11[ERROR] Re-run Maven using the -X switch to enable full debug logging.
12[ERROR]
13[ERROR] For more information about the errors and possible solutions, please read the following articles:
14[ERROR] [Help 1] http://cwiki.apache.org/confluence/display/MAVEN/MojoExecutionException

这里-Dfile 指向 aar 文件, url 指向目标地址, 我这里因为要部署在 aar 文件夹里, 所以直接用.代表当前文件夹, 它提示我缺少 3 个东西, 组名,品名,版本号

 1mvn deploy:deploy-file -Dfile=sdk.aar -Durl="file://." -DgroupId="com.pgyer" -DartifactId="sdk" -Dversion="3.0.9"
 2
 3[INFO] Scanning for projects...
 4[INFO]
 5[INFO] ------------------< org.apache.maven:standalone-pom >-------------------
 6[INFO] Building Maven Stub Project (No POM) 1
 7[INFO] --------------------------------[ pom ]---------------------------------
 8[INFO]
 9[INFO] --- maven-deploy-plugin:2.7:deploy-file (default-cli) @ standalone-pom ---
10Uploading to remote-repository: file://./com/pgyer/sdk/3.0.9/sdk-3.0.9.aar
11Uploaded to remote-repository: file://./com/pgyer/sdk/3.0.9/sdk-3.0.9.aar (134 kB at 3.3 MB/s)
12Uploading to remote-repository: file://./com/pgyer/sdk/3.0.9/sdk-3.0.9.pom
13Uploaded to remote-repository: file://./com/pgyer/sdk/3.0.9/sdk-3.0.9.pom (415 B at 208 kB/s)
14Downloading from remote-repository: file://./com/pgyer/sdk/maven-metadata.xml
15Downloaded from remote-repository: file://./com/pgyer/sdk/maven-metadata.xml (292 B at 32 kB/s)
16Uploading to remote-repository: file://./com/pgyer/sdk/maven-metadata.xml
17Uploaded to remote-repository: file://./com/pgyer/sdk/maven-metadata.xml (292 B at 146 kB/s)
18[INFO] ------------------------------------------------------------------------
19[INFO] BUILD SUCCESS
20[INFO] ------------------------------------------------------------------------
21[INFO] Total time:  0.407 s
22[INFO] Finished at: 2020-03-30T16:00:25+08:00
23[INFO] ------------------------------------------------------------------------

这样就 ok 了, 所有文件都生成了

 1tree .
 2.
 3├── com
 4│   └── pgyer
 5│       └── sdk
 6│           ├── 3.0.9
 7│           │   ├── sdk-3.0.9.aar
 8│           │   ├── sdk-3.0.9.aar.md5
 9│           │   ├── sdk-3.0.9.aar.sha1
10│           │   ├── sdk-3.0.9.pom
11│           │   ├── sdk-3.0.9.pom.md5
12│           │   └── sdk-3.0.9.pom.sha1
13│           ├── maven-metadata.xml
14│           ├── maven-metadata.xml.md5
15│           └── maven-metadata.xml.sha1
16└── sdk.aar

这是标准的 maven 目录结构

这时候 sdk.aar 就没用了, 可以删除

编辑 gradle 文件

用 studio 打开项目 example/android

 1
 2// 定义一个方法, 用于获取当前moudle的dir
 3def getCurrentProjectDir() {
 4    String result = ""
 5    rootProject.allprojects { project ->
 6        if (project.properties.get("identityPath").toString() == ":example_for_flutter_plugin_local_maven") { // 这里是flutter的约定, 插件的module名是插件名, :是gradle的约定. project前加:
 7            result = project.properties.get("projectDir").toString()
 8        }
 9    }
10    return result
11}
12
13rootProject.allprojects {
14    // 这个闭包是循环所有project, 我们让这个仓库可以被所有module找到
15    def dir = getCurrentProjectDir()
16    repositories {
17        google()
18        jcenter()
19        maven { // 添加这个指向本地的仓库目录
20            url "$dir/aar"
21        }
22    }
23}
24
25dependencies {
26    implementation "com.pgyer:sdk:3.0.9" // 添加这个, 接着点sync project with gradle file 刷新一下项目就可以了. 是使用api还是implementation根据你的实际情况来看就好了
27}

后记

本篇使用了 gradle 来完成了对主项目无侵入的方式配置 maven

这样主工程无论是任何项目可以引用到这个 aar 的内容, 当然这个方案也适用于非 flutter 项目

仓库地址: github

以上