背景
前两天接手了其他公司的一个项目,项目中大量引用了该公司自己写的依赖,并且这些依赖项目都放在了公司内部的局域网仓库。如何能将这些依赖成功引入到该项目就成了我马上要解决的问题。
解决方案
方法一
为我添加局域网的访问权限
问题:这个肯定是最简单的,有了访问权限就可以跟使用外网公共仓库一样了,但是该公司有规定,不能为我开放访问权限。。。
方法二
将依赖包(.aar、.jar)发给我,将依赖改成项目内的lib依赖
问题:这样肯定将会改变项目中的依赖代码,项目当前处于我与该公司交接期间,这样的修改无疑会对该公司开发人员产生影响(除非我不提交代码),而且像这种引入的依赖包高达70个左右。
方法三
将该公司的开发人员的gradle下的依赖缓存目录cache发给我,我利用里面缓存的依赖
问题:与我本机的cache合并后,编译后还是提示找不到依赖包,可在cache目录中明明可以找到那个依赖包了。
探索:于是揣测是不是AndroidStudio做缓存时候先把要缓存的依赖包与缓存位置写入了一个文件,我只是把依赖包copy过来,那个文件并没有更改。我又开始找那个文件,各种百度也没有找到,但却让我看到了AndroidStudio存在本地的仓库,用了一个依赖库试了下,可行。
使用他人缓存依赖包
1.拷贝他人的缓存依赖包
缓存路径是.gradle/caches/modules-2/files-2.1
2.找到AndroidStudio的本地仓库
路径为:安装路径/Contents/gradle/m2repository
3.参考本地仓库中已有的依赖包copy
在这个本地仓库中我们能看到很多我们平时项目中常用的依赖库,参考它们的目录结构把我们从其他电脑上获取的依赖copy进去。对比下files-2.1和m2repository目录结构:
files-2.1/com.crashlytics.sdk.android/crashlytics/2.6.5/ea45fe12527757f5bbaff83369f27e21879fb30a/crashlytics-2.6.5.aar
m2repository/com/crashlytics/sdk/android/crashlytics/2.6.5/crashlytics-2.6.5.aar
我们可以一个一个copy,但是我上面说过这种依赖包有70个,一个个copy明显是不符合我们程序员的作风的,仔细看我们还是能看到规律的,上代码:
public static void main(String[] args) throws IOException {
String source = "caches中/files-2.1所在目录";
String destRoot = "m2repository的目录";
File rootFile = new File(source);
for (File file : rootFile.listFiles()) {
if (file.isDirectory() && file.getName()) {
//将包名转换成文件的层级结构
String destDir = file.getName().replace(".", File.separator);
traversalFile(file, source + File.separator + file.getName(), destRoot + File.separator + destDir);
}
}
}
/**
*遍历文件
*/
private static void traversalFile(File rootFile, String source, String destRoot) {
for (File subFile : rootFile.listFiles()) {
if (!subFile.getName().equals(".DS_Store")) {
if (subFile.isDirectory()) { //文件夹
traversalFile(subFile, source, destRoot);
} else { //文件
File md5Dir = new File(subFile.getParent());
String copyPath = new File(md5Dir.getParent()).getAbsolutePath().replace(source, destRoot);
File copyDir = new File(copyPath);
if (!copyDir.exists()) {
copyDir.mkdirs();
}
File destFile = new File(copyDir, subFile.getName());
//copy时发现同一个包同一个版本可能存在多个,在这里打印出来那个依赖包存在多个但不进行copy
if (destFile.exists()) {
System.out.println(subFile.getAbsolutePath());
} else {
try {
//引入的common.io的包
FileUtils.copyFile(subFile, destFile);
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
}
}
至此,大功告成。