零知识证明-非对称加解密算法(三)

前言
非对称加解密算法 ,就有对称加解密算法
1:对称算法
定义
对称算法,加解密双方使用一个密钥。即加密秘钥和解密秘钥相同。
对称加密又分为:分组加密和流加密
分组加密
分组加密是每次只能处理特定长度的一块数据的一类密码算法,这里的“一块”就称为分组(block)。一个分组的比特数就称为分组长度(block lenght)。

常见的分组算法有:DES、3DES、DESX、Blowfish、IDEA、RC2、RC5、RC6和AES,以及中国的SSF33、SM1、SM4。
分组加密又可以根据其迭代模式分为ECB,CBC,OFB,CFB,CTR。

最简单的就是 异或(XOR) ⊕

明文 c=88
密码 p = 119 随便选的这个数字

加密
密文 e = 88 ⊕ 119 = 47
88(01011000) ⊕ 119(01110111) =47(00101111)

解密
明文 c = e ⊕ p = 47 ⊕ 119= 88
47(00101111) ⊕ 119(01110111) =88(01011000)

代码实现

package mainimport "fmt"func main()  {valuea ,valueb := 0,0for ;; {fmt.Printf("please input value1 and  value2:")if _,err := fmt.Scan(&valuea,&valueb);err !=nil{fmt.Printf("input error")break}fmt.Printf("%v(%08b) ⊕ %v(%08b) =%v(%08b) \n",valuea,valuea,valueb,valueb,valuea^valueb,valuea^valueb)}fmt.Printf("ready exit \n")
}

2:非对称算法
非对称算法也叫公钥算法,在公钥密码系统中,加密和解密使用的是不同的密钥,这两个密钥之间存在着相互依存关系:即用其中任一个密钥加密的信息只能用另一个密钥进行解密。
这使得通信双方无需事先交换密钥就可进行保密通信。其中加密密钥和算法是对外公开的,人人都可以通过这个密钥加密文件然后发给收信者,这个加密密钥又称为公钥;
而收信者收到加密文件后,它可以使用他的解密密钥解密,这个密钥是由他自己私人掌管的,并不需要分发,因此又成称为私钥,这就解决了密钥分发的问题。

主要的公钥算法有: RSA、 DSA、 DH 和 ECC。
以ras为例
1>RSA算法原理
RSA算法的基于这样的数学事实:两个大质数相乘得到的大数难以被因式分解。

2> 加解密 步骤
(1):选取两个大质数p,q,计算N = p q 及 φ ( N ) = φ § φ (q) = (p-1) * (q-1)
互质关系:如果两个正整数,除了1以外,没有其他公因子,我们就称这两个数是互质关系
φ(N):叫做欧拉函数,是指任意给定正整数N,在小于等于N的正整数之中,有多少个与N构成互质关系。
如果n是质数,则 φ(n)=n-1。
如果n可以分解成两个互质的整数之积, φ(n) = φ(p1p2) = φ(p1)φ(p2)。即积的欧拉函数等于各个因子的欧拉函数之积
(2):选择一个大于1 小于φ(N)的数e,使得 e 和 φ(N)互质
e其实是1和φ(N)之前的一个质数
(3):计算d,使得de=1 mod φ(N) 等价于方程式 ed-1 = k φ(N) 求一组解。
d 称为e的模反元素,e 和 φ(N)互质就肯定存在d
模反元素是指如果两个正整数a和n互质,那么一定可以找到整数b,使得ab被n除的余数是1,则b称为a的模反元素。
可根据欧拉定理证明模反元素存在,欧拉定理是指若n,a互质,则:
aφ(n) ≡ 1(mod n) 及 aφ(n) = a * aφ(n)-1, 可得a的 φ(n)-1 次方,就是a的模反元素。
(4):(n, e)封装成公钥,(n, d)封装成私钥。

eg: p=53 q =59 //这里选择2个小的素数,否则演算,计算量太大
n=53 * 59 = 3127
φ(n)=φ(3127)=(53-1)(59-1)=3016
选e=[1,3016) 中的 3 ,e=3
d * e = 1 mod φ(n) = d * 3 = 1 %3016
所以 d = 2011
公钥 (n,e)= (3127,3)
私钥 (n,d)=(3127,2011)

明文 m = 89
公钥用于加密、私钥用于解密
用公钥加密
密文 c = me mode n = 893 %3127 = 1394
用私钥解密
明文 m2 = cd mod n = 13942011 %3127=89

私钥用于签名、公钥用于验签名
摘要 = hash256(明文) = hash256(89) 这里省略

生成签名 用私钥
s= md mod n=89 2011 %3127 = ?
89 2011 = 16722583105308279104923867509715064099387784608129733532437680187247
01215476410680999915339774392775625618233497328039884105689289924625582672941711
14563895043871648877622204606536874504743584113292955847998021758180183927990417
49483897500785819175507565180862762681431353853013275102682395465719327412623371
28258050540279247025052968465776417477732907653405452503367096267673308971002206
96013929839366953469750761508775627460108983472889315804374409770037901189582126
58584765838551342604665358768706709286758455626768426827094918375880196280792838
33242284123972362692542970870210820376163435285317114274868254235528576051694461
71886867007589261526018877015824351473905037078170385773571206872142783198744172
37420356120173721472673067303174336047691352905498282982912556200369171268385120
35368134353869874578285960630415249362175228225147658323679663388146810809892417
34773762158899470010728479221462789538011196143235172295578671268192706789018415
01885133453915904484211096564142085081941233809369050230936738583285768617029750
86855854029263209898380849484341544160701565220283509506919749641513286320938181
74426329777153490925965948182708990967298527879750649938514756880817748425094982
18528844063701501465673309513211313717073444822078926546639912596559101776600291
95289512865177970012200681378332786352832156519536532812801091036293225470401223
32278480265698762935823434005119051663266223842380021326366079884015190554544757
33597277984129017297117077357965207375402877434119200886062896909104440409151485
22743462761578806274987697882655739546874286280567384147637584423420286898409862
06466335795738478208695453058762360993731422884437868861327934497662202657334729
70236985545597451542028429242343037658892139587600615265499948144118327954449465
35618795250490495375905698154597385010130752598856956900608700719832715964840532
24468034509793798980275070900414799021001652242043411131078254314388221096120089
29940764075886214680043890032577058149842407181571895522992650418441812514638050
74227220844356190425089580935029400020627915985927252389649246619559582482300123
54197818896427053734072948991126640475317464835569739191294816223693705963022771
74389261583712633606772420414866768733271883540367820750129689834409888436179409
79069494913901559652601008376112353715145897343526707491237847627803956357203979
32488398183539195531355629591575375980588991352299880617507113151223829123351267
38747035476138207179442159372387291324507010172254791123218745267066126158317009
61669009554099745263515225991384855384573902383889926414875574409006054378516445
72615735070655816819992318033133397352135540960674920556941926967176694849651610
63937756029486720177421753457661415872296229038633165753788154435164086513111898
11533612558006602515157339354685670227296222116077251263299481829968926775094390
49381095343453455669645799589043581137242807466717817336806439552748353887282238
51625631811789517654670280214107956893132243723685465932839910155750094832737778
50673337898123602954848673933575733902485338477466107390230119432960922704684283
48234399487763421817649560864944290073299489909151306331586949188024680434310502
86315823429151473246501833787084960016712392353065321715828858205683528640724515
98283038085467122414386158696038747851276510349977799877704030278732062050372941
69418641722401217855825517675095640553262856773390176905315186450213572617147504
89606160010003274195219724096285452561873678385841307500050432789610118206122774
83813649349446528839590415154647713580610495836553676580266311849974148636131510
27421735097426663505594232582524772119777264433643630855801556736992349566635395
55071065179017867436478530674868755873936214732855625699896586123250163536023602
46769939250810530377624055909322011694251321310059768288035223058621511296187291
08733718490134528313611337300091548944728868954706289021446131823641591812726819
40270036421978674519568461112149439540979564871459345931696461369788565080942032
2710802420489

please input value1,power and mod:89 2011 3127
(89 ^ 2011)mod 3127 = 545 怎么计算的 看后面的代码 eth 有专门函数

s= md mod n=89 2011 %3127 = 545 //签名文件

用 明文m=89 s=545 给对方,对方用公钥验证
明文 m1 = se mod n = 5453 %3127 = 161878625 % 3127 = 89
如 m1 == m mod n ,验证成功,签名OK

大数N次方 上代码

package mainimport ("fmt""github.com/ethereum/go-ethereum/common/math""math/big"
)func main()  {valuea ,power,mod := 0,0,0//89 ^2011 %3127for ;; {fmt.Printf("please input value1,power and mod:")if _,err := fmt.Scan(&valuea,&power,&mod);err !=nil{fmt.Printf("input error")break}a := int64(valuea)b := int64(power)big1 := math.BigPow(a,b)m := big.NewInt(int64(mod))big2 := m.Mod(big1,m)fmt.Printf("(%v ^ %v)mod %v = %v \n",valuea,power,mod,big2)}fmt.Printf("ready exit \n")
}

总结:
公钥 (n,e)= (3127,3)
私钥 (n,d)=(3127,2011)
明文 m
加密 密文s = me mod n 解密 明文 m1 = sd mod n
签名 签文s = md mod n 验证 明文 m1 = se mod n
是不是很简单

3:如果觉得有用,麻烦点个赞,加个收藏

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

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

相关文章

回归预测|基于卷积神经网络-鲸鱼优化-最小二乘支持向量机的数据回归预测Matlab程序 CNN-WOA-LSSVM

回归预测|基于卷积神经网络-鲸鱼优化-最小二乘支持向量机的数据回归预测Matlab程序 CNN-WOA-LSSVM 文章目录 一、基本原理1. 数据预处理2. 特征提取(CNN)3. 参数优化(WOA)4. 模型训练(LSSVM)5. 模型评估和优…

搭建webRTC cotrun流媒体服务器

1.二进制安装方式 https://blog.csdn.net/yushangyong/article/details/129973873 2.docker搭建方式 https://hub.docker.com/r/coturn/coturn 版本4.6.2-r11

(最新)华为 2024 届秋招-硬件技术工程师-单板硬件开发—机试题—(共12套)(每套四十题)

(最新)华为 2024 届秋招-硬件技术工程师-单板硬件开发—机试题—(共12套)(每套四十题) 岗位——硬件技术工程师 岗位意向——单板硬件开发 真题题目分享,完整版带答案(有答案和解析&#xff0…

工业软件架构1:(QT和C++实现)

工业软件架构 - 事件驱动 - 1 0.事件总线(EventBus)1. 传感器模块(Sensor Module)2. 硬件控制模块(Hardware Control Module)3. 按键处理模块(Button Handler Module)4. 界面管理模块…

单位的一位干部去世了,该单位领导参加他的追悼会致辞是这样写的?

单位的一位干部去世了,该单位领导参加他的追悼会致辞是这样写的? 这是一篇单位工会领导参加本单位一位普通干部追悼会的致词 (范文点评) 胡某晔同志追悼会悼词 各位来宾、各位亲友: 今天,我们怀着十分沉痛…

基于深度学习的单目标跟踪系统

基于深度学习的单目标跟踪,效果吊打传统算法,3060显卡上达到实时,代码python和c两个版本都有。 基于深度学习的单目标跟踪系统是一种先进的计算机视觉技术,它可以实现实时的、高精度的目标跟踪。与传统的基于特征匹配或模板匹配的…

【宝马中国-注册/登录安全分析报告】

前言 由于网站注册入口容易被黑客攻击,存在如下安全问题: 暴力破解密码,造成用户信息泄露短信盗刷的安全问题,影响业务及导致用户投诉带来经济损失,尤其是后付费客户,风险巨大,造成亏损无底洞…

一些零碎的关于合约测试,ERC20调用的知识

文章目录 前言一、vm.startPrank(user)是什么?二、approve 方法场景设定步骤 1: 用户授权步骤 2: 合约使用授权步骤 3: 检查授权状态示例代码 ERC20 approve的源代码代码解释代码解释应用场景示例注意事项代码解释可能的重载版本 _approve事件…

关于武汉芯景科技有限公司的实时时钟芯片XJ8337开发指南(兼容DS1337)

一、芯片引脚介绍 1.芯片引脚 2.引脚描述 二、系统结构图 三、功能描述 1.时钟功能 2.闹钟功能(两个闹钟) 3.振荡器停止控制 4.频率输出(1HZ、1.096KHZ、8.192KHZ、32.768KHZ) 5.振荡器停止检测 6.闹钟中断标志 四、程序代…

MySQL 查询优化详解

在使用 MySQL 数据库时,查询性能往往是影响应用程序整体性能的关键因素。通过对查询进行优化,可以显著提升数据库的响应速度和处理能力。本文将深入探讨 MySQL 查询优化的几个重要方面,包括查询分析与执行计划(EXPLAIN&#xff09…

#C++ 笔记三

七、异常处理 1.概念 异常是程序在执行期间产生的问题。 C异常是指在程序运行时发生的特殊情况,比如下标越界等。 异常提供了一种转移程序控制权的方式。 2.抛出异常 throw语句的操作数可以是任意表达式,表达式结果的类型决定了抛出异常的类型。 …

k8s-pod 实战六 (如何在不同的部署环境中调整startupprobe的参数?)

在不同的部署环境中(如开发、测试、生产环境),你可能希望对 startupProbe 的参数进行调整,以适应不同的需求和条件。以下是几种常见的方法和实践: 方法一:使用 Kustomize 1. 目录结构 假设你的项目目录结构如下: my-app/ ├── base/ │ └── deployment.yaml …

进程和线程(操作系统八股文part2)

一个操作系统的进程和线程部分的笔记,大部分来源于:小林coding和Javaguide,以及操作系统黑书。 进程和线程 什么是进程 运行中的程序叫进程**(Process)**。 进程是资源分配的最小单位,线程是执行的最小…

redis分布式是如何实现的(面试版)

需要结合项目中的业务进行回答,通常情况下,分布式锁使用的场景:集群情况下的定时任务、抢单、幂等性场景。 下面先来看一个抢卷场景: 以下情况会出现超卖情况: 因为线程会交替执行,所以线程查询优惠价的数…

Socket编程---UDP篇

目录 一. UDP协议 二. Socket编程 2.1 sockaddr家族 2.2 接口介绍 三. 服务端实现 四. 服务端调用实现 五. 客户端实现 六. 效果展示 一. UDP协议 何为UDP协议的含义,上篇粗略提及了一下TCP与UDP的区别: TCP: •…

SpringBoot集成kafka-消息转发@sendTo()注解

SpringBoot集成kafka-消息转发sendTo 1、消费者2、生产者3、实体类对象4、JSON工具类5、配置文件application.yml6、测试类7、测试 1、消费者 启动消费者进行消息监听,消费者A监听到生产者发送的消息使用sendTo()注解将消息转发给消费者B package com.power.consu…

Django+Vue二手交易平台的设计与实现

目录 1 项目介绍2 项目截图3 核心代码3.1 需要的环境3.2 Django接口层3.3 实体类3.4 config.ini3.5 启动类3.5 Vue 4 数据库表设计5 文档参考6 计算机毕设选题推荐7 源码获取 1 项目介绍 博主个人介绍:CSDN认证博客专家,CSDN平台Java领域优质创作者&…

react中关于token的两个场景

场景一 在react项目中,路由跳转前需判断是否存在token,有则正常跳转,没有则去登录页面。 实现 这里使用的是localstorage存储token(也可以使用redux管理token) // src\components\AuthRoute.js // 封装高阶组件 //…

cesium 地形获取和生成

1.先从网上下载12.5m精度的地形,然后叠加无人机的地形数据 2.使用global mapper pro合并并导出完整的tiff 3.使用cesiumLab进行tiff的文件数据切片生成terrain格式的数据

cocos发布unity平台试玩广告失败问题

前言 关于如何输出试玩广告和平台文档中的说明就不赘述了,下面主要介绍在发布过程中遇到的问题。 检测不到mraid.open()或应用商店链接 提示: Creative pack validation failed: Your responsive playable is missing mraid.open() Your responsive p…