Java连接Linux服务器过程分析(附代码)
这篇文章主要介绍了Java连接Linux服务器过程分析(附代码),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
pom文件添加依赖
ch.ethz.ganymed ganymed-ssh2 build210
一、服务器登陆公钥秘钥设置
步骤如下:
1、本机生成私钥公钥文件
本机进入到.ssh目录下,c:/Users/zhufengyan/.ssh,在该目录下执行
$ssh-keygen-trsa
然后一路回车即可。
说明:如果原先./ssh目录下有id_rsaid_rsa.pub这两个文件,以上的一路回车操作会生成新的id_rsaid_rsa.pub来覆盖原来的key文件。
2、将本地生成的公钥信息放到服务器
将本地生成的公钥信息放置到需要访问的服务器,操作如下:
本地获取公钥信息,复制信息
Xshell登录服务器,加入你有root权限,
Cd/root/.ssh
Viauthorized_keys
将以上复制的内容粘贴到文件尾部。Ok完成。
说明:假设你的服务器上没有authorized_keys这个文件,那么就自己创建一个,创建完后将公钥信息粘贴到这个文件中,保存,还需要进行授权,chmod600authorized_keys。
另外:ssh公钥生效需满足至少下面两个条件:
1.ssh目录的权限必须是700;
2.ssh/authorized_keys文件权限必须是600;
二、连接服务器
步骤如下
1、将私钥文件放到项目的resources目录下
则代码中访问的路径是
privateStringprivateKeypath="src/main/resources/sshkey/id_rsa";
2、代码实现连接服务器
/** *建立与服务器的连接 *@paramhost服务器IPStringhost="192.168.178.1"; *@paramport端口intport=22;(默认的,直接用即可) *@paramuserName登录服务器的用户名(work) *@parampassword登录服务器的密码(为空就行) *@paramprivateKeyFile与服务器公钥对应的私钥文件Stringpubkeypath="src/main/resources/sshkey/id_rsa"; *@return返回登录的连接,在使用的最后一定记得关闭connect资源 *@throwsIOException */ publicstaticConnectiongetSSHConnection(Stringhost,intport,StringuserName,Stringpassword,StringprivateKeyFile)throwsIOException{ Connectionconnection=newConnection(host,port); connection.connect(); Filefile=newFile(privateKeyFile); booleanb=connection.authenticateWithPublicKey(userName,file,password); if(b){ returnconnection; }else{ System.out.println("登录连接失败,请检查用户名、密码、私钥文件"); returnnull; } }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。