public enum HandshakeType { HELLO_REQUEST(0), CLIENT_HELLO(1), SERVER_HELLO(2), // certificate CERTIFICATE(3), // server_key_exchange (12) SERVER_KEY_EXCHANGE(12), // certificate_request(13) CERTIFICATE_REQUEST(13), // server_hello_done(14) SERVER_HELLO_DONE(14), // certificate_verify(15) CERTIFICATE_VERIFY(15), // client_key_exchange(16) CLIENT_KEY_EXCHANGE(16), // finished(20) FINISHED(20); private int value; private HandshakeType(int value) { this.value = value; } public int value() { return value; } }
public abstract class Handshake { public abstract ByteArrayOutputStream body() throws IOException; }
public enum ContentType { CHANGE_CIPHER_SPEC(20), ALERT(21), HANDSHAKE(22), APPLICATION_DATA(23); private int value; private ContentType(int value) { this.value = value; } public int value() { return value; } }
public enum CipherSuite { TLS_NULL_WITH_NULL_NULL((byte) 0x00, (byte) 0x00), TLS_RSA_WITH_NULL_MD5((byte) 0x00, (byte) 0x01), TLS_RSA_WITH_NULL_SHA((byte) 0x00, (byte) 0x02), TLS_RSA_EXPORT_WITH_RC4_40_MD5((byte) 0x00, (byte) 0x03), TLS_RSA_WITH_RC4_128_MD5((byte) 0x00, (byte) 0x04), TLS_RSA_WITH_RC4_128_SHA((byte) 0x00, (byte) 0x05), TLS_RSA_EXPORT_WITH_RC2_CBC_40_MD5((byte) 0x00, (byte) 0x06), TLS_RSA_WITH_IDEA_CBC_SHA((byte) 0x00, (byte) 0x07), TLS_RSA_EXPORT_WITH_DES40_CBC_SHA((byte) 0x00, (byte) 0x08), TLS_RSA_WITH_DES_CBC_SHA((byte) 0x00, (byte) 0x09), TLS_RSA_WITH_3DES_EDE_CBC_SHA((byte) 0x00, (byte) 0x0A), TLS_DH_DSS_EXPORT_WITH_DES40_CBC_SHA((byte) 0x00, (byte) 0x0B), TLS_DH_DSS_WITH_DES_CBC_SHA((byte) 0x00, (byte) 0x0C), TLS_DH_DSS_WITH_3DES_EDE_CBC_SHA((byte) 0x00, (byte) 0x0D), TLS_DH_RSA_EXPORT_WITH_DES40_CBC_SHA((byte) 0x00, (byte) 0x0E), TLS_DH_RSA_WITH_DES_CBC_SHA((byte) 0x00, (byte) 0x0F), TLS_DH_RSA_WITH_3DES_EDE_CBC_SHA((byte) 0x00, (byte) 0x10), TLS_DHE_DSS_EXPORT_WITH_DES40_CBC_SHA((byte) 0x00, (byte) 0x11), TLS_DHE_DSS_WITH_DES_CBC_SHA((byte) 0x00, (byte) 0x12), TLS_DHE_DSS_WITH_3DES_EDE_CBC_SHA((byte) 0x00, (byte) 0x13), TLS_DHE_RSA_EXPORT_WITH_DES40_CBC_SHA((byte) 0x00, (byte) 0x14), TLS_DHE_RSA_WITH_DES_CBC_SHA((byte) 0x00, (byte) 0x15), TLS_DHE_RSA_WITH_3DES_EDE_CBC_SHA((byte) 0x00, (byte) 0x16), TLS_DH_anon_EXPORT_WITH_RC4_40_MD5((byte) 0x00, (byte) 0x17), TLS_DH_anon_WITH_RC4_128_MD5((byte) 0x00, (byte) 0x18), TLS_DH_anon_EXPORT_WITH_DES40_CBC_SHA((byte) 0x00, (byte) 0x19), TLS_DH_anon_WITH_DES_CBC_SHA((byte) 0x00, (byte) 0x1A), TLS_DH_anon_WITH_3DES_EDE_CBC_SHA((byte) 0x00, (byte) 0x1B); private byte hb; private byte lb; private CipherSuite(byte high, byte low) { this.hb = high; this.lb = low; } public byte high() { return hb; } public byte low() { return lb; } }
public class ClientHello extends Handshake { // 23 * 16 + 3 public ByteArrayOutputStream body() throws IOException { ByteArrayOutputStream bos = new ByteArrayOutputStream(); bos.write(Test.MAJOR); bos.write(Test.MINOR); long ms = System.currentTimeMillis(); ms = ms / 1000; bos.write((int) ((ms << 32) >> 56)); bos.write((int) ((ms << 40) >> 56)); bos.write((int) ((ms << 48) >> 56)); bos.write((int) ((ms << 56) >> 56)); Random random = new Random(ms); byte[] random_bytes = new byte[28]; random.nextBytes(random_bytes); bos.write(random_bytes); // bos.write(0); // the length of session id, this value indicates the bytes of length // // if session id is empty, then the length of session id is zero // // and so here do not write session id byte[] sessionId = new byte[32]; Random sessionIdGenerator = new Random(System.currentTimeMillis()); sessionIdGenerator.nextBytes(sessionId); bos.write(sessionId.length); bos.write(sessionId); // // the length of cipher suite, this value indicates the bytes of cipher suite // bos.write(0); // bos.write(0); // // if doe's contains cipher suite, do not write cipher suites // the length of cipher suite, this value indicates the bytes of cipher suite bos.write(0); bos.write(2); bos.write(CipherSuite.TLS_DH_RSA_WITH_DES_CBC_SHA.high()); bos.write(CipherSuite.TLS_DH_RSA_WITH_DES_CBC_SHA.low()); bos.write(1); bos.write(0); return bos; } }
public class ClientHello extends Handshake { // 23 * 16 + 3 public ByteArrayOutputStream body() throws IOException { ByteArrayOutputStream bos = new ByteArrayOutputStream(); bos.write(Test.MAJOR); bos.write(Test.MINOR); long ms = System.currentTimeMillis(); ms = ms / 1000; bos.write((int) ((ms << 32) >> 56)); bos.write((int) ((ms << 40) >> 56)); bos.write((int) ((ms << 48) >> 56)); bos.write((int) ((ms << 56) >> 56)); Random random = new Random(ms); byte[] random_bytes = new byte[28]; random.nextBytes(random_bytes); bos.write(random_bytes); // bos.write(0); // the length of session id, this value indicates the bytes of length // // if session id is empty, then the length of session id is zero // // and so here do not write session id byte[] sessionId = new byte[32]; Random sessionIdGenerator = new Random(System.currentTimeMillis()); sessionIdGenerator.nextBytes(sessionId); bos.write(sessionId.length); bos.write(sessionId); // // the length of cipher suite, this value indicates the bytes of cipher suite // bos.write(0); // bos.write(0); // // if doe's contains cipher suite, do not write cipher suites // // the length of cipher suite, this value indicates the bytes of cipher suite // bos.write(0); // bos.write(2); // bos.write(CipherSuite.TLS_DH_RSA_WITH_DES_CBC_SHA.high()); // bos.write(CipherSuite.TLS_DH_RSA_WITH_DES_CBC_SHA.low()); // the length of cipher suite, this value indicates the bytes of cipher suite bos.write(0x00); bos.write(0x38); byte[] cipherSuites = new byte[] {(byte)0xc0, (byte)0x14, (byte)0x00, (byte)0x88, (byte)0x00, (byte)0x87, (byte)0x00, (byte)0x39, (byte)0x00, (byte)0x38, (byte)0xc0, (byte)0x0f, (byte)0x00, (byte)0x84, (byte)0x00, (byte)0x35, (byte)0xc0, (byte)0x11, (byte)0xc0, (byte)0x13, (byte)0x00, (byte)0x45, (byte)0x00, (byte)0x44, (byte)0x00, (byte)0x66, (byte)0x00, (byte)0x33, (byte)0x00, (byte)0x32, (byte)0xc0, (byte)0x0c, (byte)0xc0, (byte)0x0e, (byte)0x00, (byte)0x96, (byte)0x00, (byte)0x41, (byte)0x00, (byte)0x05, (byte)0x00, (byte)0x04, (byte)0x00, (byte)0x2f, (byte)0xc0, (byte)0x12, (byte)0x00, (byte)0x16, (byte)0x00, (byte)0x13, (byte)0xc0, (byte)0x0d, (byte)0xfe, (byte)0xff, (byte)0x00, (byte)0x0a}; bos.write(cipherSuites); bos.write(1); bos.write(0); return bos; } }
public class Test { // 版本由主版本和小版本组成:major.minor,如3.2,3表示主版本,2表示小版本 // 目前版本包括3.1, 3.2 // 主版本,3表示版本3.x, 3.0以上的版本。 public static final int MAJOR = 0x03; // 小版本 public static final int MINOR = 0x02; public static final int DEFAULT_PORT = 443; private Socket socket; public Test(String host) throws IOException { this(host, DEFAULT_PORT); } public Test(String host, int port) throws IOException { socket = new Socket(host, port); } public void handshake() throws IOException { OutputStream os = socket.getOutputStream(); ByteArrayOutputStream bos = new ByteArrayOutputStream(); bos.write(ContentType.HANDSHAKE.value()); bos.write(MAJOR); bos.write(MINOR); ByteArrayOutputStream bbos = hello(); int length = bbos.size(); bos.write((int) ((length << 16) >> 24)); bos.write((int) ((length << 24) >> 24)); bos.write(bbos.toByteArray()); os.write(bos.toByteArray()); InputStream is = socket.getInputStream(); } public ByteArrayOutputStream hello() throws IOException { ByteArrayOutputStream bos = new ByteArrayOutputStream(); bos.write(HandshakeType.CLIENT_HELLO.value()); ClientHello client_hello = new ClientHello(); ByteArrayOutputStream bbos = client_hello.body(); int length = bbos.size(); bos.write((int) ((length << 8) >> 24)); bos.write((int) ((length << 16) >> 24)); bos.write((int) ((length << 24) >> 24)); bos.write(bbos.toByteArray()); return bos; } }
public class TestTest { private static final String DEFAULT_HOST = "112.65.203.33"; private static com.chos.tls.Test test; @BeforeClass public static void initialize() throws IOException { test = new com.chos.tls.Test(DEFAULT_HOST); } @Test public void handshake() throws IOException { test.handshake(); } }
相关推荐
随便写的代码,大家随便看看
扫雷最简单的做法,大家来看看 内有代码。 扫雷游戏
闲来无事,上来看看,每次来都有点愧疚的感觉,老是索取代码提问,今天把我写的一个网络录音的程序放上来,本来是监视我女友用来的,我就随便写了写,录音部分是参照vckbase的录音api代码,结合了一小段socket(TCP)就可以...
1.手机先建立一个wifi网络 ssid随便写一个就ok 选中设备到设备 在填写个ip地址,跟子网掩码跟笔记本一个网段就行了 2.vs写个Server段程序,服务端负责接受客户端传过来的文件名,跟文件数据 接收文件名的代码如下 ...
然后,想想这样一个问题-----如何在已存在的文件中特定的位置上不定期地插入一段代码?(如:在典型的SSH框架的xml配置文件中,陆陆续续的添加Action,Domain,Service) 第一种方法: 解析这个文件,定位到插入位置,插入...
因为硬盘上有几个版本,懒得去看到底哪一个是图形识别版本或者内存扫描版本了,随便上传了一个,除了识别部分,其他差别不大,内存扫描版本也会遗留有图形识别的代码。有兴趣的可以研究其中的图形模糊识别定位以及...
没错就是万恶的8086汇编. 介绍不知道怎么写,随便贴一段代码吧.懂得人也大概知道这是大概什么样的了
这时候后如果我们在软件的注册失败的那段代码前面加一个跳转,说得容易理解一点就是:跳过软件注册码验证失败后应该运行的分支,而将它转到注册成功的那个分支上。那么这时候不管你输入的注册码是对是错,都会提示...
前言 快捷方式是一种特殊的文件,扩展名为 lnk。...这是最方便的方式了,因为这段代码随便放到一段代码中就能运行: /// /// 为当前正在运行的程序创建一个快捷方式。 /// /// 快捷方式的完全限定路径
PC-Lint是C/C++软件代码静态分析工具,你可以把它看作是一种更加严格的编译器。它不仅可以检查出一般的语法错误,还可以检查出那些虽然符合语法要求但不易发现的潜在错误。 C语言的灵活性带来了代码效率的提升,但...
第二,也就是代码的内容,这个全世界的影视作品都差不多,随便找一段代码粘上。战狼也不例外,东拼西凑了一些C语言代码。 只是战狼这个实在是太简单了,小编都能看懂,是粘贴的《C语言入门100例》中的一例,内容是...
这是一个纯java写的魔兽对战平台.不抓包.原理非常简单. 可以聊天,可以发布自己的魔兽主机.有人建立主机或者人满了也会有声音提示. 学习网络编程.非常好! 里面有许多注释.应该能看懂. 关于原理.博客上有详细介绍....
有的时候不知道自己的数据库连接是否存在问题的时候,可以用一小段代码进行测试下。这个测试代码较少,主要就是测试数据库的连接。如果输出“连接成功”说明没问题(注:这是连接sql server 数据库的代码,连接前先...
闲来无事,上来看看,每次来都有点愧疚的感觉,老是索取代码提问,今天把我写的一个网络录音的程序放上来,本来是监视我女友用来的,我就随便写了写,录音部分是参照 vckbase 的录音api代码 ,结合了一小段 socket(TCP) 就...
这个跟我在第二节里介绍的是一模一样的(第二节第10行),还有数据的处理函数,数据发送函数,判断连接已断开的代码与第二节也是一模一样的,不过在这里我们需要额外的添加一段代码,当判断出连接已断开的时候,我们要...
自己随便写的 用C语言实现的凯撒密码的加密解密小程序 密钥可以为任意整数 明文密文可以任意字符 含实验报告
3)但是过了一段时间,老板又跑过来和xx说,这一千个方法又要调用日志打印的方法功能,同时又要添加用户合法性验证。这个时候xx有两种选择: 1)对老板说:滚。 2)使用aop技术来实现这个功能,以后老板随便加都可以...
这是一个纯java写的魔兽对战平台.不抓包.原理非常简单. 可以聊天,可以发布自己的魔兽主机.有人建立主机或者人满了也会有声音提示. 主机是自动发布的,不需要客服端搜索。 也不需要连、接转。整个过程就是一个局域网...
在淘宝上随便找一个做毕设的都要好多钱的,而且客户本身的代码能力、数学、逻辑能力都很差,导致我每行都给注释以及看不懂,在我交付代码后又纠缠了我一个多礼拜。反正总体做下来的感觉就是烦躁。头一次感觉到了客户...
没有用哦,只是一小段代码,随便上传的,谢谢