前言
平时开发中,我们经常会使用到通过 gradle 依赖三方的工具。例如我们常用的 okHttp 、 EventBus 等框架。那么这些代码是如何部署到远程并且供我们使用的呢?接下来就来看一下如何去实现。
maven
maven 其实就是为我们提供了进行托管我们代码的地址,我们可以相关代码进行上传到 maven,同时其他人如果觉得你写的比较好就可以通过依赖获取相关代码。maven 就类似于一个 git 或者 svn 的仓库。
把自己的项目部署到 maven 中
上面项目中,我们有一个 jnilib 的 library 。这个项目是我们创建的为了进行 jni 调用的一个示例 library 。接下来我们去把这个 library 部署到 maven 中,并供其它项目依赖使用。
1 首先需要在 jnilib 的 build.gradle 中进行一些配置:
//上传的maven库中
apply plugin: 'maven'
uploadArchives {
repositories.mavenDeployer {
def mavenDirPath = file('D:\\mavendir') // 本地存放目录(自行选择),可放在gradle.properties文件中引用
repository(url:"file://${mavenDirPath.absolutePath}") // 必须双引号,单引号不会转义$
pom.project {
groupId "com.harusty.maven" // 可以随意取,一般取包名
artifactId "jnisay" // 可以随意取,一般取库的名字
version "1.0.0" // 版本号
}
}
}
apply plugin: 'maven' 应用 maven 的插件。
可以看到我们配置了本地的 maven 缓存目录,以及库的包名、库名、版本号的信息,根据自己的习惯进行命名。
2 生成aar文件
定义好了相关配置信息,就可以去编译进行刷新生成 jnilib 的相关文件:
点击Run "MyApplication ...",或者我们去执行gradlew :jinlib:uploadArchives命令
此时会在本地目录中生成相关文件,我这里定义的本地D盘,去看一看:
我这里因为之前改过版本号为1.0.1,所以会生成两个文件夹。库的升级也就是这样去做的。
这样,我们已经在本地生成了文件,接下来就只需要上传到远程就可以了。
3 上传本地文件到远程
上传到github的地址:
拿到地址信息,https://github.com/harusty/jnisay/
4 本地配置信息,下载部署在 git 上的文件:
github 的地址信息
https://github.com/harusty/jnisay/
进行修改:
https://raw.githubusercontent.com/harusty/jnisay/master
即 github.com ——> raw.githubusercontent.com
在末尾追加 master 分支
根目录下 build.gradle 进行地址信息配置:
allprojects {
repositories {
google()
jcenter()
maven{
url "https://raw.githubusercontent.com/harusty/jnisay/master"
}
}
}
在需要使用该库的build.gradle文件的dependencies添加依赖:
dependencies {
implementation fileTree(dir: 'libs', include: ['*.jar'])
implementation 'androidx.appcompat:appcompat:1.0.2'
implementation 'androidx.constraintlayout:constraintlayout:1.1.3'
implementation 'com.harusty.maven:jnisay:1.0.0'
// compile project(path: ':jnilib')
}
上面我们同时屏蔽了本地对 library 的依赖。
5 刷新 build.gradle 文件,下载对应部署在 git 上的 library 文件。
成功下载后我们可以在 External Libraries 中看到上述的 aar 文件。
注意:
在下载过程中我们有可能连接不上 raw.githubusercontent.com,导致下载 aar 文件失败。可以通过修改 Host 文件解决:
通过IPAddress.com首页,输入raw.githubusercontent.com查询到真实IP地址
199.232.28.133
C:\Windows\System32\drivers\etc
hosts文件
添加 以下内容并保存即可恢复
199.232.28.133 raw.githubusercontent.com
6 运行文件,调用 jnilibs 里的方法。
public class JNIUtils {
static {
System.loadLibrary("demo");
}
public static native String sayHelloFromJNI();
}
这里用的 jni ,native 层会返回一个字符串。关于 jni 相关可查看
jni 调用的相关文章,这里知道会返回一个字符串。
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
final TextView tv = findViewById(R.id.jni_click);
tv.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
tv.setText(JNIUtils.sayHelloFromJNI());
}
});
}
}
功能可正常调用即部署成功。如果本地升级了,同时升级 maven 配置的版本号即可,并进行上传至 git 。
uploadArchives {
repositories.mavenDeployer {
def mavenDirPath = file('D:\\mavendir') // 本地存放目录(自行选择),可放在gradle.properties文件中引用
repository(url:"file://${mavenDirPath.absolutePath}") // 必须双引号,单引号不会转义$
pom.project {
groupId "com.harusty.maven" // 可以随意取,一般取包名
artifactId "jnisay" // 可以随意取,一般取库的名字
version "1.0.3" //升级 版本号
}
}
}
升级到 1.0.3 版本。