数据采集器服务——Socket(今天才发现AES加解密代码跟贴的时候不一样,貌似乱码,不知什么情况)

原创 2015年07月08日 15:24:15

最近刚做的一个项目,关于 Socket TCP 通信。

需求方提供了一个 ARM 机器,及数据采集器,需要我做一个服务端与数据采集器进行交互。


目的:

数据采集器:定时将读取到的数据发送到服务端。

服务端:将数据采集器发送过来的数据保存在本地。


要求:

1、通信以 TCP 方式进行交互,端口可配置。

2、自己实现握手、心跳包机制。

3、TCP 包结构包括:包头、有效数据总长度、有效数据、CRC 校验、包尾,其中有效数据包括指令序号和指令内容,为经过 AES 128位加密的 XML 数据。

4、加密算法:AES 128位,加密模式:CBC,填充模式:NoPadding。

5、握手过程:(以下过程均以 TCP 包结构加密形式传输,并只提主要内容数据,省略 CRC 校验说明)

(1)数据采集器发送请求包到服务端,服务端解析包结构后取出数据段进行 AES 解密。

(2)服务端判断该包为请求包后回复一个包含一个随机序列的包到数据采集器。

(3)数据采集器接收到包后将随机序列与 MD5 密钥组合后进行 MD5 加密,并回发给服务端。

(4)服务端接收到加密后的内容,并与本地加密后的内容进行比较,通过则回复 pass,否则回复 fail。

(5)数据采集器收到 pass 则握手成功并建立连接,否则握手失败并断开连接。

6、心跳包:握手建立后,采集器每隔一定时间会往服务端发送一个心跳包,服务端收到心跳包后应立即应答,回复服务器当前时间信息供采集器校时。

7、数据包:采集器在握手建立后,会定时向服务端发送断点数据包和实时数据包,服务端接收到以后将数据保存在本地 PC 并回复 pass。


1、创建服务端Socket

(C#)

IPEndPoint ipep = new IPEndPoint(IPAddress.Any, 36829); //本机预使用的IP和端口

Socket newsock = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp);

newsock.Bind(ipep); //绑定

newsock.Listen(10); //监听

(Node.js)

var server = net.createServer(function(socket) { //'connection' listener
	console.log('client connected');
});
server.listen(36829, function() { //'listening' listener
	console.log('server bound');
});

2、创建客户端对象并监听

(C#)

Console.WriteLine("waiting for a client");
Socket client = newsock.Accept(); //当有可用的客户端连接尝试时执行,并返回一个新的socket,用于与客户端之间的通信
IPEndPoint clientip = (IPEndPoint)client.RemoteEndPoint;
Console.WriteLine("connect with client: " + clientip.Address + " at port: " + clientip.Port);
while (true)
{
    byte[] buffer = new byte[1024]; //用于缓存客户端所发送的信息,通过socket传递的信息必须为字节数组
    int packageLength = client.Receive(buffer); //用于表示客户端发送的信息长度
    if (packageLength == 0)
    {
        Console.WriteLine("解除循环监听,Disconnected from " + clientip.Address);
        break; //当信息长度为0,说明客户端连接断开
    }
}

(Node.js)

var server = net.createServer(function(socket) { //'connection' listener
	console.log('client connected');

	socket.on('end', function() {
		console.log('client disconnected');
	});
	socket.on('data', function(data){
		console.log(data.length);
		console.log(data);
	});
});
server.listen(36829, function() { //'listening' listener
	console.log('server bound');
});

因为其他内容涉及到保密性,所以下面只贴一下 AES 加解密过程

// AES 解密
public static string AESDecrypt(byte[] data)
{
    SymmetricAlgorithm aes = Rijndael.Create();
    aes.Key = keyArray; // 密钥
    aes.IV = keyArray; // 向量
    aes.Mode = CipherMode.CBC;
    aes.Padding = PaddingMode.None;
    byte[] decryptBytes = new byte[data.Length];
    using (MemoryStream ms = new MemoryStream(data))
    {
        using (CryptoStream cs = new CryptoStream(ms, aes.CreateDecryptor(), CryptoStreamMode.Read))
        {
            cs.Read(decryptBytes, 0, decryptBytes.Length);
            cs.Close();
            ms.Close();
        }
    }
    aes.Clear();

    return System.Text.Encoding.Default.GetString(decryptBytes).Replace("\0", " ");
}

// AES 加密
public static byte[] AESEncrypt(byte[] data)
{
    SymmetricAlgorithm aes = Rijndael.Create();
    aes.Key = keyArray;
    aes.IV = keyArray;
    aes.Mode = CipherMode.CBC;
    aes.Padding = PaddingMode.None;

    using (MemoryStream ms = new MemoryStream())
    {
        using (CryptoStream cs = new CryptoStream(ms, aes.CreateEncryptor(), CryptoStreamMode.Write))
        {
            cs.Write(data, 0, data.Length);
            cs.FlushFinalBlock();
            byte[] cipherBytes = ms.ToArray(); // 得到加密后的字节数组
            cs.Close();
            ms.Close();
            aes.Clear();

            return cipherBytes;
        }
    }
}

























































                
版权声明:本文为博主原创文章,未经博主允许不得转载。

完整的AES分组与文件的加解密功能程序实现

[在此处输入文章标题]                       完整的AES分组与文件的加解密功能程序实现 签名: 1 前言     本报告论述在论述AES加...
  • zhoujn90
  • zhoujn90
  • 2015年01月16日 19:58
  • 2471

【加密解密】-AES加密解密实现

先看实现效果,测试代码如下:package org.iti.algorithm;public class AESDemo { public static void main(String[] a...
  • tailyou
  • tailyou
  • 2015年08月27日 14:24
  • 3167

【密码学】AES加解密原理及其C++实现算法

AES简介 高级加密标准(Advanced Encryption Standard,AES),在密码学中又称Rijndael加密法,是美国联邦政府采用的一种区块加密标准。这个标准用来替代原先的DE...
  • White_Idiot
  • White_Idiot
  • 2017年04月14日 00:21
  • 1032

今天才发现

原来jquery修改元素的css样式,是直接添加的行内样式. 如果你有用id或class 的样式与次冲突,会造成id或css中的样式失效.....
  • kofjjj
  • kofjjj
  • 2015年03月24日 19:11
  • 179

数据采集器-架构介绍

说点事说说数据采集的流程数据采集一般是一个从硬件设备收集到数据,然后对对数据进行解析处理,归类,入库,供查询使用。说说踩过的坑 坑1:java多线程并发数量以及tcp粘包问题 由于数据采集是通过tc...
  • qzshiyongjie123
  • qzshiyongjie123
  • 2017年01月11日 10:54
  • 1063

JAVA实现AES加密和解密

经过三周的不懈努力,终于完成了AES对文件的加密和解密。现在将自己的学习经历记下来,纪念自己三周的付出。同时也感谢网上的各位大神的博客。 AES对文件加密和解密以及打包的工具:http://downl...
  • xiaaiwu
  • xiaaiwu
  • 2015年01月15日 20:21
  • 3093

AES加密解密源码示例,以及解决:aes在tomcat解密中文乱码,在控制台解密中文不是乱码

这里使用AES128,进行加密,解密 加密示例: /** * * 加密 * * @param sSrc 原字符 * @param sKey 16位字符的key * ...
  • han_huayi
  • han_huayi
  • 2017年04月11日 15:34
  • 1327

AES加解密算法详解

0 AES简介   美国国家标准技术研究所在2001年发布了高级加密标准(AES)。AES是一个对称分组密码算法,旨在取代DES成为广泛使用的标准。   根据使用的密码长度,AES最常见的...
  • yxtxiaotian
  • yxtxiaotian
  • 2016年08月01日 11:20
  • 6418

BCDEdit 启动项编辑器4 zz

http://bbs.wuyou.net/viewthread.php?tid=158454&pid=1867618&page=1&extra=      9 写得很乱,大家凑合看了  补充...
  • mobilechan
  • mobilechan
  • 2013年05月04日 21:03
  • 480

利用openssl里的库函数进行AES的加解密—cbc

本人尝试编写的测试利用openssl库函数进行AES中cbc的加解密,至于其它ecb,cfb,ofb等的加解密可套路以下程序。 在贴代码之前本人需要分享三个网站,个人认为对理解AES加解密和text的...
  • Justine_King
  • Justine_King
  • 2017年04月13日 13:50
  • 421
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:数据采集器服务——Socket(今天才发现AES加解密代码跟贴的时候不一样,貌似乱码,不知什么情况)
举报原因:
原因补充:

(最多只允许输入30个字)