java j2ssh替代jsch,jsch设置ssh协商算法优先级

最近接触jsch这个包,发现在默认情况下,jsch登录ssh的时候,协商的加密算法和mac算法都不是最高优先级的,这个时候需要手动配置一下算法列表,将强度高的调整在算法列表的前面,这样ssh链接的时候,如果双方都,就会协商成高优先级算法。代码参数jsch的示例,只是添加了一个配置文件,通过wireshark抓包来观测配置前后的变化。

测试结果:

默认不配置:

d76448202f86edce6433125939591060.png

配置算法列表:

8cd82bc0527cb4dcf147bf516e3a098a.png

代码:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

importjava.io.InputStream;

importjava.util.Properties;

importcom.jcraft.jsch.*;

publicclassjschSample{

publicstaticvoidmain(String[]args){

// TODO Auto-generated method stub

Propertiesp=newProperties();

p.setProperty("cipher.s2c","aes256-ctr,aes192-ctr,aes128-ctr");

p.setProperty("cipher.c2s","aes256-ctr,aes192-ctr,aes128-ctr");

p.setProperty("mac.s2c","hmac-sha2,hmac-sha1");

p.setProperty("mac.c2s","hmac-sha2,hmac-sha1");

p.setProperty("kex","ecdh-sha2-nistp256");

p.setProperty("StrictHostKeyChecking","no");

try{

JSchjsch=newJSch();

Sessionsession=jsch.getSession("pi","192.168.1.7",22);

session.setConfig(p);

session.setPassword("raspberry");

session.connect();

Channelchannel=session.openChannel("exec");

((ChannelExec)channel).setCommand("pwd");

channel.setInputStream(null);

InputStreamin=channel.getInputStream();

channel.connect();

byte[]tmp=newbyte[1024];

while(true){

while(in.available()>0){

inti=in.read(tmp,0,1024);

if(i<0)break;

System.out.print(newString(tmp,0,i));

}

if(channel.isClosed()){

if(in.available()>0)continue;

System.out.println("exit-status: "+channel.getExitStatus());

break;

}

try{Thread.sleep(1000);}catch(Exceptionee){}

}

channel.disconnect();

session.disconnect();

}

catch(Exceptione)

{

System.out.println(e);

}

}

}

捕获到的jsch0.1.55版本消息算法列表如下(encryption_algorithms/mac_algorithms算法s2c和c2s是一样的):

kex_algorithms string:

ecdh-sha2-nistp256,ecdh-sha2-nistp384,ecdh-sha2-nistp521,diffie-hellman-group14-sha1,diffie-hellman-group-exchange-sha256,diffie-hellman-group-exchange-sha1,diffie-hellman-group1-sha1

server_host_key_algorithms string:

ssh-rsa,ssh-dss,ecdsa-sha2-nistp256,ecdsa-sha2-nistp384,ecdsa-sha2-nistp521

encryption_algorithms_client_to_server string:

aes128-ctr,aes128-cbc,3des-ctr,3des-cbc,blowfish-cbc,aes192-ctr,aes192-cbc,aes256-ctr,aes256-cbc

mac_algorithms_client_to_server string:

hmac-md5,hmac-sha1,hmac-sha2-256,hmac-sha1-96,hmac-md5-96

相关

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/527143.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

php验证码图片乱码,php ,验证码图片,乱码

找不出哪里出错了&#xff0c;但是预览时就是会出现一大堆乱码回复讨论(解决方案)乱码是浏览器显示了字符而不是图片么&#xff1f;关闭浏览器重新访问这个地址试试。如果还不行&#xff0c;应该是header的问题。图片输出&#xff0c;最好用UTF-8字符集&#xff0c;因为有可能会…

java 截取汉字首字母,java 取汉字首字母

有时候&#xff0c;可能会有一些类似这样的需求&#xff1a;对于这样的效果&#xff0c;我们可以有类似这样的解决方案&#xff1a;package bys.utils;import java.io.UnsupportedEncodingException;/*** Created by toutou on 2014/2/21*/public class ChineseCharacterHelper…

php给别人写接口,php给客户端写接口记录

通过控制器实现类似Java的工厂模式在主入口文件中通过DIRECTORY_SEPARATOR和dirname(__FILE__)以及url中的参数拼接控制模块文件&#xff0c;通过include 进入子控制模块$l DIRECTORY_SEPARATOR;$dir dirname(__FILE__);$ctrlName trim($operation);$controllerFile "…

html wap php,wap.php

header(Content-type:text/html; Charsetutf-8);/*** 请填写以下配置信息 ***/$appid xxxxx; //https://open.alipay.com 账户中心->密钥管理->开放平台密钥&#xff0c;填写添加了电脑网站支付的应用的APPID$returnUrl http://www.xxx.com/alipay/return.php; //付款成…

php5.0相等,关于php:3个相等

&#xff0c;和有什么区别&#xff1f;我认为使用一个等号表示变量&#xff0c;而使用两个等号表示比较条件&#xff0c;最后使用三个等号表示比较变量的值。看看这个例子...我已经发布了&#xff0c;它将澄清更多的事情..对于高级PHP用户&#xff0c;了解和之间的区别并问自己…

oracle中的自带函数,求完整的ORACLE自带函数文档

最初由 WL_ZCJ 发布[B]create or replace procedure p_97_auto_cron asret_flag number;ret_errmsg varchar2(200);as_area_id number;as_staff_id number;as_begin_time varchar2(20);as_end_time varchar2(20);beginas_staff_id : -1;for rec in (select 1 …

php数组排序综合例子,php数组实例之数组排序

1&#xff0c;php数组排序的小例子例1&#xff0c;sort()、rsort()/asort()、arsort()对数组排序&#xff1a;/p>$array array("b","c","d","a");sort($array);//从低到高排序print_r($array);echo "";rsort($array);//…

oracle 正则表达式匹配日期格式,利用正则表达式找出不合符的日期

很多时候我们的日期可能存放的是字符串类型&#xff0c;在插入的时候也很有可能插入的日期格式不正确&#xff0c;因此我们需要找出这些不合符的日期格式&#xff0c;来此来修正。当然可以使用TO_DATE函数一个一个的转换来找出不合法的日期。ORACLE提供了正则表达式&#xff0c…

cx oracle 中文 u,cx\U Oracle永久连接

我有一个任务是用cxu Oracle为两个进程创建持久连接。在它需要在同一事务中执行来自第一个进程的一些请求&#xff0c;延迟来自第二个进程的一些请求。在如中所述尝试使用DRCP时下一个代码&#xff1a;#coding: utf-8import cx_Oraclecon1 cx_Oracle.connect(user/pass:127.0.…

oracle amm和asmm,AMM与ASMM

一、AMM相关知识&#xff1a;1.从oracle 11.1开始oracle提供了通过MEMORY_TARGET参数实现自动SGA和PGA自动管理的功能&#xff0c;从此版本开始不再需要明确设置SGA_TARGET及PGA_AGGREGATE_TARGET&#xff0c;这个被支持在linux、windows、solaris、hpux、aix。2.在使用MEMORY_…

oracle display set,Check if the DISPLAY variable is set

1.oracle安装报错如下&#xff1a;Checking Temp space: must be greater than 120 MB. Actual 109499 MB PassedChecking swap space: must be greater than 150 MB. Actual 8191 MB PassedChecking monitor: must be configured to display at least 256 colors>…

linux 系统改名,linux改名命令

弹性云服务器 ECS弹性云服务器(Elastic Cloud Server)是一种可随时自助获取、可弹性伸缩的云服务器&#xff0c;帮助用户打造可靠、安全、灵活、高效的应用环境&#xff0c;确保服务持久稳定运行&#xff0c;提升运维效率三年低至5折&#xff0c;多种配置可选了解详情弹性云服务…

linux确定刻录机目录,在Linux操作系统下使用DVD刻录机(转)

在Linux操作系统下使用DVD刻录机(转)[more]  现在&#xff0c;越来越多的用户开始装备DVD刻录机。在Windows平台上使用DVD刻录机应该不存在什么问题&#xff0c;那么在Linux平台又应该如何使用DVD刻录机呢&#xff1f;一、安装要想在Linux环境中使用DVD刻录机&#xff0c;先必…

linux操作系统网络,网络安装linux操作系统

网络安装安装的准备首先配仓库然后需要安装的服务Yun y install tftp-serverYum y install dhcp开始实验配仓库安装tfpt包并进行配置Tftp-server dhcp tftp后&#xff0c;会在/var/lib/tftpboot这个文件&#xff0c;这个文件是作为linux安装的引导文件&#xff0c;将/mnt/isoli…

Linux使用ftp传输10g的文件,Ubuntu 16.04 安装ftp服务器传输文件

最近在搞深度学习&#xff0c;老师比较宝贝他的服务器&#xff0c;要求我以后负责管理服务器。往后所有要使用服务器的人都必须向我申请账号&#xff0c;然后只允许客户端访问&#xff0c;使用文件传输软件传输文件。像我这样一个Linux菜逼&#xff0c;这种要求不是赶鸭子上架嘛…

linux ks脚本,kickstar-KS文件和语法解析

# KS文件和语法解析[TOC]## 1ks说明### 1.1ks文件说明使用kickstart&#xff0c;只需事先定义好一个Kickstart自动应答配置文件ks.cfg(通常存放在安装服务器上)&#xff0c;并让安装程序知道该配置文件的位置&#xff0c;在安装过程中安装程序就可以自己从该文件中读取安装配置…

linux打印服务叹号,linux中如何通过echo输出!(叹号)? -bash: !: event not found

需求描述:今天在做通过echo结合passwd给用户改密码的过程中,出现无法修改的错误.错误如下:[roottestvm ~]# useradd mytest[roottestvm ~]# echo "mytest!" | passwd --stdin mytest-bash: !": event not found错误分析:经过查找该命令发现叹号!在linux中有特殊…

linux磁盘资源,liunxCPU和内存,磁盘等资源,

liunxCPU和内存&#xff0c;磁盘等资源&#xff0c;1.Screen是一款由GNU计划开发的用于命令行终端切换的自由软件。用户可以通过该软件同时连接多个本地或远程的命令行会话&#xff0c;并在其间自由切换。GNU Screen可以看作是窗口管理器的命令行界面版本。它提供了统一的管理多…

linux降低线程优先级,Linux线程优先级,行为不正常

在下面的代码片段中&#xff0c;我创建了6个线程。各有不同的优先级。全局优先级数组中提到了优先级。我正在根据线索索引在每个线程内连续增加全局变量。如果线程优先级更高&#xff0c;我期待计数更高。但我的输出不遵循优先概念pl。请参阅下面显示的输出顺序。我在Ubuntu 16…

linux非阻塞等待线程,linux – 即使异步I / O操作挂起,只有线程处理io_service正在等待...

这是一个错误.我已经能够通过在task_io_service :: do_poll_one的非关键部分添加延迟来复制它.以下是booost/asio/detail/impl/task_io_service.ipp中修改后的task_io_service :: do_poll_one()的片段.添加的唯一行是sleep.std::size_t task_io_service::do_poll_one(mutex::sc…