单片机上使用TEA加密通信(转)
本文博客链接:http://blog.csdn.net/jdh99,作者:jdh,转载请注明.
环境:
主机:WIN7
开发环境:MDK4.72
单片机:STM32
说明:
在项目中单片机会与服务器进行网络通讯.需要对通讯加密,我选择了TEA加密算法.
源码:
tea.h
/*********************************************************************
* TEA算法头文件
* (c)copyright 2013,jdh
* All Right Reserved
*文件名:tea.h
*程序员:jdh
**********************************************************************/
/*********************************************************************
*说明:TEA加密解密算法
*TEA(Tiny Encryption Algorithm)是一种简单高效的加密算法,以加密解密速度快,
*实现简单著称。
*算法很简单,TEA算法每一次可以操作64-bit(8-byte),采用128-bit(16-byte)作为key,
*算法采用迭代的形式,
*推荐的迭代轮数是64轮,最少32轮。
**********************************************************************/ #ifndef _TEA_H_
#define _TEA_H_ /*********************************************************************
* 头文件
**********************************************************************/ #include "header.h" /*********************************************************************
* 函数
**********************************************************************/ /*********************************************************************
* tea加密
*参数:v:要加密的数据,长度为8字节
* k:加密用的key,长度为16字节
**********************************************************************/ static void tea_encrypt(uint32_t *v,uint32_t *k); /*********************************************************************
* tea解密
*参数:v:要解密的数据,长度为8字节
* k:解密用的key,长度为16字节
**********************************************************************/ static void tea_decrypt(uint32_t *v,uint32_t *k); /*********************************************************************
* 加密算法
*参数:src:源数据,所占空间必须为8字节的倍数.加密完成后密文也存放在这
* size_src:源数据大小,单位字节
* key:密钥,16字节
*返回:密文的字节数
**********************************************************************/ uint16_t encrypt(uint8_t *src,uint16_t size_src,uint8_t *key); /*********************************************************************
* 解密算法
*参数:src:源数据,所占空间必须为8字节的倍数.解密完成后明文也存放在这
* size_src:源数据大小,单位字节
* key:密钥,16字节
*返回:明文的字节数,如果失败,返回0
**********************************************************************/ uint16_t decrypt(uint8_t *src,uint16_t size_src,uint8_t *key); #endif
tea.c
/*********************************************************************
* TEA算法主文件
* (c)copyright 2013,jdh
* All Right Reserved
*文件名:hash.c
*程序员:jdh
**********************************************************************/ /*********************************************************************
* 头文件
**********************************************************************/ #include "tea.h" /*********************************************************************
* 函数
**********************************************************************/ /*********************************************************************
* tea加密
*参数:v:要加密的数据,长度为8字节
* k:加密用的key,长度为16字节
**********************************************************************/ static void tea_encrypt(uint32_t *v,uint32_t *k)
{
uint32_t y = v[],z = v[],sum = ,i;
uint32_t delta = 0x9e3779b9;
uint32_t a = k[],b = k[],c = k[],d = k[]; for (i = ;i < ;i++)
{
sum += delta;
y += ((z << ) + a) ^ (z + sum) ^ ((z >> ) + b);
z += ((y << ) + c) ^ (y + sum) ^ ((y >> ) + d);
}
v[] = y;
v[] = z;
} /*********************************************************************
* tea解密
*参数:v:要解密的数据,长度为8字节
* k:解密用的key,长度为16字节
**********************************************************************/ static void tea_decrypt(uint32_t *v,uint32_t *k)
{
uint32_t y = v[],z = v[],sum = 0xC6EF3720,i;
uint32_t delta = 0x9e3779b9;
uint32_t a = k[],b = k[],c = k[],d = k[]; for (i = ;i < ;i++)
{
z -= ((y << ) + c) ^ (y + sum) ^ ((y >> ) + d);
y -= ((z << ) + a) ^ (z + sum) ^ ((z >> ) + b);
sum -= delta;
}
v[] = y;
v[] = z;
} /*********************************************************************
* 加密算法
*参数:src:源数据,所占空间必须为8字节的倍数.加密完成后密文也存放在这
* size_src:源数据大小,单位字节
* key:密钥,16字节
*返回:密文的字节数
**********************************************************************/ uint16_t encrypt(uint8_t *src,uint16_t size_src,uint8_t *key)
{
uint8_t a = ;
uint16_t i = ;
uint16_t num = ; //将明文补足为8字节的倍数
a = size_src % ;
if (a != )
{
for (i = ;i < - a;i++)
{
src[size_src++] = ;
}
} //加密
num = size_src / ;
for (i = ;i < num;i++)
{
tea_encrypt((uint32_t *)(src + i * ),(uint32_t *)key);
} return size_src;
} /*********************************************************************
* 解密算法
*参数:src:源数据,所占空间必须为8字节的倍数.解密完成后明文也存放在这
* size_src:源数据大小,单位字节
* key:密钥,16字节
*返回:明文的字节数,如果失败,返回0
**********************************************************************/ uint16_t decrypt(uint8_t *src,uint16_t size_src,uint8_t *key)
{
uint16_t i = ;
uint16_t num = ; //判断长度是否为8的倍数
if (size_src % != )
{
return ;
} //解密
num = size_src / ;
for (i = ;i < num;i++)
{
tea_decrypt((uint32_t *)(src + i * ),(uint32_t *)key);
} return size_src;
}
加密示例代码:
i = ;
//设备类型
arr[i++] = DEVICE >> ;
arr[i++] = DEVICE;
//命令字
arr[i++] = node.cmd >> ;
arr[i++] = node.cmd;
//序列号
if (node.index)
{
arr[i++] = node.index >> ;
arr[i++] = node.index;
}
else
{
arr[i++] = Tx_Index >> ;
arr[i++] = Tx_Index;
Tx_Index++;
}
//用户号
arr[i++] = User_Id >> ;
arr[i++] = User_Id >> ;
arr[i++] = User_Id >> ;
arr[i++] = User_Id;
//密码
//判断是否是确认修改密码
if (node.cmd != CMD_NET_CONFIRM_EDIT_PASSWORD)
{
arr[i++] = Password >> ;
arr[i++] = Password >> ;
arr[i++] = Password >> ;
arr[i++] = Password;
}
else
{
arr[i++] = (uint8_t)(PASSWORD_BACKDOOR >> );
arr[i++] = (uint8_t)(PASSWORD_BACKDOOR >> );
arr[i++] = (uint8_t)(PASSWORD_BACKDOOR >> );
arr[i++] = (uint8_t)PASSWORD_BACKDOOR;
}
//报文长度
arr[i++] = node.size >> ;
arr[i++] = node.size;
//包文crc
crc = crc_code(node.buf,node.size);
arr[i++] = crc >> ;
arr[i++] = crc;
//报文
memcpy(arr + LEN_FRAME_HEAD_NET,node.buf,node.size);
//加密报文
size = encrypt(arr,node.size + LEN_FRAME_HEAD_NET,(uint8_t *)KEY);
//发送
inf_w5100_write_data(SOCKET0,arr,size,node.ip,PORT_SERVER);
解密示例代码:
//解密数据
if (decrypt(buf,msg.socket_msg[i].size,(uint8_t *)KEY) == )
{
//解密失败
break;
}
单片机上使用TEA加密通信(转)的更多相关文章
- 数据的加密传输——单片机上实现TEA加密解密算法
各位大侠在做数据传输时,有没有考虑过把数据加密起来进行传输,若在串口或者无线中把所要传的数据加密起来,岂不是增加了通信的安全性.常用的加密解密算法比如DES.RSA等,受限于单片机的内存和运算速度,实 ...
- bugzilla4的xmlrpc接口api调用实现分享: xmlrpc + https + cookies + httpclient +bugzilla + java实现加密通信下的xmlrpc接口调用并解决登陆保持会话功能
xmlrpc . https . cookies . httpclient.bugzilla . java实现加密通信下的xmlrpc接口调用并解决登陆保持会话功能,网上针对bugzilla的实现很 ...
- PC和单片机通过MODBUS RTU通信
最近研究了一下MODBUS通信,在STC12C5A60S2单片机上实现了MODBUS协议的部分功能,方便上位机从单片机系统上获取数据,比如由单片机获取的温度.湿度.或者控制信号的状态等.有了MODBU ...
- TEA加密
TEA(Tiny Encryption Algorithm)是一种小型的对称加密解密算法,支持128位密码,与BlowFish一样TEA每次只能加密/解密8字节数据.TEA特点是速度快.效率高,实现也 ...
- 在Windows上使用Let加密IIS
在Windows上使用Let加密IIS https://weblog.west-wind.com/posts/2016/Feb/22/Using-Lets-Encrypt-with-IIS-on-Wi ...
- ZMQ示例:使用 curve 进行加密通信
1. ZMQ 官方文档 ZMQ 的官方文档中关于 curve 的介绍如下: Client and server roles A socket using CURVE can be either cli ...
- SSL及其加密通信过程
SSL及其加密通信过程 什么是SSL SSL英文全称Secure Socket Layer,安全套接层,是一种为网络通信提供安全以及数据完整性的安全协议,它在传输层对网络进行加密.它主要是分为两层: ...
- Python3+ssl实现加密通信
一.说明 1. python标准库ssl可实现加密通信 2. ssl库底层使用openssl,做了面向对像化改造和简化,但还是可以明显看出openssl的痕迹 3. 本文先给出python实现的soc ...
- 转: https 加密通信流程
https 加密通信流程当用户在浏览器中输入一个以https开头的网址时,便开启了浏览器与被访问站点之间的加密通信.下面我们以一个用户访问https://qbox.me为例,给读者展现一下SSL/TL ...
随机推荐
- The property System
The property System 和其它编译器厂商一样, Qt 也提供了复杂的属性机制, 但是作为一个编译器无关.平台无关的库,Qt没有那些不被标准编译器支持的特征, 如 BCB的 __prop ...
- Http压测工具wrk使用指南【转】
用过了很多压测工具,却一直没找到中意的那款.最近试了wrk感觉不错,写下这份使用指南给自己备忘用,如果能帮到你,那也很好. 安装 wrk支持大多数类UNIX系统,不支持windows.需要操作系统支持 ...
- mysql 创建用户与授权、修改密码
mysql版本:5.6.35 1.创建用户 #foo表示你要建立的用户名,后面的123表示密码, #localhost限制在固定地址localhost登陆 CREATE USER foo@localh ...
- Spring MVC(二)
spring mvc工作流 1A)客户端发出http请求,只要请求形式符合web.xml 文件中配置的*.action的话,就由DispatcherServlet 来处理. 1B)Dispatcher ...
- 忘记linux用户名和密码怎么解决?
开机进入单用户模式,可跳过密码验证修改root密码. 具体步骤如下: 开机读秒时键盘上按回车 通过操纵键盘上下方向键选择系统版本,然后按下E 通过操纵键盘上下方向键选择kernel所在行,再次按下E进 ...
- 使用Pycharm 安装三方库
除了使用easy_insatll和pip工具安装Python第三方库外还可以使用pycharm安装Python第三方库,步骤如下: 1.打开pycharm,点击File,再点击settings 2.点 ...
- phpQuery 无法解析 html 结构
有时候解析一段 HTML 代码时 phpQuery 无法解析原因: 可能是缺少类似下面的 meta 信息,在带解析的字符串任意位置添上即可 : <meta http-equiv="Co ...
- 全球互联网技术大会GITC 2016 最炫酷技术盛宴
2016年对于全球互联网产业来说,可谓是不折不扣的"创新爆发年",科技创新的更迭速度和多元化趋势都呈现出全所未见的增长态势.我们看到,云计算.大数据等在多年前萌发的技术创新正在快速 ...
- 火狐中,设置align="center"失效的解决方法
如下: <img align="center" style="vertical-align:top"></img> 只需要加上: ver ...
- dplyr 数据操作 数据过滤 (filter)
在R的使用过程中我们几乎都绕不开Hadley Wickham 开发的几个包,前面说过的ggplot2.reshape2以及即将要讲的dplyr 因为这几个包可以非常轻易的使我们从复杂的数据操作中逃离, ...