我在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