android引入第三方aar,jar冲突如何解决?

引入第三方aar,发现第三方aar里面的jar和本地项目的jar冲突了 如何解决?

方法一:proguard-rules.pro里面加上

-repackageclasses 'youappname or packageName'

加上这一句后,aar里面的class都会归为这个名称下,一般加上这一句,就不会和其他应用冲突,除非调用方的repackageclasses和你重名,而且又引用了相同的第三方jar

方法二:把本地引入的冲突的jar删了 (缺点:是否会影响自身的APP?需要测试)

方法三:删除aar里面的冲突的jar相关的class,重新打成aar (缺点:是否会影响应用的AAR?需要测试)

用winRAR打开aar文件,再把里面的classes.jar拖出来,再使用winRAR打开classes.jar删除里面冲突的jar,比如okhttp相关的,再次打开aar,把改过的jar拖进去即可。

以上步骤也可使用命令行来完成:

在linux环境,先解压

unzip test-v1.0.2.aar -d  /usr/local/test/test-v1.0.2

再使用winrar打开classes.jar,删除冲突的jar

最新版本androidstudio打出的aar,会碰到无法删除classes.jar内部文件的情况(7zip会这样),如果7zip无法删除,那么使用winrar软件打开再删除

两个解压缩软件都无法删除,那么就使用命令行解压

unzip classes.jar -d classes

解压后,修改或删除里面的class文件

再重新打成jar(jar命令需要安装jdk)
jar cvf classes.jar -C classes/ .

重新打成aar包,记得后面还有个 .

jar cvf test-v1.0.3.aar -C test-v1.0.2/ .

方法四:aar提供方jar依赖改成在build.gradle添加依赖

比如原先在lib文件夹下添加了谷歌的zxing,二维码处理相关jar

core_3.3.0.jar

现在改成

dependencies {
api 'com.google.zxing:core:3.3.0'

}

因为APP本身是通过这种方式,aar提供方也通过这种方式来添加依赖,通过build.gradle里面添加依赖的方式,可以发现打出的aar里面不会包含依赖的包的,那么就不会造成冲突,我理解,gradle编译时,可能发现有两个相同的依赖,只会加载一个,这样就不会造成冲突了。

方法五:添加依赖的时候api,compile,implementation换成provided或compileOnly

 provided(compileOnly)

只在编译时有效,不会参与打包,可以在自己的moudle中使用该方式依赖。比如com.android.support,gson这些使用者常用的库,避免冲突。

compileOnly files('mylibs/sdk.jar')

provided files('mylibs/sdk.jar')

另外关于android gradle仓库,国外经常连不上其实可以加上aliyun提供的

buildscript {
    repositories {
        google()
        jcenter()
        maven { url 'https://maven.aliyun.com/repository/jcenter' }
        maven { url 'https://maven.aliyun.com/repository/google'}
    }
    dependencies {
        classpath 'com.android.tools.build:gradle:3.2.1'
        
        // NOTE: Do not place your application dependencies here; they belong
        // in the individual module build.gradle files
    }
}

allprojects {
    repositories {
        google()
        jcenter()
        maven { url 'https://maven.aliyun.com/repository/jcenter' }
        maven { url 'https://maven.aliyun.com/repository/google'}
    }
}

<think>好的,用户问的是如何在路由器上安装和配置AList文件列表程序。首先我需要回忆一下AList的相关知识。AList是一个支持多种存储的文件列表程序,可以挂载网盘等,通常通过Docker部署。用户提到的是在路由器上安装,所以需要确认路由器是否支持Docker。 根据引用[1],之前有在ARMv7架构的玩客云主机上安装AList和Aria2的例子,使用的是Docker部署。路由器如果是基于类似架构,并且支持Docker的话,步骤可能类似。但很多普通家用路由器可能没有足够的性能或存储来运行Docker,所以需要用户确认路由器的系统是否支持,比如是否是OpenWrt这类第三方固件。 接下来,我需要整理安装步骤。首先,确保路由器系统兼容,比如OpenWrt,并且安装了Docker。然后通过SSH登录路由器,使用Docker命令拉取AList镜像,创建容器,配置端口和数据目录。之后进入AList的Web界面进行进一步设置,比如添加存储和用户管理。 另外,引用[3]提到有些步骤已有详细教程,可能需要引导用户查看相关链接。用户可能还需要内网穿透,如引用[1]中的Cpolar,来公网访问AList,但用户问题暂时没提到这部分,可能后续会需要。 需要注意检查路由器的资源是否足够,存储空间和内存。如果路由器无法运行Docker,可能需要交叉编译AList的二进制文件,或者寻找适合路由器架构的预编译版本,手动安装。 最后,生成相关问题,帮助用户深入解决可能遇到的问题,比如性能优化、结合Aria2使用,或者内网穿透配置。</think>### 如何在路由器上安装和配置AList文件列表程序? #### 前提条件 1. **路由器系统需支持Docker**:推荐使用OpenWrt等支持容器化部署的固件,并确保路由器存储空间和内存足够运行容器[^1]。 2. **SSH访问权限**:需能通过SSH登录路由器后台。 --- #### 分步操作指南 ##### 1. 安装Docker环境 - 若路由器系统未预装Docker,需通过包管理器手动安装。例如在OpenWrt中: ```bash opkg update opkg install docker docker-compose ``` ##### 2. 拉取AList镜像并启动容器 通过SSH连接路由器后执行: ```bash docker run -d \ --name alist \ -p 5244:5244 \ -v /mnt/sda1/alist:/opt/alist/data \ --restart=always \ xhofe/alist:latest ``` - **参数说明**: - `-p 5244:5244`:将容器内5244端口映射到路由器 - `-v /mnt/sda1/alist:/opt/alist/data`:挂载存储目录(需提前创建`/mnt/sda1/alist`) - `--restart=always`:设置容器自动重启 ##### 3. 获取管理员密码 执行以下命令查看初始密码: ```bash docker exec -it alist ./alist admin random ``` 或查看日志: ```bash docker logs alist | grep password ``` ##### 4. 访问Web界面 浏览器输入 `http://路由器IP:5244`,使用用户名`admin`和上一步获取的密码登录。 ##### 5. 配置存储功能 - **添加存储**:在Web界面中选择“存储” > “添加”,支持阿里云盘、OneDrive等20+种存储类型。 - **用户管理**:可创建多用户并分配不同存储权限。 - **主题插件**:支持自定义主题和扩展功能插件。 --- #### 常见问题解决 - **端口冲突**:若5244端口被占用,修改`-p`参数为其他端口(如`-p 8080:5244`)。 - **存储挂载失败**:检查挂载路径权限,执行`chmod -R 777 /mnt/sda1/alist`。 - **性能问题**:若路由器资源不足,可关闭非必要插件或限制容器内存: ```bash docker update --memory 256M alist ``` --- #### 扩展应用(结合引用[1]) 若需公网访问AList,可参考引用[1]通过**Cpolar内网穿透**生成公网地址,或配置DDNS实现固定域名访问。 ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值