SFTP信任公钥配置及JSCH库
1、SFTP信用公钥配置
1.1 客户端生成密钥对
以DSA举例:
ssh-keygen –t dsa
执行该命令后,在home/用户名/.ssh目录下,会生成id_dsa和id_dsa.pub两个文件
1.2 将id_dsa.pub公钥文件上传至服务端的home/用户名/.ssh目录下
scp id_dsa.pub 用户名@服务端IP:/home/用户名/.ssh
此时还需要输入密码
1.3服务端添加信任公钥
登录服务端,进入到/home/用户名/.ssh目录,将刚刚拷贝的id_dsa.pub文件的内容加入到authorized_keys文件中
cat id_dsa.pub >> authorized_keys
1.4 服务端分别修改authorized_key文件和.ssh的权限为600和700
chmod 600 authorized_keys
chmod 700 .ssh
1.5 测试
在客户端执行:
sftp –oPort=端口 用户名@服务端IP
如果不需要输入密码就可以连上,则说明配置成功
2、基于JSCH库的sftp操作
- public class SftpUtil {
- private final static Logger log = LoggerFactory.getLogger(SftpUtil.class);
- /** SFTP */
- public static final String SFTP = "sftp";
- /** 通道 */
- private ChannelSftp channel;
- /** session */
- private Session session;
- /** 规避多线程并发 */
- private static ThreadLocal<SftpUtil> sftpLocal = new ThreadLocal<SftpUtil>();
- /**
- * 获取sftpchannel
- *
- * @param connectConfig 连接配置
- * @return
- * @throws Exception
- * @throws JSchException
- */
- private void init(ConnectConfig connectConfig) throws Exception {
- String host = connectConfig.getHost();
- int port = connectConfig.getPort();
- String userName = connectConfig.getUserName();
- //创建JSch对象
- JSch jsch = new JSch();
- //添加私钥(信任登录方式)
- if (StringUtils.isNotBlank(connectConfig.getPrivateKey())) {
- jsch.addIdentity(connectConfig.getPrivateKey());
- }
- session = jsch.getSession(userName, host, port);
- if (log.isInfoEnabled()) {
- log.info(" JSCH Session created,sftpHost = {}, sftpUserName={}", host, userName);
- }
- //设置密码
- if (StringUtils.isNotBlank(connectConfig.getPassWord())) {
- session.setPassword(connectConfig.getPassWord());
- }
- Properties config = new Properties();
- config.put("StrictHostKeyChecking", "no");
- session.setConfig(config);
- //设置超时
- session.setTimeout(connectConfig.getTimeout());
- //建立连接
- session.connect();
- if (log.isInfoEnabled()) {
- log.info("JSCH Session connected.sftpHost = {}, sftpUserName={}", host, userName);
- }
- //打开SFTP通道
- channel = (ChannelSftp) session.openChannel(SFTP);
- //建立SFTP通道的连接
- channel.connect();
- if (log.isInfoEnabled()) {
- log.info("Connected successfully to sftpHost = {}, sftpUserName={}", host, userName);
- }
- }
- /**
- * 是否已连接
- *
- * @return
- */
- private boolean isConnected() {
- return null != channel && channel.isConnected();
- }
- /**
- * 获取本地线程存储的sftp客户端
- *
- * @return
- * @throws Exception
- */
- public static SftpUtil getSftpUtil(ConnectConfig connectConfig) throws Exception {
- SftpUtil sftpUtil = sftpLocal.get();
- if (null == sftpUtil || !sftpUtil.isConnected()) {
- sftpLocal.set(new SftpUtil(connectConfig));
- }
- return sftpLocal.get();
- }
- /**
- * 释放本地线程存储的sftp客户端
- */
- public static void release() {
- if (null != sftpLocal.get()) {
- sftpLocal.get().closeChannel();
- sftpLocal.set(null);
- }
- }
- /**
- * 构造函数
- * <p>
- * 非线程安全,故权限为私有
- * </p>
- *
- * @throws Exception
- */
- private SftpUtil(ConnectConfig connectConfig) throws Exception {
- super();
- init(connectConfig);
- }
- /**
- * 关闭通道
- *
- * @throws Exception
- */
- public void closeChannel() {
- if (null != channel) {
- try {
- channel.disconnect();
- } catch (Exception e) {
- log.error("关闭SFTP通道发生异常:", e);
- }
- }
- if (null != session) {
- try {
- session.disconnect();
- } catch (Exception e) {
- log.error("SFTP关闭 session异常:", e);
- }
- }
- }
- /**
- * 下载文件
- *
- * @param downDir 下载目录
- * @param src 源文件
- * @param dst 保存后的文件名称或目录
- * @throws Exception
- */
- public void downFile(String downDir, String src, String dst) throws Exception {
- channel.cd(downDir);
- channel.get(src, dst);
- }
- /**
- * 删除文件
- *
- * @param filePath 文件全路径
- * @throws SftpException
- */
- public void deleteFile(String filePath) throws SftpException {
- channel.rm(filePath);
- }
- @SuppressWarnings("unchecked")
- public List<String> listFiles(String dir) throws SftpException {
- Vector<LsEntry> files = channel.ls(dir);
- if (null != files) {
- List<String> fileNames = new ArrayList<String>();
- Iterator<LsEntry> iter = files.iterator();
- while (iter.hasNext()) {
- String fileName = iter.next().getFilename();
- if (StringUtils.equals(".", fileName) || StringUtils.equals("..", fileName)) {
- continue;
- }
- fileNames.add(fileName);
- }
- return fileNames;
- }
- return null;
- }
- }
说明:
2.1 ConnectConfig包含了建立sftp连接所需要的全部参数信息
2.2 如果按照第一步进行了sftp的信任公钥配置,则需要通过调用jsch的addIdentity方法将密钥对中的私钥id_dsa设置进去
- //添加私钥(信任登录方式)
- if (StringUtils.isNotBlank(connectConfig.getPrivateKey())) {
- jsch.addIdentity(connectConfig.getPrivateKey());
- }
2.3 为了避免频繁的进行连接建立和连接释放操作,一般会定义为单例模式,但存在某些业务场景,需要在同一个线程执行完连续几次完整的业务操作后,将连接释放掉。如果采用单例,那么多线程并发的场景下会出现共享资源竞争导致的并发问题,譬如在B线程执行业务的过程中,A线程将连接释放。因此,可以借助ThreadLocal来避免该问题。
- /**
- * 获取本地线程存储的sftp客户端
- *
- * @return
- * @throws Exception
- */
- public static SftpUtil getSftpUtil(ConnectConfig connectConfig) throws Exception {
- SftpUtil sftpUtil = sftpLocal.get();
- if (null == sftpUtil || !sftpUtil.isConnected()) {
- sftpLocal.set(new SftpUtil(connectConfig));
- }
- return sftpLocal.get();
- }
- /**
- * 释放本地线程存储的sftp客户端
- */
- public static void release() {
- if (null != sftpLocal.get()) {
- sftpLocal.get().closeChannel();
- sftpLocal.set(null);
- }
- }
SFTP信任公钥配置及JSCH库的更多相关文章
- linux信任公钥的配置
一.每个用户都有自己的家目录 访问方式是:~/.ssh/id_rsa.pub 使用~就是表示家目录. 具体家目录在哪里,在用户密码配置文件中:/etc/passwd中.第6列的值就是. 可以使用~访问 ...
- Git 实用基础(配置,建库,提交,推送 GitHub)
Git 实用基础(配置,建库,提交,推送 GitHub) SVN ? Git ? 目前市面上主流的版本控制系统就是 SVN 和 Git . 两者的区别简单通俗地说就是,版本数据是否有在本地. 如果觉得 ...
- Linux中安装C++编译器codeBlock,并配置opencv链接库
1.Linux中安装codeBlock https://blog.csdn.net/xinyunyishui/article/details/50967395 2.CodeBlock中的中文显示不完全 ...
- Git SSH公钥配置
https://www.cnblogs.com/smuxiaolei/p/7484678.html https://blog.csdn.net/weixin_42063071/article/deta ...
- SFTP 安装与配置
SFTP 安装与配置 sftp 是 Secure File Transfer Protocol 的缩写,安全文件传送协议.可以为传输文件提供一种安全的加密方法.SFTP 为 SSH 的一部分,由于这种 ...
- rsa字符串格式公钥转换python rsa库可识别的公钥形式
在爬虫分析的时候,经常在网页上看到如下格式的rsa公钥: MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDC7kw8r6tq43pwApYvkJ5laljaN9BZb21 ...
- Sftp搭建与配置参考
Sftp搭建与配置参考 1. 介绍 sftp是Secure File Transfer Protocol的缩写,安全文件传送协议.可以为传输文件提供一种安全的加密方法.sftp 与 ftp 有着几乎一 ...
- Gerrit+apache+H2数据库简单安装配置及建库流程
Gerrit 是一个基于 Web 的代码评审和项目管理的工具,面向基于 Git 版本控制系统的项目.因此需要Apache.Mysql.GIT等相关软件的支持 系统配置: 新装的UBANTU LINUX ...
- maven的安装、路径配置、修改库文件路径和eclipse中的配置、创建maven工程。
注:本文来源于:杨四郎2018 <maven的安装.路径配置.修改库文件路径和eclipse中的配置.创建maven工程> 一.maven的安装 首先,先到官网去下载maven.这里是官 ...
随机推荐
- Sigmoid function in NN
X = [ones(m, ) X]; temp = X * Theta1'; t = size(temp, ); temp = [ones(t, ) temp]; h = temp * Theta2' ...
- [Leetcode] Container With Most Water ( C++)
题目: Given n non-negative integers a1, a2, ..., an, where each represents a point at coordinate (i, a ...
- 用GDAL/OGR去读shapefile
一.读shapefile 1.首先,用Arcgis创建所要读的shp文件.打开ArcCatalog,右键NEW->Shapefile,名称Name:point ,要素类型(Feature Typ ...
- Virtual Environments
virtualenv 再另一篇随笔中已经提到过virtualenv.如果我们有好几个不同的项目,他们需要的第三方包版本不同,那怎么办呢.这时候就需要virtualenv创建一个虚拟环境,里面包含了一个 ...
- 轻量jquery框架之--组件交互基础设计
概要 组件交互基础,即考虑在JQUERY对象下($)下扩展所有组件都需要用到的通用api,如ajax入口.对表单的操作.html片段加载.通用的配合datagrid通用的curd客户端对象等. 扩展a ...
- 写jQuery插件时,一种更好的合并参数的方法
看到很多人写jQuery插件时居然这样合并参数: this.defaults = { 'color': 'red', 'fontSize': '12px', 'textDecoration':'non ...
- python随机产生4个互不相等的随机数
从0-9中随机产生4个互不相等的数, 方法一: import random s=[] while(len(s)<4): x=random.randint(0,9) if x not in s: ...
- 动态加载JS过程中如何判断JS加载完成
在正常的加载过程中,js文件的加载是同步的,也就是说在js加载的过程中,浏览器会阻塞接下来的内容的解析.这时候,动态加载便显得尤为重要了,由于它是异步加载,因此,它可以在后台自动下载,并不会妨碍其它内 ...
- hdu 2489 Minimal Ratio Tree
http://acm.hdu.edu.cn/showproblem.php?pid=2489 这道题就是n个点中选择m个点形成一个生成树使得生成树的ratio最小.暴力枚举+最小生成树. #inclu ...
- NOI十连测 第六测 T3
思路:考试的时候我非常地**,写了圆并,然后还TM写了半平面交和三角剖分,虽然只有30分..但是看在我写了500行的份上还是挂着吧.. #include<cstdio> #include& ...