- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试通过 CloneCommand
克隆 Git 存储库.
用这段代码
`Git.cloneRepository().setDirectory(new File(path)).setURI(url).call();`
Caused by: java.security.cert.CertificateException: No name matching <hostName> found
at sun.security.util.HostnameChecker.matchDNS(HostnameChecker.java:221)
at sun.security.util.HostnameChecker.match(HostnameChecker.java:95)
TrustManager
, 注册一个虚拟
HostnameVerifier
并创建并初始化一个
SSLContext
使用这个假人
TrustManager
.
最佳答案
在 4.9 版本中,JGit 将更优雅地处理 SSL 验证。如果 SSL
握手不成功,JGit 会询问 CredentialsProvider
是否应跳过 SSL 验证。
在这个过程中,CredentialsProvider
得到一个 InformationalMessage
以文字方式描述问题,最多三个 YesNoType
CredentialItem
s 决定是否跳过此操作、当前存储库和/或始终的 SSL 验证。
似乎更改是在考虑交互式 UI 的情况下进行的,可能很难以编程方式回答这些“凭据请求”。 commit message of this change更详细地描述行为。
如果您确定 SSL 验证是唯一的 InformationalMessage
将发送,您可以应用 this test 中使用的技术伴随着变化而盲目地对所有这些问题回答"is"。
对于早期版本的 JGit,或者如果 CredentialsProvider
模型不符合您的需求,下面介绍了两种解决方法。
要解决此限制,您可以 手动执行特定的克隆步骤 正如以下评论中所建议的:
StoredConfig config = git.getRepository().getConfig();
config.setBoolean( "http", null, "sslVerify", false );
config.save();
HttpConnectionFactory
返回
HttpConnection
s 带有虚拟主机名和证书验证器。例如:
class InsecureHttpConnectionFactory implements HttpConnectionFactory {
@Override
public HttpConnection create( URL url ) throws IOException {
return create( url, null );
}
@Override
public HttpConnection create( URL url, Proxy proxy ) throws IOException {
HttpConnection connection = new JDKHttpConnectionFactory().create( url, proxy );
HttpSupport.disableSslVerify( connection );
return connection;
}
}
HttpConnection
在包裹中
org.eclipse.jgit.transport.http
并且是 HTTP 连接的 JGit 抽象。虽然示例使用默认实现(由 JDK http 代码支持),但您可以自由使用自己的实现或由
org.eclipse.jgit.transport.http.apache
提供的实现。使用 Apache http 组件的包。
HttpTransport::setConnectionFactory()
更改:
HttpConnectionFactory preservedConnectionFactory = HttpTransport.getConnectionFactory();
HttpTransport.setConnectionFactory( new InsecureHttpConnectionFactory() );
// clone repository
HttpTransport.setConnectionFactory( preservedConnectionFactory );
不幸的是,连接工厂是一个单例,因此当 JGit 命令并发执行时,这个技巧需要额外的工作(例如,一个线程局部变量来控制 sslVerify 是打开还是关闭)。
关于jgit - 为 JGit 克隆命令关闭 SSL 验证,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33998477/
使用 JGit,我想尽可能使用 git log --name-status 获取在提交时更改的文件列表。 这可能吗?如果是这样,你怎么做? 最佳答案 我使用了来自伟大的 GitBlit-Tool 的
我想使用 JGit 确定 HEAD 的远程跟踪分支。 在直接 git 中,我可以这样做: git rev-parse --abbrev-ref --symbolic-full-name @{upstr
在 GitHub 项目中,当我们转到任何分支页面时,我们可以看到描述分支 w.r.t 的提交前/后数量的图表。掌握。 我们如何使用 JGit 确定数字后面的那些人? 我用过 BranchTrackin
我想将文件夹中所做的所有修改添加到索引中: 文件修改 添加了 文件 文件已删除 File gitDir = new File("/home/franck/Repositories/Git/Sandbo
想出了: /** * Create a repo at the specified directory or open one if it already * exists. Return a {
如何使用 JGit 确定哪些分支已合并到 master? 我想做相当于普通的 git 命令: git branch -a --merged 这在 JGit 中可能吗? 最佳答案 RevWalk::is
我正在尝试通过 CloneCommand 克隆 Git 存储库. 用这段代码 `Git.cloneRepository().setDirectory(new File(path)).setURI(ur
当我对存储库中的第一个提交执行 git show commit 时,我看到了所有文件以及文件的差异(即添加的所有行) $ git show cb5d132 commit cb5d13286cf9d14
我在应用程序中使用 JGit。此应用有一个 SecurityManager,它只允许特定的白名单类和方法产生新进程。 JGit 内部正在发现是否安装了本地 git 并尝试在 org.eclipse.j
我需要从上次 Jenkins 构建中提取的日期的提交列表,并获取自该日期以来的 merge 提交列表。到目前为止我已经编码以获得 merge 提交列表。只需要一个解决方案来提取指定日期之间的这些提交。
我使用 JGit 在我的本地磁盘上克隆了一个裸仓库。现在,我需要读取任何给定提交 ID (SHA1) 的文件内容。我该怎么做? 最佳答案 comment of Rüdiger Herrmann in
我正在尝试从托管在 bitbucket 上的远程存储库中提取数据。为此,我正在使用 JGit。我的代码如下; Git git = Git.open( new File( localPa
我正在尝试使用 JGit 将本地存储库推送到 github 存储库: String remote = "https://token@github.com/me/foo"; Repository rep
我找到了类似的 question并以此为基础,但出现错误 Cannot invoke method getAuthorIdent() on null object。我尝试获取最后一次提交,检查它是否等
是否可以使用 JGit 解析第一次提交某个文件的日期和时间? Git 等效项将列出第一个提交,例如: git log --format=%aD | tail -1 最佳答案 可以按如下方式使用 Re
我找到了类似的 question并以此为基础,但出现错误 Cannot invoke method getAuthorIdent() on null object。我尝试获取最后一次提交,检查它是否等
我想读取某个分支中某个提交处的文件内容:我目前正在使用此代码来读取某个提交处的文件内容,忽略该分支。 public static String readContentOfFileAtCommi
我想使用 jgit 创建一个 git 存储库浏览器。但我不知道如何获取文件的最后修改日期和最后提交消息。这是我当前的浏览器代码: File directory = new File("/Users/s
我想克隆远程存储库,添加文件并将文件推回,但出现异常: org.eclipse.jgit.api.errors.TransportException: git://192.168.1.1/abc: C
我们正在使用 git 来维护我们的源代码。像 git@xx.xx.xx.xx:XYZ.git 这样的 URL。我正在使用 JGit 提取更改。 UsernamePasswordCredentialsP
我是一名优秀的程序员,十分优秀!