JGit与远程仓库连接使用的两种验证方式(ssh和https)

JGit是使用JAVAAPI来操控Git仓库的库,由Eclipse公司维护。他提供的API分红两个层次,底层命令和高层命令。底层API是直接做用于低级的仓库对象,高层的API是一个面向普通用户级别功能友好的前端。前端

  JGit主要经过SSHHTTP(S)的方式与远程仓库进行交互,此外也能够用Git协议(只读)。经过这两种方式,必然是须要添加验证信息的。介绍以下:git

1HTTPS - https://example.com/repo.git安全

 

CloneCommand cloneCommand = Git.cloneReposity();session

 

CloneCommand经过setCredentialsProvider()的方法,经过赋值一个UsernamePasswordCredentialsProvider对象,来提供用户名和密码登录。ssh

 

(不建议使用HTTP的方式传送,可是也可行)ide

  (2)SSH with Public Key -测试

 

   其实经过公钥访问的连接:spa

 

 

    git@***.***.***/user/***.gitcode

 

   而SSH利用公钥的访问方式的认证信息,经过JSCH库提供。而在JGit中提供了JschConfigSessionFactory的抽象类,代码以下:对象

SshSessionFactory sshSessionFactory = new JschConfigSessionFactory() {    @Override   protected void configure( Host host, Session session ) {       /*       解除HostKey检查,也就意味着能够接受未知的远程主机的文件,这是不安全的,这种模式只是用于测试为目的的。    利用ssh-keyscan -t rsa hostname,收集主机数据。     */ session.setConfig("StrictHostKeyChecking","no"); } };

如下这是在command中注册认证信息:

cloneCommand.setTransportConfigCallback( new TransportConfigCall back(){ public void configure(Transporttransport){ SshTransport sshTransport=(SshTransport)transport; sshTransport.setSshSessionFactory(sshSessionFactory); } }

3)SSH  with Password - ssh://user@example.com/repo.git

 

 

使用的是上述JschConfigSessionFactory重写的configure方法中,设置password,具体就不详述了。

相关文章
相关标签/搜索