zoukankan      html  css  js  c++  java
  • 现代密码学中的数论基础知识梳理

    导读

    数论是一门研究自然数之间的关系和规律的学科,普遍认为是纯数学的分支,但并非是完全没有实用性的学科。现代密码学中用到了很多基础数论中的结论,特别是公钥加密体系(例如RSA算法,椭圆曲线加密等)。

    本文目的在于梳理现代密码学中常用到的基础数论方面的定理和结论。其中包括素数的特性、欧几里德算法、线性方程定理、算术基本定理、模算数运算、线性同余定理、欧拉函数、费马小定理、中国剩余定理、欧拉定理、本原根、离散对数问题等等一些基础知识。了解这些知识,应该能够理解现代密码学中经典的

    Diffie-Hellman密钥协商和RSA算法的原理,进而能够理解秘钥管理、数字签名、消息认证、公钥证书等密码学领域的问题。

    本文很大程度上参考了数论概述里面的内容,也借鉴了算法导论密码编码学与网络安全原理与实践的相关章节。

    一、关于互质和整除的一些有用结论和定理

     数论对素数的特性尤其感兴趣,素数是整数的基础构件,就像是元素在化学式中的作用类似。

    1、$d$整除$a$记作:$d mid a$

     如果$d mid a$且$d mid b$,那么$d mid (ax + by)$.

    2、如果$p$是素数,且$p$整除乘积$ab$,则$p$整除$a$或者$p$整除$b$(或者$p$同时整除$a$和$b$)。

    证明的关键是假设$p$不整除$a$,考虑$1=gcd(p,a)$同时整除$p$和$a$。但由于$p$是素数,$p$的因子只能是1或者$p$,所以$gcd(p,a)=1$。由后面的线性方程定理得知,可以构造线性方程$px+ay=1=gcd(p,a)$,两边同时乘上$b$,得$bpx+aby=b$,$p$整除左边等价于$p$整除右边的$b$。$p$不整除$b$的情况可以用同样的方式证明。

    拓展:如果素数$p$整除整数乘积$a_{1}a_{2}a_{3}...a_{r}$,则p至少整除$a_{1}$,$a_{2}$,$a_{2}$,$...$,$a_{r}$中至少一个因数。

    3、1和任意一个自然数是都是互质关系。

    4、任意两个质数构成互质关系。

    5、一个数是质数,另一个数只要不是前者的倍数,两者就构成互质关系,比如3和10。

    6、如果两个数之中,较大的那个数是质数,则两者构成互质关系,比如97和57。

    7、 $p$是大于1的整数,则$p$和$p-1$构成互质关系,比如57和56。

    8、$p$是大于1的奇数,则$p$和$p-2$构成互质关系,比如17和15。

    9、素数$p$与1到$p-1$的任意整数均互质。并且阶乘$(p-1)!$与$p$互质,这个结论在后面费马小定理和欧拉定理的证明过程中会用到。

    二、欧几里德算法

    欧几里德算法的原理和流程其实比较容易理解。

    (GCD递归定理) :对于任意的非负整数$a$和正整数$b$,满足

    $gcd(a,b)=gcd(b,a;mod;b)$

    更详细的将,其计算流程:

    $a=q_{1} imes b+r_{1}\b=q_{2} imes r_{1}+r_{2}\r_{1}=q_{3} imes r_{2}+r_{3}\r_{2}=q_{4} imes r_{3}+r_{4}\...\r_{n-3}=q_{n-1} imes r_{n-2}+r_{n-1}\r_{n-2}=q_{n} imes r_{n-1}+r_{n}\r_{n-1}=q_{n+1} imes r_{n}+0\$

    $r_{n}$即为求得的$a$和$b$的最大公约数。

    以上流程主要需要思考三个问题:

    1)为什么$r_{n}$是公约数?(需要从下往上推理)

    2)为什么$r_{n}$是最大的公约数?(假设$d$是$a$与$b$的任意公约数,如果能够证明$d$整数$r_{n}$,即可得证。)

    3)为什么欧几里德算法最后一定会终止?(因为每轮辗转之后的余数是单调递减的,辗转的轮次数有上界,最后一定能够保证余数为0,然后取最后一个非零余数$r_{n}$就是正确的结果。)

    算法实现Demo:

        //欧几里德算法迭代实现
        public static int getGCD(int a,int b) {
            if (a<b) {//保证a>=b
                return getGCD(b, a);
            }
            if (b>=1) {//保证b>=1
                int temp = 0;
                while(b>0) {
                    temp = a%b;
                    a = b;
                    b = temp;
                }
                return a;
            }else {
                return -1;
            }
        }

    三、扩展欧几里德算法

    扩展欧几里德算法可以用来求解一类有意思的线性方程的整数解,该线性方程的整数求解过程与最大公约数有密切关系。

     对于线性方程($a,b,c$为常数):

    $ax+by=c$

    是很熟悉的方程。这里讨论情况是$a,b,c$满足一定的关系:$c=gcd(a,b)$,也即是这样的线性方程:

    $ax+by=gcd(a,b)$

     这个线性方程必然有整数解,但我们更关心如果用更好算法去求解,该算法利用欧几里德算法求解最大公约数过程中的中间商和余数,进行扩展运算,在求$gcd(a,b)$的过程中,同时也就求得线性方程的整数解$(x,y)$。

     算法实现Demo:

        public static long[] gcdExt(long a,long b){  
            long ans;  
            long[] result=new long[3];  
            if(b==0)  
            {  
                result[0]=a;  
                result[1]=1;  
                result[2]=0;  
                return result;  
            }  
            long [] temp=gcdExt(b,a%b);  
            ans = temp[0];  
            result[0]=ans;  
            result[1]=temp[2];  
            result[2]=temp[1]-(a/b)*temp[2];  
            return result;  
        } 

    四、算术基本定理

    (算术基本定理):每个整数$ngeqslant 2$可唯一分解成素数的乘积:

    $n=p_{1}^{e_{1}}p_{2}^{e_{2}}...p_{r}^{e_{r}}$

    其中,$p_{i}$为素数,且$p_{1}<p_{2} <...<p_{r}$,$e_{i}$为正整数。

     实际上,看似理所当然的事实,其实并非如此。如果自定义一个有别正整数集合的其他集合,很可能就不再满足唯一分解定理。例如,集合E是由偶数构成的集合:

    $E=left {0,2,4,6,8,10,12... ight }$

    也可在这个集合中定义所谓的“素数”,称之为“E-素数”,2,6,10,14,18,22,26,30都是“E-素数”。对这个集合中的元素尝试做“素因子”分解,并不总是能都到唯一分解的结果,例如180=10x18=2x30,存在两种“E-素数”的分解形式。

     实际上算术基本定理包含两个方面:

    1)$n$可以分解成素数乘积的形式。

    2)仅有一种这样的素因子分解的形式(当然这里不考虑因数重排序的情况)。

    显然唯一性分解是算术基本定理的关键和重点。

    另外一个有意思的事实:

    如果$n$是一个合数,则在小于等于$sqrt{n}$的数中必定有一个数$a$整除合数$n$。

    该结论基于算术基本定理:合数$n$必定可以唯一分解多个素数的乘积,这里假设$p$是它的素因子中最小的一个,则$n$必定可以写成$n=p imes m$的形式,这里的$m$是其余大于等于$p$的素因子的乘积,显然$mgeqslant p$,因此$n=p imes mgeqslant p imes p=p^{2}$

    所以,在$0...sqrt{n}$的范围内,必定存在一个数$a$整除$n$。

    可以利用这种方法简单的分辨一个数是否是素数,也可以反复执行上述过程将一个较小的合数进行素因子分解。

    五、 同余式与模算术

    一般来讲,可以将$mod$视为一种求余数的二元运算符,例如$2=5;mod;3$;也可以用来表示同余关系,这种同余关系通常用同余式表示。例如$2equiv 5;(mod;3)$表示模3时2与5同余。

    同余式虽然有别于普通的算数运算下的等式,但是具有相同模的同余式与普通等式有一些相似的特性:

    如果已知:

    $a_{1}equiv b_{1};(mod;m)$ 且$a_{2}equiv b_{2};(mod;m)$

    那么有:

    $a_{2}pm a_{2}equiv b_{2}pm b_{2};(mod;m)$和$a_{2}a_{2}equiv b_{2}b_{2};(mod;m)$

    同时,也不难得出:

    如果,$a^{k}equiv b;(mod;m)$,那么,$(a^{k})^jequiv b^{j};(mod;m)$

    特别的当$b=1$时:

    如果$a^{k}equiv 1;(mod;m)$,那么,$(a^{k})^{j}equiv 1;(mod;m)$。

    但是,由$acequiv bc;(mod;m)$不一定能得到$aequiv b;(mod;m)$。

    例如$2 imes25equiv2 imes20;(mod;10) $,但是$25 otequiv 20;(mod;10)$。

    只有当$c$和$m$互质时(也即是$gcd=(c,m)=1$),才能够从同余式两边消去$c$。

     由同余式可以引出同余方程:

    $axequiv c;(mod;m)$

    求解上述同余方程有一个定理,叫做同余方程定理。

    (同余方程定理):设$a,c,m$是整数,$mgeqslant 1$,且设$g=gcd(a,m)$,则

    1)如果$g$不整除$c$,那么同余方程$axequiv c;(mod;m)$没有解。

    2)如果$g$整除$c$,那么同余方程$axequiv c;(mod;m)$恰好有$g$个解。

    以上同余方程的求解过程需要用到扩展欧几里德的求解方法。实际上$axequiv c;(mod;m)$可以转化为线性方程$ax+m(-y)=c$。

    特别地,当$a$和$m$互质,即$g=gcd(a,m)=1$时,同余方程变成:

    $axequiv 1;(mod;m)$

    $a$和$x$互为模反元素,这在RSA公钥加密算法生成秘钥过程中有应用。

    六、费马小定理

    费马小定理揭示了整数的幂在模运算下的特殊规律。

    (费马小定理):设$p$是素数,$a$是任意的正整数且满足$a otequiv0;(mod;p)$,则

    $a^{p-1}equiv 1 ;(mod;p)$

    实际上对于条件的更简单的表述可以为"$a$与素数$p$互质"即可。

    证明费马小定理并不是非常难,证明过程是基于这样一个结论:

    设素数$p$与任意正整数$a$互质,那么集合$S=left { a,2a,3a,...(p-1)a ight }$中任意任意两个元素均不可能模$p$同余。也即是$ja otequiv ka;(mod;p)$。其证明过程只需要利用反证法即可。

    上述结论表明,如果对集合$S$中的每一个元素模$p$的结果,其结果刚好与集合$T= left { 1,2,3,4...(p-1) ight }$中的元素一一对应(不考虑次序重排)。

    于是有:

    $a imes 2a imes3a... imes(p-1)aequiv 1 imes2 imes3... imes(p-1);(mod;p)$

    稍微整理得:

    $(p-1)! imes a^{p-1}equiv(p-1)!;(mod;p)$

    这里必然后$gcd((p-1)!,p)=1$,所以,可以两边消去$(p-1)!$,得到$a^{p-1}equiv 1 ;(mod;p)$。

    正是由于存在这样的关系,所有费马小定理可以用来简化对整数的幂取模的计算。

    费马小定理在数论中非常重要,与其三个定理(分别是威尔逊定理、欧拉定理和中国剩余定理)合称数论四大基本定理。更有趣的是,费马小定理实际上可以视为欧拉定理的一个特例。

    最后,费马小定理还有一种等价的表示形式:

    若$p$是素数,$a$是正整数,则

    $a^{p-1}equiv a;(mod;p)$

    这里不需要$a$与$p$互质的条件。这并不是一件很奇怪的事情,无非是利用模算术的除法特性(见同余式与模算术)的变形。

    七、中国剩余定理

    中国剩余定理(也叫作孙子定理)所描述的问题在小学课本中都能找到,只不过当时只能用方程组去刻画这个的问题。

    在数论中,它有不止一种表述形式,我见到的就至少有两种。

    其中一种比较易懂的描述为:

    设$m,n$是正整数,$gcd(m,n)=1$,$b,c$是任意正整数,则同余方程组

    $xequiv b;(mod;m)\xequiv c;(mod;n)$
    恰有一个解$0leqslant xleqslant mn$。

     以上是从方程的角度描述,另外一种从对应的角度(数与k元组的对应关系)表述也是可行的,可以看做是上面表述形式更抽象的扩展:

     令

    $M=prod_{i=1}^{k}m_{i}$,其中$m_{i}$两两互质

    则$Z_{M}=left { 0,1,2,3...(m-1) ight }$中任意整数会对应一个$k$元组:

    $Aleftrightarrow (a_{1},a_{2}...,a_{k})$

    其中$a_{i}$当然是要在$Z_{m_{i}}$中(也即是$a_{i}in Z_{m_{i}}$),并且$a_{i}$由关系$a_{i}=A;mod;m_{i}$给出。

    从以上定理实际上可以推断出$A$与$k$元组唯一一对应的事实。

    以上描述形式是算法导论密码编码学与网络安全--原理与实践中采用的表述形式。相比于第一种表述形式,第二种表述更具有通用性,也更抽象。中国剩余在推导欧拉函数求解公式时会用到。

    八、欧拉函数

     欧拉函数$phi (m)$的含义是1到$m-1$中(也就是$left [ 1,m-1 ight ]$)且与$m$互质的整数的个数。它是数论中一个非常重要的函数。

    如何计算欧拉函数的值是一个关键的问题。欧拉函数的计算方法的推导主要用到两个结论:

    (1)如果$p$是素数,$kgeqslant 1$,则$phi (p^{k})=p^k-p^{k-1}=p^k(1-frac{1}{p})$

    (2)如果$gcd(m,n)=1$,则$phi (mn)=phi (m) imes phi (n)$

    证明(1)的思路很简单:从1到$p^{k}$共有$p^{k}$个整数,这些整数中当然有可能存在与$p^{k}$不互质的数,那么只要扣除去这些数就可以了。显而易见的是,这些与$p^{k}$不互质的数并不难找,它们分别是:

    $p,2p,3p,...,(p^{k-1}-2) imes p,(p^{k-1}-1) imes p,p^{k-1} imes  p$

    一共有$p^{k-1}$个数与$p^{k}$不互质,那么从$p^{k}$中扣除这$p^{k-1}$个数即可。

    证明(2)比较复杂一点,其思路是采用计数的思想然后结合中国剩余定理(第一种表述形式)来证明。

    有了以上两个结论,结合算术基本定理,可以得到计算$phi (m)$比较通用的公式:

    假设任意正整数$m$,且其素因子分解形式为

    $m=p_{1}^{k_{1}}p_{2}^{k_{2}}...p_{r}^{k_{r}}$

    利用上面的(2)可以得到

    $phi (m)=phi (p_{1}^{k_{1}})phi (p_{2}^{k_{2}})...phi (p_{r}^{k_{r}})$

    然后利用(1),继续得到

    $phi (m)=p_{1}^{k_{1}}p_{2}^{k_{2}}...p_{r}^{k_{r}}(1-frac{1}{p_{1}})(1-frac{1}{p_{2}})...(1-frac{1}{p_{r}})$

    也就是

    $phi (m)=m(1-frac{1}{p_{1}})(1-frac{1}{p_{2}})...(1-frac{1}{p_{r}})$

    例如

    $phi (12)=phi (2^{2} imes 3)=phi (2^{2}) imes phi (3)=12 imes (1-frac{1}{2}) imes (1-frac{1}{3})=4$

    另外,欧拉函数与各因数之间存在一种巧妙的关系:

    设$d_{1},d_{2},...,d_{r}$是$n$的因数,则

    $phi (d_{1})+phi (d_{2})+...+phi (d_{r})=phi (n)$

    其实当$n=p$或者$n=p^{2}$甚至$n=p^{k}$($p$是素数)时,很容易验证其正确性。

    九、欧拉定理

    欧拉定理与费马小定理同样都是揭示了整数的幂在模运算下的特殊规律,实际上他们有微妙的关系。

    (欧拉定理):如果$gcd(a,m)=1$,则

    $a^{phi (m)}equiv 1;(mod;m)$

    实际上证明欧拉定理的方法与证明费马小定理基本类似,此处略去。

    欧拉定理与费马小定理有微妙的关系:如果这里的$m$是一个素数,则$phi (m)=m-1$,由此得到费马小定理。说明费马小定理实际上可以看成欧拉定理的一个特例。

    与费马小定理类似,欧拉定理也有另外一种表现形式:

    $a^{phi (m)+1}equiv a;(mod;m)$

    这里没有要求$a$与$m$互质的条件。

    十、模反元素

    如果两个正整数$a$和$m$互质,那么一定可以找到整数$b$,使得 $ab-1$ 被$m$整除,或者说$ab$被$m$除的余数是1。

    $abequiv1;(mod;m)$

    则此时$b$就是$a$的模反元素。

    实际上这里相当于求解同余方程$axequiv 1;(mod;m)$,当$gcd(a,m)=1$时,必定存在一个整数解,因此模反元素必定存在,此解即是$a$的模反元素。

    从欧拉定理的角度

    $a^{phi (m)}=a imes a^{phi (m)-1}equiv 1;(mod;m)$

    也可以证明模反元素是存在的。

    更进一步,如果$p$是素数,由集合$Z_{p}=left { 0,1,2,...p-1 ight }$和二元运算模$p$的算术运算构成一个有限交换群G。G中每一个元素都有乘法逆元,此乘法逆元就是这里的模反元素。

    十一、本原根

    本原根通常与幂模有关,观察如下例子:

    $3^{1};mod;7=3\3^{2};mod;7=2\3^{3};mod;7=6\3^{4};mod;7=4\3^{5};mod;7=5\3^{6};mod;7=1\...$

    可以发现3的各幂次模$n$能够得到一个循环的序列$left { 3,2,6,4,5,1 ight }$,这个序列刚好对应着小于等于7且与7互质的整数集合。这并非一个偶然规律,2或者3的各次幂模5,2或者6或者7或者8的各次幂模11都能够得到同样的规律。

    当然也并不是总是这样,例如

    $2^{1};mod;7=2\2^{2};mod;7=4\2^{3};mod;7=1\2^{4};mod;7=2\...$

    更一般的,考虑$p$为素数,$gcd(a,p)=1$且$aleqslant p-1$,如下序列

    $a;mod;p,a^{2};mod;p,a^{3};mod;p,...,a^{p-3};mod;p,a^{p-2};mod;p,a^{p-1};mod;p$

    如果$a^{p-1};mod;p=1$,那么可以证明上述序列值必然各不相同(证明可以用反证法,不存在$a^{i}equiv a^{j};(mod;p)$的情况)。因为这里模$p$运算的结果总会映射到集合$Z_{p}=left { 1,2,3,...,p-2,p-1 ight }$,这个集合中的每个元素与$p$互质。也即是说不考虑次序重排,上述序列值对应了集合$Z_{p}$的值。

    这时称$a$是$p$的本原根或者生成元。

    并非所有的整数都存在本原根,事实上只有$1,4,p^{alpha},2p^{alpha}$才有本原根,其中$p$是任意奇素数,可见素数一定存在本原根。

    (原根定理):每个素数$p$都有本原根,而且刚好有$phi (p-1)$个模$p$的本原根。

     另外还有一些值得挖掘的规律,不难发现,对于$a^{k}equiv1;(mod;p)$,这样的$k$可能不止一个,比如:

    $2^{3}equiv 1;(mod;p)\2^{6}equiv 1;(mod;p)$

    取最小的$k$称为$a$模$p$的阶:$ord_{p}(a)$,例如$ord_{7}(2)=3$。

    不难发现,$1leqslant ord_{p}(a)leqslant p-1$且总是整除$p-1$(从费马小定理的角度思考可以容易得出结论)。

    十二、离散对数问题

    离散对数的问题很好理解,与算术对数相对,只是在算术对数的基础上增加了模运算。

    对于$y=g^{x};mod;p$,如果已知$x,g,p$求$y$是比较容易的求解的;但是反过来,已知$y,g,p$求$x$是很困难的,因此这里可以看成一个单向函数。

    Diffie-Hellman密钥协商原理正是基于这样的离散对数问题而设计。而椭圆曲线加密是基于定义在椭圆曲线上的特殊加法运算规则下的离散对数问题而设计,两者达到的目的是一致的,都是利用某一个方向上的计算困难程度保证加密算法的机密性。

    十三、References

    1、数论概述

    2、算法导论.第三一章.数论算法

    3、密码编码学与网络安全原理与实践

    完!

    转载请注明原文出处:http://www.cnblogs.com/qcblog/p/8976017.html

  • 相关阅读:
    在Linux下修改图形界面的分辨率
    Linux 常用命令
    读ActiveAndroid源码(三)
    读ActiveAndroid源码(二)
    读ActiveAndroid源码(一)
    Android中图片的文件储存
    构造器内部的多态方法的行为
    摸触事件分发的小实践——关闭View滑动
    【Java】 关于类的初始化
    git配置http代理
  • 原文地址:https://www.cnblogs.com/qcblog/p/8976017.html
Copyright © 2011-2022 走看看