调试Gradle中的Github软件包存储库连接



我在Github中建立了一个私有项目,其中包含一些Maven包。我可以在Github网站上浏览到它们。

按照这里的指示,我已经设置了build.gradle来声明存储库,如下所示:

repositories {
mavenLocal()
maven {
url = "https://maven.pkg.github.com/myAccountName/myRepo"
credentials {
username = System.getenv("GITHUB_USERNAME")
password = System.getenv("GITHUB_PACKAGES_TOKEN")
}
}
}

我已经使用用户名和访问令牌设置了系统环境变量,这些变量是我在具有read:packages权限的Github设置中创建的。

我声明依赖项的方式与之前将其安装到mavenLocal()时相同。但我从本地Maven回购中删除了它,这样我就可以测试它了。

无法解析依赖项。但Gradle的所有警告都是:

无法解析"的依赖项:android@debug/compileClasspath":无法解析myGroup:myArtifact:1.0

没有关于其中一个Maven回购无效的日志警告,但我认为这可能是问题所在,因为当包在本地Maven回购中时,这一切都很好。可能是我指定错误,或者凭据不起作用。

我还尝试直接键入字符串用户名和令牌,而不是使用环境变量。代币是全新的,没有过期。

我如何确定我与Github Packages Maven存储库的连接出了什么问题?有没有办法让我得到更多有用的日志?或者你看到我的身份验证有什么问题吗?

根据您的问题,您的设置看起来是正确的。

你似乎只是在看安卓工作室提供的错误。Gradle自己的错误消息通常更有用,所以我建议查看这些消息。换句话说,我建议尝试从命令行构建项目,例如:

./gradlew build

根据问题的不同,您会收到不同的错误消息。例如,如果你的密码/令牌是错误的,那么你会看到这样的东西:

> Could not resolve all files for configuration ':compileClasspath'.
> Could not resolve com.example:my-lib:1.0.0.
Required by:
project :
> Could not resolve com.example:my-lib:1.0.0.
> Could not get resource 'https://maven.pkg.github.com/myAccountName/myRepo/com/example/my-lib/1.0.0/my-lib-1.0.0.pom'.
> Could not GET 'https://maven.pkg.github.com/myAccountName/myRepo/com/example/my-lib/1.0.0/my-lib-1.0.0.pom'. Received status code 401 from server: Unauthorized

注意末尾的Received status code 401 from server: Unauthorized

然而,如果您的依赖声明是错误的(组、模块名称或版本中的任何一个(,那么您将得到这样的错误:

> Could not resolve all files for configuration ':compileClasspath'.
> Could not find com.example:oops-wrong:1.0.0.
Searched in the following locations:
- file:/home/chriki/.m2/repository/com/example/oops-wrong/1.0.0/oops-wrong-1.0.0.pom
- https://maven.pkg.github.com/myAccountName/myRepo/com/example/oops-wrong/1.0.0/oops-wrong-1.0.0.pom
Required by:
project :

当然,如果你之前没有(正确地(上传/发布所需的包,你也会遇到同样的错误。您可以手动检查它是否存在于https://maven.pkg.github.com/myAccountName/myRepo/packages

对于其他情况,可能还有其他错误消息。例如,我记得我见过一辆403。不幸的是,GitHub Packages注册表似乎没有向Gradle提供足够的详细信息,因此它可以提供除上述两个错误之外的其他错误。即使我使用了错误的存储库,我仍然只会得到第二种错误:

> Could not resolve all files for configuration ':compileClasspath'.
> Could not find com.example:my-lib:1.0.0.
Searched in the following locations:
- file:/home/chriki/.m2/repository/com/example/my-lib/1.0.0/my-lib-1.0.0.pom
- https://maven.pkg.github.com/oops-wrong/com/example/my-lib/1.0.0/my-lib-1.0.0.pom
Required by:
project :

更多发现:

  • 对于凭据,GitHub似乎只查看令牌。用户名似乎无关紧要
  • URL中存储库的具体名称似乎无关紧要,只要它不是空的

回到你的具体问题:Android Studio错误消息的一部分似乎仍然直接来自Gradle。上面写着"无法解决"而不是"找不到"。所以这很可能是存储库连接的问题。如果您没有将代币用于其他用途,那么您可以查看https://github.com/settings/tokensGitHub是否认为它已经被使用过(例如,"上周最后一次使用"(。如果上面写着"从未使用过",那么你就会知道Gradle从未成功连接到GitHub,你应该仔细检查使用过的令牌或尝试新的令牌。或者,您可以先试用wget的凭据:

wget --user myAccountName --password "$GITHUB_PACKAGES_TOKEN" 
https://maven.pkg.github.com/myAccountName/myRepo/com/example/my-lib/1.0.0/my-lib-1.0.0.pom

最新更新