赞
踩
本人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
那么恭喜,这一步过去了。否则重复执行⑧⑨,直至出现成功连接为止。
其余的网站也同样处理。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。