温馨提示:这篇文章已超过427天没有更新,请注意相关的内容是否还可用!
BeeWare无法连接https下载依赖包,可能是由于网络问题或配置错误导致的。尝试检查网络连接是否正常,并确认是否已正确配置相关设置。如果问题仍然存在,可能需要寻求专业的技术支持来解决该问题。BeeWare无法下载https依赖包,需检查网络和配置设置,或寻求专业支持解决。
本人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
那么恭喜,这一步过去了。否则重复执行⑧⑨,直至出现成功连接为止。
其余的网站也同样处理。
还没有评论,来说两句吧...