第三十五个知识点:给针对ECDLP问题的Pollard rho,Pollard "Kangaroo",parallel Pollard rho攻击的一个粗略的描述

我们的目标是对任意一个有限循环阿贝尔群\(G\),解决离散对数问题\(h = g^x\)。问题进行详细描述,给定一个循环群\(G = <g>\),\(G\)的阶是素数\(p\),给定\(G\)中元素\(h\),我们需要找到这样的\(x\)使得\(h = g^x\)成立。我们使用上一篇中的方法进行计算时,时间复杂度是\(O(\sqrt{n})\),但是这个算法也需要\(O(\sqrt{p})\)的时间复杂度。因此,我们对使用使用更小的空间有了需求。这个任务被算法[1]实现了。

1.Pollard's Rho Algorithm

让\(f:S \rightarrow S\)是一个\(S\)到它自身的映射。\(S\)的大小是\(n\)。对于一个随机的值\(x_0 \in S\),对于每个\(i \ge 0\),我们计算\(x_{i+1} = f(x_i)\)。对于每一步来说\(x_{i+1} = f(x_i)\)都是一个确定的函数,我们就得到了一个确定的随机序列\(x_0,x_1,x_2...\)。

因为\(S\)是有限的,我们最终会得到\(x_i=x_j\)因此\(x_{i+1} = f(x_i) = f(x_j) = x_{j+1}\)。因此,序列\(x_0,x_1,x_2...\)将变成一个循环。我们的目标是在上述的序列中找到一个碰撞,就是找到\(i,j\)使得\(i \neq j\)并且\(x_i = x_j\)。

为了寻找一个碰撞,我们使用Floyd's发现算法,给定\((x_1,x_2)\),我们计算\((x_2,x_4)\),然后是\((x_3,x_6)\)等等。例如给定\((x_i,x_{2i})\),我们就可以计算\((x_{i+1},x_{2i+2}) = (f(x_i),f(f(x_{2i}))))\)。当我们发现的时候我们有\(x_m = x_{2m}\)。此时\(m = O(\sqrt{n})\)。(这里计算出来的是当\(f\)为完全随机函数而算出的时间复杂度。)

对于离散对数问题,我们将群\(S\)人为划分成三个组\(S_1,S_2,S_3\)。我们假设\(1 \in S_2\),然后定义下面的随机序列

\[R_{i+1} = f(R_i) = \left\{
\begin{aligned}
Q+R_i,R_i \in S_1 \\
2R_i,R_i \in S_2\\
P+R_i,R_i \in S_3
\end{aligned}
\right.\]
\[a_{i+1} = \left\{
\begin{aligned}
a_i,R_i \in S_1 \\
2a_i \mod N ,R_i \in S_2 \\
a_i + 1, R_i \in S_3
\end{aligned}
\right.\]
\[b_{i+1} = \left\{
\begin{aligned}
b_i+1,R_i \in S_1 \\
2b_i \mod N ,R_i \in S_2 \\
b_i, R_i \in S_3
\end{aligned}
\right.\]

然后我们初始化参数\((x_0,a_0,b_0)=(1,0,0)\),我们知道对所有的\(i\),我们有\(log_g(x_i)=a_i+b_i\),\(log_g(h)=a_i+b_ix\)。使用Floyd's算法,我们能找到\(x_m = x_{2m}\)。这样我们就计算出了\(x = \frac{a_{2m}-a_m}{b_m-b_{2m} \mod n}\)。

我们精确的计算,如果\(f\)是完全随机的,那么时间复杂度的期望是\(O(\sqrt{n})\)。

2.Pollard's Kangaroo Method

Pollard's Kangaroo 算法和Rho算法类似,但是它更适合我们知道\(x\)在一定范围,即\(x \in [a,b]\)。

让w = b-a是区间的长度。我们定义一个集合\(S = \{s_0,...s_{k-1}\}\)是一个非降序的序列。这意味着m的值在\(N = \sqrt{w}\)附近。我们通常选择\(s_i = 2^i,0\le i <k\)。因此\(m = 2^k/k,k = 1/2*log_2(m)\)。群被分成了k个子集。我们定义一个随机的序列\(x_{i+1} = x_ig^{s_j},x_i \in S_i\)。

我们计算出确定的随机序列,从\(g_0 = g^b\)

[1] http://www.cs.bris.ac.uk/~nigel/Crypto_Book/book.ps (pages 208 - 214)

第三十五个知识点:给针对ECDLP问题的Pollard rho,Pollard "Kangaroo",parallel Pollard rho攻击的一个粗略的描述的更多相关文章

  1. 孤荷凌寒自学python第三十五天python的文件操作之针对文件操作的os模块的相关内容

     孤荷凌寒自学python第三十五天python的文件操作之针对文件操作的os模块的相关内容 (完整学习过程屏幕记录视频地址在文末,手写笔记在文末) 一.打开文件后,要务必记得关闭,所以一般的写法应当 ...

  2. Python进阶(三十五)-Fiddler命令行和HTTP断点调试

    Python进阶(三十五)-Fiddler命令行和HTTP断点调试 一. Fiddler内置命令   上一节(使用Fiddler进行抓包分析)中,介绍到,在web session(与我们通常所说的se ...

  3. NeHe OpenGL教程 第三十五课:播放AVI

    转自[翻译]NeHe OpenGL 教程 前言 声明,此 NeHe OpenGL教程系列文章由51博客yarin翻译(2010-08-19),本博客为转载并稍加整理与修改.对NeHe的OpenGL管线 ...

  4. JAVA之旅(三十五)——完结篇,终于把JAVA写完了,真感概呐!

    JAVA之旅(三十五)--完结篇,终于把JAVA写完了,真感概呐! 这篇博文只是用来水经验的,写这个系列是因为我自己的java本身也不是特别好,所以重温了一下,但是手比较痒于是就写出了这三十多篇博客了 ...

  5. Java进阶(三十五)java int与integer的区别

    Java进阶(三十五)java int与Integer的区别 前言 int与Integer的区别从大的方面来说就是基本数据类型与其包装类的区别: int 是基本类型,直接存数值,而Integer是对象 ...

  6. Gradle 1.12用户指南翻译——第三十五章. Sonar 插件

    本文由CSDN博客万一博主翻译,其他章节的翻译请参见: http://blog.csdn.net/column/details/gradle-translation.html 翻译项目请关注Githu ...

  7. SQL注入之Sqli-labs系列第三十四关(基于宽字符逃逸POST注入)和三十五关

    开始挑战第三十四关和第三十五关(Bypass add addslashes) 0x1查看源码 本关是post型的注入漏洞,同样的也是将post过来的内容进行了 ' \ 的处理. if(isset($_ ...

  8. “全栈2019”Java多线程第三十五章:如何获取线程被等待的时间?

    难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java多 ...

  9. 第三百三十五节,web爬虫讲解2—Scrapy框架爬虫—豆瓣登录与利用打码接口实现自动识别验证码

    第三百三十五节,web爬虫讲解2—Scrapy框架爬虫—豆瓣登录与利用打码接口实现自动识别验证码 打码接口文件 # -*- coding: cp936 -*- import sys import os ...

随机推荐

  1. Kotlin 学习(2)

    属性和字段 1.声明属性 Kotlin中可以使用var关键字声明可变属性,或者用val关键字声明只读属性,属性的类型在后面,变量名在前面,中间加冒号和空格. public class Address ...

  2. API接口设计之token、timestamp、sign 具体架构与实现(APP/小程序,传输安全)

    Java生鲜电商平台-API接口设计之token.timestamp.sign 具体设计与实现 说明:在实际的业务中,难免会跟第三方系统进行数据的交互与传递,那么如何保证数据在传输过程中的安全呢(防窃 ...

  3. 技术预演blog

    canal整合springboot实现mysql数据实时同步到redis spring+mysql集成canal springboot整合canal监控mysql数据库 SpringBoot cana ...

  4. 如何设置eclipse下查看java源码

    windows--preferences--java--installed jres --选中jre6--点击右边的edit--选中jre6/lib/rt.jar --点击右边的 source att ...

  5. Element-ui 中对表单进行验证

    Element-ui 中对表单(Form)绑定的对象中的对象属性进行校验 如果是直接绑定属性,是可以的,但是绑定对象中的属性就需要特别处理,需要在rules中添加双引号 " "或者 ...

  6. Java 将Word转为OFD

    通常在工作中比较常用到的Microsoft Word是属于国外的文档内容编辑软件,其编译技术均属国外.而OFD是一种我国的自主文档格式,在某些特定行业或企业的文档存储技术上是一种更为安全的选择.下面将 ...

  7. YC-Framework版本更新:V1.0.3

    分布式微服务框架:YC-Framework版本更新V1.0.3!!! 本次版本V1.0.3更新 集成分布式事务Seata: 集成分布式事务Tx-LCN: 集成Kafka: 集成RocketMQ: 集成 ...

  8. Python基础入门(7)- Python异常处理机制

    1.初识异常 1.1.什么是异常与异常处理 异常就是错误 异常会导致程序崩溃并停止运行 能监控并捕获异常,将异常部位的程序进行修理使得程序继续正常运行 1.2.异常的语法 1 # coding:utf ...

  9. wordpress的.htaccess很容易就被挂马啊

    wordpress的.htaccess很容易就被挂马啊 修改成这样吧: # BEGIN WordPress<IfModule mod_rewrite.c>RewriteEngine OnR ...

  10. InnoDB学习(五)之数据库锁

    InnoDB存储引擎的默认隔离级别事可重复读,MVCC多版本并发控制仅仅解决了快照读情况下的数据隔离,而对于当前读,InnoDB通过锁来进行并发控制. InnoDB锁 本文主要参考了MySQL官方文档 ...