我在 Github 中建立了一个私有(private)项目,其中包含一些 Maven 包。我可以在 Github 网站上浏览到它们。
按照指示 here我已经设置了我的 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")
}
}
}
我已经使用我在 Github 设置中创建的具有 read:packages
权限的用户名和访问 token 来设置系统环境变量。
我声明依赖项的方式与之前将其安装到 mavenLocal()
时的方式相同。但是我从本地 Maven 存储库中删除了它,所以我可以测试它。
无法解析依赖关系。但是来自 Gradle 的所有警告都是:
Unable to resolve dependency for ':android@debug/compileClasspath': Could not resolve myGroup:myArtifact:1.0
没有记录关于 Maven 存储库之一无效的警告,但我认为这是可能的问题,因为当包在本地 Maven 存储库中时它工作正常。可能是我指定的不正确,或者凭据不起作用。
我还尝试直接输入字符串用户名和 token ,而不是使用环境变量。 token 是全新的,没有过期。
如何确定我与 Github Packages Maven 存储库的连接出了什么问题?有什么办法可以获得更多有用的日志吗?或者您是否发现我的身份验证方式有问题?
最佳答案
从你的问题中我可以看出,你的设置看起来是正确的。
看来你只是在看Android Studio提供的错误。 Gradle 自己的错误消息通常更有帮助,所以我建议看看那些。换句话说,我建议尝试从命令行构建项目,例如与:
./gradlew build
根据问题的不同,您会收到不同的错误消息。例如,如果您的密码/ token 错误,那么您将看到如下内容:
> 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 似乎只看 token 。用户名似乎并不重要。
- URL 中存储库的具体名称似乎无关紧要,只要它不为空即可。
回到您的具体问题:Android Studio 错误消息的一部分似乎仍然直接来自 Gradle。它说“无法解决”而不是“找不到”。所以这可能是存储库连接的问题。如果您还没有将 token 用于任何其他用途,那么您可以在 https://github.com/settings/tokens 查看GitHub 是否认为它已经被使用过(例如,“上周内最后一次使用”)。如果它显示“Never used”,那么你就会知道 Gradle 从未成功连接到 GitHub,你应该仔细检查使用过的 token 或尝试一个新的。或者,您可以先使用 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
关于java - 在 Gradle 中调试 Github Packages 存储库连接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/71812255/