当前位置: 首页 > news >正文

上市设计网站wordpress上传到阿里云

上市设计网站,wordpress上传到阿里云,安装好采集侠网站地图后在哪里查看网站地图,WordPress允许评论编辑文章目录 1. 什么是SFTP2. 什么是Jsch以及它的作用3. Linux中配置SSH密钥登录4. sftp服务器认证机制5. publickey和password两种方式登录sftp的API调用6. 代码可以如下改造#xff1a; 需求#xff1a;做一个通过ssh免密登录的需求#xff0c;是基于原先密码登录sftp服务器的… 文章目录 1. 什么是SFTP2. 什么是Jsch以及它的作用3. Linux中配置SSH密钥登录4. sftp服务器认证机制5. publickey和password两种方式登录sftp的API调用6. 代码可以如下改造 需求做一个通过ssh免密登录的需求是基于原先密码登录sftp服务器的代码上进行改造 1. 什么是SFTP SFTP是一个安全文件传送协议可以为传输文件提供一种安全的加密方法。SFTP 为 SSH的一部份是一种传输文件到服务器的安全方式。SFTP是使用加密传输认证信息和传输的数据所以使用SFTP是非常安全的。但是由于这种传输方式使用了加密/解密技术所以传输效率比普通的FTP要低得多如果您对网络安全性要求更高时可以使用SFTP代替FTP。 2. 什么是Jsch以及它的作用 Jsch是一个纯粹的用java实现SSH功能的java library。如果要知道Jsch的功能需先了解一下SSH。SSH是一个安全协议用来在不同系统或者服务器之间进行安全连接在连接和传送数据的过程中会进行加密。SSH一般是基于客户端的或者Linux命令行比如window同过OpenSSH、putty等客户端的工具在linux上可以通过ssh usernamehost命令进行连接。但是如果在Java中如何实现SSH呢?这时候便是通过JSCH来实现此的功能。 3. Linux中配置SSH密钥登录 SSH 免密登录可以让用户在不输入密码的情况下登录远程服务器提高登录效率和安全性 步骤 在本机中生成秘钥SSH有专门创建SSH密钥的工具ssh-keygen - 生成旧版密钥的命令ssh-keygen -m PEM -t rsa - 生成新版密钥命令ssh-keygen -t rsapassphrase生成密钥时的密码执行结束后~/.ssh/目录下会多两个文件id_rsa私钥、id_rsa.pub公钥 id_rsa私钥 id_rsa.pub公钥给目标服务器添加公钥 ssh-copy-id 用户名主机 公钥将被复制到目标服务器的~/.ssh/authorized_keys文件中。 ssh-copy-id -p 19222 lihw10.1.61.118或 将公钥ftp到目标服务器的.ssh后cd ~/.ssh手动将公钥导入到authorized_keys信任列表 cat 公钥 authorized_keys更新权限公钥权限 # 自此SSH免密登录配置完成。 chmod 644 authorized_keys配置服务器 在目标服务器上使用文本编辑器打开SSH服务器的配置文件通常为/etc/ssh/sshd_config sudo nano /etc/ssh/sshd_config确保以下配置选项的值为yes如果不是请进行相应修改 RSAAuthentication yes PubkeyAuthentication yes保存修改并关闭配置文件。 重新启动SSH服务器以应用更改 sudo service ssh restart测试使用密钥登录 ssh -p 19222 lihw10.1.61.1184. sftp服务器认证机制 Jsch提供了四种认证机制 password 密码方式publickey(DSARSA) 公私钥方式keyboard-interactivegss-api-with-mic 其中publickey方式通过配置公私钥实现SSH免密登录这里也只是简单讲一下它的使用。 5. publickey和password两种方式登录sftp的API调用 SSH公钥检查机制 公钥检查机制是一个安全机制可以防范中间人劫持等黑客攻击。SSH连接远程主机时会检查主机的公钥。如果是第一次该主机会显示该主机的公钥摘要提示用户是否信任该主机。当选择接受就会将该主机的公钥追加到文件 ~/.ssh/known_hosts 中。当再次连接该主机时就不会再提示该问题了。 但是在某些特殊的情况下严格的SSH公钥检查可能会破坏一些依赖SSH协议的自动化任务如Java的Jsch免密登录sftp程序。解决方式为调整StrictHostKeyChecking配置指令。StrictHostKeyChecking选项如下3种 session.setConfig(StrictHostKeyChecking, no/ask/yes);no 最不安全的级别当然也没有那么多烦人的提示了相对安全的内网测试时建议使用。如果连接server的key在本地不存在那么就自动添加到文件中(默认是known_hosts)并且给出一个警告。ask 默认的级别就是出现刚才的提示了。如果连接和key不匹配给出提示并拒绝登录。yes 最安全的级别如果连接与key不匹配就拒绝连接不会提示详细信息。 下面根据password来分析publickey方式与其区别 原来password方式需要这样一段代码来设置密码session.setPassword (properties.getPassword ()); 但是ssh key的方式就没有password了所以这段要删掉。publickey需要设置我们的ssh私钥文件的全路径privateKeyFilejsch.addIdentity (properties.getPrivateKeyFile ());一般私钥文件需要口令passphrase才能读取这需要设置一个配置类对象在jsch里其实需要自己搞一个简单的接口实现如下SftpAuthKeyUserInfo类 然后增加session.setUserInfo(new SftpAuthKeyUserInfo (properties.getPassphrase ())); 6. 代码可以如下改造 设置配置类对象 SftpAuthKeyUserInfo.java import com.jcraft.jsch.UserInfo; import lombok.extern.slf4j.Slf4j;/*** ssh private key passphrase info*/ Slf4j public class UserInfoImpl implements UserInfo {/*** ssh private key passphrase*/private String passphrase;public UserInfoImpl (String passphrase) {this.passphrase passphrase;}Overridepublic String getPassphrase() {return passphrase;}Overridepublic String getPassword() {return null;}Overridepublic boolean promptPassphrase(String s) {return true;}Overridepublic boolean promptPassword(String s) {return false;}Overridepublic boolean promptYesNo(String s) {return true;}Overridepublic void showMessage(String message) {log.info (SSH Message:{}, message);} }改造以适配publickey登录方式 try {JSch jsch new JSch();session jsch.getSession(sftpProperties.getUsername(),sftpProperties.getHost(), sftpProperties.getPort());if (sftpProperties.isCheckToHostKey()) {session.setConfig(PreferredAuthentications, publickey);session.setConfig(userauth.gssapi-with-mic, no);session.setConfig(StrictHostKeyChecking, ask);session.setUserInfo(new SftpAuthKeyUserInfo(sftpProperties.getPassword()));jsch.addIdentity(sftpProperties.getKeyPath());} else {session.setConfig(PreferredAuthentications, password);session.setConfig(StrictHostKeyChecking, no);session.setPassword(sftpProperties.getPassword());}session.setConfig(UseDNS, no);session.setConfig(kex, diffie-hellman-group1-sha1, diffie-hellman-group-exchange-sha1, diffie-hellman-group-exchange-sha256);session.connect(sftpProperties.getConnectTimeout());channelSftp (ChannelSftp) session.openChannel(sftp);channelSftp.connect();originalDir channelSftp.pwd();} catch (Exception e) {disconnect();throw new IllegalStateException(failed to create sftp Client, e);}properties为自定义sftp服务端配置 package io.github.lihewei7.easysftp.config;import org.springframework.boot.context.properties.ConfigurationProperties; import java.util.LinkedHashMap;/*** explain: SFTP client configuration information* author: lihewei */ ConfigurationProperties(sftp) public class SftpProperties {private String host localhost;private int port 22;private String username;private String password ;/*** Connection timeout.*/private int connectTimeout 0;/*** Enable jsch log, Cannot be individually turned on or off for one of multiple hosts.*/private boolean enabledLog false;/*** Whether to use a key to log in*/private Boolean isCheckToHostKey false;/*** SSH kex algorithms.*/private String kex;/*** host key.*/private String keyPath;/*** Configuring multiple hosts.*/private LinkedHashMapString,SftpProperties hosts;public LinkedHashMapString, SftpProperties getHosts() {return hosts;}public void setHosts(LinkedHashMapString, SftpProperties hosts) {this.hosts hosts;}public String getHost() {return host;}public void setHost(String host) {this.host host;}public int getPort() {return port;}public void setPort(int port) {this.port port;}public String getUsername() {return username;}public void setUsername(String username) {this.username username;}public String getPassword() {return password;}public void setPassword(String password) {this.password password;}public boolean isEnabledLog() {return enabledLog;}public void setEnabledLog(boolean enabledLog) {this.enabledLog enabledLog;}public int getConnectTimeout() {return connectTimeout;}public void setConnectTimeout(int connectTimeout) {this.connectTimeout connectTimeout;}public Boolean isCheckToHostKey() {return isCheckToHostKey;}public void setCheckToHostKey(Boolean checkToHostKey) {isCheckToHostKey checkToHostKey;}public String getKex() {return kex;}public void setKex(String kex) {this.kex kex;}public String getKeyPath() {return keyPath;}public void setKeyPath(String keyPath) {this.keyPath keyPath;} }
http://www.hkea.cn/news/14265420/

相关文章:

  • 龙华网站建设价格网站收费模板
  • 网站建设书籍资料购物商城网站开发目的文档
  • 网站设计与实现菏泽炫佑网站建设
  • 网站建设方案 文库网站首页怎样排版
  • 安居客网站怎么做如何看网站的流量
  • 建网站服务开发软件需要哪些技术
  • 建设信用卡银行积分商城网站建设网站需要的资金清单
  • 网站建设好了还要收取维护费站长之家域名解析
  • 在别人的网站做域名跳转辛集网站建设
  • 职业院校专题建设网站他人盗用公司资料建设网站怎么处理
  • 道客网站建设推广ps设计素材网站
  • 有没有网站做字体变形美食地图网站开发
  • 负责网站建设推广合肥网站建设哪里好
  • ps海报制作教程步骤的网站北京定制网页
  • wap网站 手机网站公司网站建设付款分录
  • 自己怎么做新闻开头视频网站海珠区住房和建设水务局网站
  • 免费网站站长学软件开发好还是网站开发好
  • 网站恶意点击软件做销售网站的公司哪家最好
  • 做pos机网站有必要么电子商务网站购物流程图
  • 做一个自适应网站多少钱工程建设游戏
  • 快捷做网站wordpress虚拟主机如何安装
  • 做传媒网站公司一般购物网站有哪些模块
  • 如何知道网站什么时候做的建筑做文本网站
  • 陕西网站seo6黄页网站建设
  • 网站建设项目软件开发招标文件杭州 高端网站建设
  • 为什么做网站的会弄友情链接网站建设硬件条件
  • 怎样建立个人的网站泉州建设部网站
  • 河南省百城建设提质网站微信h5
  • 如何让自己网站排名提高手机在线做ppt的网站
  • 360网站空间做商业地产常用的网站