区块链基础之密码学及安全技术

1.2 密码学及安全技术

区块链中的密码学与安全技术

1.2.1 密码学知识

1.2.1.1 Hash函数
  • Hash(哈希)
    哈希函数是一类数学函数,可以在有限合理的时间内,将任意长度的消息压缩为
    固定长度的输出值,并且是不可逆的。其输出值称为哈希值,也称为散列值。
    hash算法

  • 哈希算法的应用:
    消息认证:确保收到的消息和发送的消息都是未被篡改的。
    数字签名:对消息摘要进行数字签名与对消息本身进行数字签名等效。
    口令的安全性:仅将口令的哈希值进行保存,进行口令检验时仅需对比哈希值即可,即使攻击者获取了口令的哈希值,也无法计算出口令。
    数据完整性:具有抗数据篡改的能力。

  • Hash函数在区块链中的应用
    hash函数在区块链中应用
    在区块链系统中,哈希算法得到了广泛的使用。
    在区块链系统中,区块之间的链接就是通过区块的哈希值串联起来的。除此以外,还有梅克尔树的生成计算,交易事务的哈希值计算等。
    区块链是一个使用哈希指针构建的链表

  • Merkle tree
    Merkle(默克尔)树,又叫哈希树,是一种典型的二叉树结构,由一个根节点、一组中间节点和一组叶节点组成
    应用场景:
    快速比较大量数据
    快速定位修改
    Merkle tree

1.2.1.2椭圆曲线加密算法

即:Elliptic Curve Cryptography,简称ECC,是基于椭圆曲线数学理论实现的一种非对称加密算法。 相比RSA,ECC优势是可以使用更短的密钥,来实现与RSA相当或更高的安全。据研究,160位ECC加密安全性相当于1024位RSA加密,210位ECC加密安全性相当于2048位RSA加密。

1.2.2 安全技术

1.2.2.1 数字签名

用于防止消息篡改和抵赖的场景
数字签名基于非对称加密,既可以用于证实内容的完整性,又同时可以确 认来源(或不可抵赖,Non-Repudiation)。
数字签名的全过程分两大部分,即签名与验证。一侧为签名,一侧为验证 过程。

1.2.2.2 数字证书

数字证书

1.2.2.3 PKI体系

PKI体系

1.2.2.4 同态加密

本质上,同态加密是指这样一种加密函数,对明文进行环上的加法和乘法运算再加密,与加密后对密文进行相应的运算,结果是等价的。由于这个良好的性质,人们可以委托第三方对数据进行处理而不泄露信息。具有同态性质的加密函数是指两个明文a、b满足Dec(En(a)⊙En(b))=a⊕b的加密函数,其中En是加密运算,Dec是解密运算,⊙、⊕分别对应明文和密文域上的运算。当⊕代表加法时,称该加密为加同态加密:当⊕代表乘法时,称该加密为乘同态加密。

全同态加密是指同时满足加同态和乘同态性质,可以进行任意多次加和乘运算的加密函数。用数学公式来表达,即Dec(f(En(m1),En(m2),…,En(mk)))=f(m1,m2,…,mk),或写成:f(En(m1),En(m2),…,En(mk))=En(f(m1,m2,…,mk)),如果f是任意函数,称为全同态加密。

1.2.2.5 布隆过滤器
class BloomHash {/*** Hash工具类返回的hashcode的最大长度<br>* maxLength为2的n次方,返回的hashcode为[0,2^n-1]*/public int maxLength;// Hash函数生成哈希码的关键字public int seed;public BloomHash(int maxLength, int seed) {this.maxLength = maxLength;this.seed = seed;}/*** 返回字符串string的hashcode,大小为[0,maxLength-1]* * @param string* @return*/public int hashCode(String string) {int result = 0;// 这个构建hashcode的方式类似于java的string的hashcode方法// 只是我这里是可以设置的seed,它那里是31for (int i = 0; i < string.length(); i++) {char a = string.charAt(i);int b = seed * a; // 隐式的把字符转换为整数(ASSIC码)result = result + b;}/*** public static int indexFor(int m, int n){ return m & (n - 1); } public static* void main(String[] args) { System.out.println("19 与 16 求余 = "+ indexFor(19,* 16) ); System.out.println("19 与 16 求余 = "+ 19 % 16 ); }* 此方法中n为2的指数值,则其二进制形式的表示中只存在一个1,其余位都为0, 例如: 0000 1000、0100 0000、0010* 0000等等。则n-1的二进制形式就为1的位数变为0, 其右边位全变为1,例如16的二进制  0001 0000 -1 = 0000* 1111测试m为19的二进制 0001 0011 & 0000 1111 = 0000 0011 = 3,地位保留的结果便是余数。此位运算也是* HashMap中确定元素键(key)值所在哈希数组下标位置的核心方法,此位运算(hash & (length - 1)) 的效率极高于hash %* length的求余, 所以也解释为什么HashMap的扩容始终为2的倍数(2的指数值)。*/// 保证结果在[0,maxLength-1]:equal to 'result % maxLength'return result & (maxLength - 1);}
}public class BloomFilter {// 构建hash函数的关键字,总共7个private static final int[] HashSeeds = new int[] { 3, 5, 7, 11, 13, 17, 19 };// Hash工具类的数组private static BloomHash[] HashList = new BloomHash[HashSeeds.length];// BloomFilter的长度,最好为插入数量的10倍,目前为2的20次方,大约100万个private static final int BloomLength = 1 << 20;// 对位的操作类,java自带的BitSet,共BloomLength个bitprivate BitSet bitSet = new BitSet(BloomLength);public BloomFilter() {// 初始化Hash工具类的数组,每个hash工具类的hash函数都不同for (int i = 0; i < HashSeeds.length; i++) {HashList[i] = new BloomHash(BloomLength, HashSeeds[i]);}}/*** 在布隆过滤器中加入值value,在多个hash函数生成的hashcode对应的位置上,置1* * @param value字符串,如果为数字,可以自己转化成string*/public void addValue(String value) {for (int i = 0; i < HashSeeds.length; i++) {// 根据对应的hash函数得到hashcodeint hashcode = HashList[i].hashCode(value);// 在位图中,将对应的位,设置为1bitSet.set(hashcode);}}/*** 在布隆过滤器中,检验是否可能有值value* * @param value* @return 如果返回false,则一定没有<br>*         如果返回true,就代表有可能有*/public boolean existsValue(String value) {boolean result = true;for (int i = 0; i < HashSeeds.length; i++) {// 根据对应的hash函数得到hashcodeint hashcode = HashList[i].hashCode(value);/*** 隐式把boolean转换为整数进行按位与运算 “短路” 主要用于逻辑运算符中,即 “ ! && || "这三种运算符 短路 就是知如果左侧的* 表达式能确定运算后的结果,则不再计算右侧的表达式。 如(1>2)&&(2<3) 明明左侧已经为假 了 我 不用计算右侧我一定知道 此表达是为假*/// 将result与对应位置上的0或1 做与运算// 如果全为1,则result最后为1// 如果有一个位置上为0,则最后result为0result = result & bitSet.get(hashcode);}return result;}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/3906.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Vue.js中的状态管理:理解和使用Vuex

目录 前言 Vue.js 样式绑定 Vue.js class class 属性绑定 实例 1 实例 2 实例 3 实例 4 数组语法 实例 5 实例 6 Vue.js style(内联样式) 实例 7 实例 8 实例 9 Vue.js 组件 全局组件 全局组件实例 局部组件 局部组件实例 Prop Prop 实例 动态 Prop Pro…

Linux基础服务4——ftp

文章目录 一、基本了解1.1 C/S型架构1.2 数据连接模式1.3 用户认证 二、安装服务端2.1 安装vsftpd2.2 配置文件2.3 主配置文件参数2.4 windows访问服务端2.4.1 系统用户访问2.4.2 匿名用户访问2.4.2 开启客户端上传权限2.4.3 开启客户端其他权限2.4.4 开启客户端删除、修改权限…

大数据赋能交通业务管理——远眺智慧交通集成管控系统

随着交通管理需求的不断提升&#xff0c;原有系统管理模式的缺点逐渐显露&#xff0c;各业务系统的相互独立、各自为战&#xff0c;成为交通管理人员全局把控交通资源、实现交通综合管控的壁垒。 智慧交通集成管控平台通过统一标准&#xff0c;集成交警各类业务系统、整合相关数…

解决JD-GUI-1.6.6 中文乱码

解决JD-GUI-1.6.6 中文乱码 原因解决办法的方式一解决办法的方式二最终版 原因 在拖入java文件进行反编译时候发现中文出现了乱码。 g) 解决办法的方式一 值得注意的是&#xff1a;这种方式只能每次输入命令才弹出jd-gui窗口才能不能乱码 每次打开powershell并输入这一串命…

LeetCode 0002. 两数相加

【LetMeFly】2.两数相加 力扣题目链接&#xff1a;https://leetcode.cn/problems/add-two-numbers/ 给你两个 非空 的链表&#xff0c;表示两个非负的整数。它们每位数字都是按照 逆序 的方式存储的&#xff0c;并且每个节点只能存储 一位 数字。 请你将两个数相加&#xff…

SpringBoot3之GraalVM之Windows详细安装及使用教程

配置Maven环境变量 我直接使用的是IDEA plugins文件夹下的maven 新建MAVEN_HOME环境变量 Path环境变量追加 %MAVEN_HOME%\bin安装Visual Studio Community 因为GraalVM需要调用操作系统的底层工具&#xff0c;而Windows底层工具是VisualStudio&#xff0c;所以我们要先下载…

LabVIEW开发光线追踪可视化分段反射器测试台

LabVIEW开发光线追踪可视化分段反射器测试台 为了满足美国国家航空航天局&#xff08;NASA&#xff09;对未来望远镜的要求&#xff0c;新的红外空间天文台将在哈勃太空望远镜使用寿命结束后取代其。作为HST的继任者&#xff0c;詹姆斯韦伯太空望远镜&#xff08;JWST&#xf…

机器学习-方差和偏差理论

机器学习-方差和偏差理论 关于机器学习方差和偏差的内容其实很重要&#xff0c;这个方差和偏差可以帮助我们去分析&#xff0c;模型的泛化能力和过拟合的程度。 下面我们先给存储方差和偏差的公式&#xff1a; 注意&#xff0c;下式当中&#xff0c; f ( x ; D ) 表示在数据集…

Gitlab升级报错二:rails_migration[gitlab-rails] (gitlab::database_migrations line 51)

gitlab-ctl 修改文件目录后出现以下错误&#xff1a;从root --> home 先停掉gitlab: gitlab-ctl stop 单独启动数据库&#xff0c;如果不单独启动数据库&#xff0c;就会报以上错误 sudo gitlab-ctl start postgresql 解决办法&#xff1a; sudo gitlab-rake db:migrat…

登录校验-interceptor/拦截器

Interceptor 概念&#xff1a;拦截前端对后端的某些请求 使用步骤 自定义拦截器类&#xff0c;实现HandlerInterceptor接口&#xff0c;重写所有的方法&#xff08;preHandle方法在controller执行之前执行、【postHandle、afterCompletion】在controller执行后执行&#xff0…

《项目实战》构建SpringCloud alibaba项目(一、构建父工程、公共库、网关))

系列文章目录 构建SpringCloud alibaba项目&#xff08;一、构建父工程、公共库、网关&#xff09; 构建SpringCloud alibaba项目&#xff08;二、构建微服务鉴权子工程store-authority-service&#xff09; 文章目录 系列文章目录1、概要2、整体架构流程2.1、技术结构组成部分…

计算机网络-网络体系结构

目录 计算机网络的基本概念计算机网络的定义组成与功能计算机网络的分类按照网络的作用范围进行分类按照网络的使用者进行分类 计算机网络主要性能指标 计算机网络体系结构计算机网络协议、接口、服务等概念ISO/OSI 参考模型和 TCP/IP 模型OSI七层模型TCP/IP 模型封装与分用 计…