当前位置: 首页 > news >正文

openssl学习——消息认证码原理

消息认证码原理

消息认证码(Message Authentication Code, MAC)是一种技术,它的原理是通过对消息和密钥进行特定的处理,生成一个固定长度的数据,这个数据就是消息认证码(MAC)。这个过程可以看作是一个单向的散列函数,因为一旦消息和密钥确定,生成的MAC就是唯一的。

消息认证码的作用是确认消息的完整性和真实性。它不仅可以防止消息被篡改,还可以通过共享密钥来确认发送者的身份。只有知道共享密钥的人才能生成和验证 MAC,因此,如果有人伪装成发送者发送了消息,接收者可以通过检查 MAC 来发现这个消息是伪造的。
在这里插入图片描述

简单说明

A给B发送消息,可以通过哈希算法判断消息是否完全。但是没有办法判断消息是否是A发送的。如果A和B都有一个共享的秘钥,A在发送消息时,进行auth_code_A = md5(消息+秘钥),注意传输过程中是不传输共享秘钥的,中间人没有秘钥,无法生成auth_code_A,但是B在接收到消息后,进行auth_code_B = md5(消息+秘钥),判断auth_code_A是否等于auth_code_B,当auth_code_A==auth_code_B时,说明消息是A发送的。
在这里插入图片描述

http://www.lryc.cn/news/192962.html

相关文章:

  • Netty使用SslHandler实现加密通信-单向认证篇
  • Jetpack:007-Kotlin中的Button
  • opencv图形绘制2
  • “华为杯”研究生数学建模竞赛2019年-【华为杯】A题:无线智能传播模型(附优秀论文及Pyhton代码实现)(续)
  • 爬虫 | 正则、Xpath、BeautifulSoup示例学习
  • nginx的location的优先级和匹配方式
  • 深入了解Spring Boot Actuator
  • 【SQL】NodeJs 连接 MySql 、MySql 常见语句
  • SSH 基础学习使用
  • JavaFX: 使用本地openjfx包
  • 【HCIA】静态路由综合实验
  • Django框架集成Celery异步-【2】:django集成celery,拿来即用,可用操作django的orm等功能
  • 获取本地缓存数据修改后,本地缓存中的值也修改问题
  • 云开发校园宿舍/企业/部门/物业故障报修小程序源码
  • K邻近算法(KNN,K-nearest Neighbors Algorithm)
  • 前端基础一:用Formdata对象来上传图片的原因
  • CSS的布局 Day03
  • nodejs+vue+elementui养老院老年人服务系统er809
  • antd表格宽度超出屏幕,列宽自适应失效
  • 布局--QT Designer
  • 2024第八届杭州国际智慧城市博览会:建筑与智能,智慧与未来
  • Text-to-SQL小白入门(八)RLAIF论文:AI代替人类反馈的强化学习
  • C语言联合体和枚举
  • Ubuntu 上传项目到 GitHub
  • CSS 复杂卡片/导航栏特效运用目录
  • QT: 一种精确定时器类的实现与使用
  • SQLite4Unity3d安卓 在手机上创建sqlite失败解决
  • 跨站请求伪造:揭秘攻击与防御
  • matlab 图像均值滤波
  • P1433 吃奶酪