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

企业安全——密码学基础

0x00 前言

密码学的内容一直都是零零散散的,学一遍忘一遍,对于这些很少用到的内容,只能这样子去进行重复,效率低从此没有效率会稍微好一点。
总会比说出base64是一种加密方式贻笑大方的好一点。

0x01 密码学的目的

密码学的主要目的是:

  • 保密性
  • 完整性
  • 身份认证
  • 不可否认性

保密性:

  • 对称密码体系: 使用一个共享秘钥
  • 非堆成:使用公私钥结合的方式

完整性

通常使用加密的消息摘要来实现,也就是数字签名。通过验证消息的数字签名的有效性,来确保消息在传输过程中未被改动。注意这里通过数字签名的方式仅仅是为了保证内容在传输过程中不被更改,而没有验证数据真实性的能力。

身份认证

用于验证系统用户自称的身份。

A:你好,我是张三
B:请证明你是张三,请加密“key”
A:密钥(key)
B:你好,张三

这里需要A使用,B知道的或者可以验证的内容对key进行加密。然后B通过相同的内容进行相同的计算,如果计算内容一致则身份验证通过。

不可否认性

不可否认性使用非堆成密钥密码系统提供,比如BTC等,发送的消息是不可以否认的。

0x02 密码数学

布尔运算

布尔数学(Boolean mathematics)为用于构成任何计算机神经系统的位和字节定义了规则。你可能非常熟悉十进制系统。这是一个逢十进位的系统,其中的每个位上都有一个整数(从0到9),每个位值都是10的倍数。我们对十进制系统的依赖极可能起源于生物学方面的原因—人类用十根手指头来数数。

逻辑运算

AND与:同真为真,有一假则为假
OR:有真则为真
NOT 非:真为假,假为真
XOR异或:不同为1,同为0
mod:模运算
单向函数:每种组合都只能输出一种数学运算,比如hash

分割知识:

当执行某项操作所要求的信息或权限被分散到多名用户手中时,任何一个人都不会具有足够的权限来破坏环境的安全。这种把职责分离和双人控制融于一个解决方案的做法叫分割知识(split knowledge)。

代价函数

代价函数
你可以用代价函数(work fnction)或代价因子从耗费成本和/或时间的角度测算破解一个密码系统时需要付出的努力,从而衡量密码系统的强度。对一个加密系统实施一次完整暴力破解攻击时需要付出的时间和精力,通常是代价函数所代表的内容。

相关文章:

  • 鸿蒙应用程序包HAP的开发与使用
  • 欧拉降幂-乘积幂次
  • RocketMQ 性能优化与调优策略(二)
  • 【redis】Jedis 操作 Redis 基础指令(上)
  • 2022 年 3 月青少年软编等考 C 语言七级真题解析
  • 【Azure 架构师学习笔记】- Azure Databricks (22) --Autoloader
  • LeetCode 热题 100_前 K 个高频元素(75_347_中等_C++)(堆)(哈希表+排序;哈希表+优先队列(小根堆))
  • 基于ssm的自习室预订座位管理(全套)
  • 蓝桥杯 阶乘的和
  • 登录Xshell主机及Linux基本指令
  • SpringBoot之一个注解完成所有类型的文件下载!
  • MySQL UPDATE 更新操作详解
  • 深入解析GORM的配置选项及示例
  • clickhouse清除system 表数据释放磁盘空间
  • 内容中台智能推荐服务创新路径
  • 网上怎么样可以挣钱,分享几种可以让你在家赚钱的兼职项目
  • 开发过程中的网络协议
  • SpringMVC(八)Knife4j 接口文档
  • XML 树结构
  • 爬虫逆向:逆向中用到汇编语言详细总结
  • 耶路撒冷发生山火,以防长宣布紧急状态
  • 奈雪的茶叫停“能喝奶茶就不要喝水”宣传,当地市监称不要误导消费者
  • 白玉兰奖征片综述丨国产剧集创作的此消彼长
  • 中国人民解放军南部战区位南海海域进行例行巡航
  • 铁路五一假期运输今日启动,预计发送旅客1.44亿人次
  • 建发股份:将于5月6日召开股东大会,审议提名林茂等为公司新一届董事等议案