本人android开发新手,打算用python+beeware开发一个简单的anroid程序,结果在按照beeware教程创建测试程序时,新建的程序使用briefcase build android 一直出现报错。
A problem occurred configuring root project 'DroneEnvData'.
> Could not resolve com.android.tools.build:gradle:4.2.2.
> Could not get resource 'https://dl.google.com/dl/android/maven2/com/android/tools/build/gradle/4.2.2/gradle-4.2.2.pom'.
> Could not GET 'https://dl.google.com/dl/android/maven2/com/android/tools/build/gradle/4.2.2/gradle-4.2.2.pom'.
> The server may not support the client's requested TLS protocol versions: (TLSv1.2). You may need to configure the client to allow other protocols to be used. See: https://docs.gradle.org/7.2/userguide/build_environment.html#gradle_system_properties
> sun.security.validator.ValidatorException: PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target
表现为无法连接dl.google.com下载对应的包。
按照网上教程折腾一天,差一点从入门到放弃。现在将踩的坑记录下来,以备未来继续踩。
1、无法连接dl.google.com
参考其他文章内容,修改google源到国内源,在BeeWare创建的项目文件中修改settings.gradle及build.gradle文件
这两个文件在这里:
盘符:\你创建的beeware项目\build\droneenvdata\android\gradle
原始setting.gradle
include ':app'
rootProject.name='你的项目'
修改为
pluginManagement {
repositories {
maven { url 'https://maven.aliyun.com/repository/central' }
maven { url 'https://maven.aliyun.com/repository/google' }
maven { url 'https://maven.aliyun.com/repository/public' }
gradlePluginPortal()
google()
mavenCentral()
}
}
dependencyResolutionManagement {
repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)
repositories {
maven { url 'https://maven.aliyun.com/repository/central' }
maven { url 'https://maven.aliyun.com/repository/google' }
maven { url 'https://maven.aliyun.com/repository/public' }
google()
mavenCentral()
}
}
include ':app'
rootProject.name='DroneEnvData'
修改build.gradle
// Top-level build file where you can add configuration options common to all sub-projects/modules.
buildscript {
repositories {
maven { name "Alibaba" ; allowInsecureProtocol true ; url "http://maven.aliyun.com/nexus/content/groups/public/" } #新增
maven { url 'https://maven.aliyun.com/repository/central' } #新增
maven { url 'https://maven.aliyun.com/repository/google' } #新增
google()
mavenCentral()
}
dependencies {
classpath 'com.android.tools.build:gradle:4.2.2'
classpath 'com.chaquo.python:gradle:14.0.2'
// NOTE: Do not place your application dependencies here; they belong
// in the individual module build.gradle files
}
}
allprojects {
repositories {
//google() #注释掉
//mavenCentral() #注释掉
}
}
task clean(type: Delete) {
delete rootProject.buildDir
}
2、下载阿里云的证书,并添加信任
下载方法:
①打开对应的网站,如仓库服务 (aliyun.com)
②点击浏览器地址栏上的锁头图标(Edge)
③点击 连接安全
④点击证书图标
⑤点击详细信息
⑥点击 导出,将证书文件存放到本机,如C:\Users\administrator\Desktop\XX.crt
⑦打开Everything,搜索cacerts。这个文件是JAVA的证书库,保存着你信任的证书
这里就是我之前坑了好久的地方,系统内可能有多个cacerts文件,不知道哪个是JAVA正在用的。。。
⑧打开powershell,准备执行keytool命令。建议把下面的命令在记事本里面多复制几分,下面要用。
keytool -importcert -alias 证书别名 -keystore "证书库路径" -storepass changeit -file 刚下载的证书地址
如:
keytool -importcert -alias google -keystore "" -storepass changeit -file C:\Users\你\Desktop\_.google.com.crt
⑨对每一个cacerts文件,复制其路径及文件名,修改到⑧里面的证书库路径中
如:
keytool -importcert -alias google -keystore "C:\Users\你\.android\cacerts" -storepass changeit -file C:\Users\你\Desktop\_.google.com.crt
执行该语句,当出现”是否信任此证书? [否]“时,键入Y
是否信任此证书? [否]: y
出现”证书已添加到密钥库中“就ok了,然后尝试用语句测试一下
java SSLPoke dl.google.com 443
注:没有SSLPoke命令的同学,网上搜索并下载一下SSLPoke.class文件,cmd切换到该文件所在位置,再执行刚才的语句。
⑩如果出现了
Successfully connected
那么恭喜,这一步过去了。否则重复执行⑧⑨,直至出现成功连接为止。文章来源:https://www.toymoban.com/news/detail-767391.html
其余的网站也同样处理。文章来源地址https://www.toymoban.com/news/detail-767391.html
到了这里,关于BeeWare无法连接https下载依赖包的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!