Paillier同态加密之解密的正确性

一、Paillier同态加密系统

1.1 符号说明

  • p,q为大素数,\(p\neq q\)
  • \(n=p\cdot q\)
  • \(\lambda =(p-1)\cdot (q-1)\)
  • \(B_{\alpha}=\{e\in Z_{n^{2}}^{*}|ord(e)=\alpha\cdot n\}\)
  • \(B=\bigcup_{\alpha=1}^{\lambda}B_{\alpha}\)
  • 函数\(L(x,n)=[(x-1)/n]\)

1.2 密钥生成

  • 随机选择指定长度的大素数p,q;(p,q)为私钥;
  • \(n=p*q\);随机选择\(g\in B\);(g,n)为公钥;

1.3 加密

  • 明文m<n,随机选择r<n;
  • 密文\(c=g^{m}\cdot r^{n}\ \textrm{mod}\ n^{2}\)

1.4 解密

  • 密文\(c<n^{2}\)
  • 明文\(m=\frac {L(c^{\lambda}\ \textrm{mod}\ n^{2}, n)} {L(g^{\lambda}\ \textrm{mod}\ n^{2}, n)}\ \textrm{mod}\ n\)

二、解密的正确性

对于\(g=1+n\)的情形,网上已有很多证明解密正确性的推导,而我在这里是希望给出更一般的情形下解密正确性的证明;推导参考提出Paillier同态加密系统的这篇论文:《Public-Key Cryptosystems Based on Composite Degree Residuosity Classes》。

定义1:定义映射\(\varepsilon_{g}: Z_{n}\times Z_{n}^{*}\mapsto Z_{n^{2}}^{*}\)\(\varepsilon_{g}(x,y)=g^{x}\cdot y^{n}\ \textrm{mod}\ n^{2}\)

引理1:若\(g\)的阶\(ord(g)\)\(n\)的非零整数倍,则\(\varepsilon_{g}\)是双射。

证明:由于\(Z_{n}\times Z_{n}^{*}\)\(Z_{n^{2}}^{*}\)的元素个数均为\(n\phi(n)\)(参考《近世代数》(第三版)杨子胥 第149页 定理1),因此只需证明\(\varepsilon_{g}\)是单射;

假设\(\varepsilon_{g}(x_{1},y_{1})=\varepsilon_{g}(x_{2},y_{2})\)

\(g^{x_{1}-x_{2}}\cdot (y_{1}\cdot y_{2}^{-1})^{n}\equiv 1\ \textrm{mod}\ n^{2}\)

因此\(g^{\lambda(x_{1}-x_{2})}\cdot (y_{1}\cdot y_{2}^{-1})^{\lambda\cdot n}\equiv g^{\lambda(x_{1}-x_{2})}\equiv 1\ \textrm{mod}\ n^{2}\)

从而\(ord(g)|\lambda(x_{1}-x_{2})\)

\(n|ord(g)\Rightarrow n|\lambda(x_{1}-x_{2}) , (n,\lambda)=1\Rightarrow n|(x_{1}-x_{2})\)

因此在\(x_{1},x_{2}\in Z_{n}\)的意义下,\(x_{1}=x_{2}\)

那么\((y_{1}\cdot y_{2}^{-1})^{n}\equiv 1\ \textrm{mod}\ n^{2}\),则\(y_{1}\cdot y_{2}^{-1}\equiv 1\ \textrm{mod}\ n\),理由如下:

假设\(x^{n}\equiv 1\ \textrm{mod}\ n^{2}\),则:

\[\begin{cases} x^{(p-1)\cdot q+q}\equiv 1\ \textrm{mod}\ p\ \\ x^{(q-1)\cdot p+p}\equiv 1\ \textrm{mod}\ q\ \end{cases} \]

即:

\[\begin{cases} x^{q}\equiv 1\ \textrm{mod}\ p\ \\ x^{p}\equiv 1\ \textrm{mod}\ q\ \end{cases} \]

\((p,q-1)=1\)\((q,p-1)=1\),从而存在\(s,t\in Z\),使得\(p\cdot s\equiv 1\ \textrm{mod}\ q-1 , q\cdot t\equiv 1\ \textrm{mod}\ p-1\),同理可得:

\[\begin{cases} x\equiv 1\ \textrm{mod}\ p\ \\ x\equiv 1\ \textrm{mod}\ q\ \end{cases} \]

由中国剩余定理,\(x\)在模\(n\)意义下有唯一解,又1满足上述同余方程组,因此\(x\equiv 1\ \textrm{mod}\ n\)
回到本引理的证明,则有\(y_{1}\cdot y_{2}^{-1}\equiv 1\ \textrm{mod}\ n\),即\(y_{1}\equiv y_{2}\ \textrm{mod}\ n\)
综上,\(\varepsilon_{g}\)是单射,也是双射。

解密的正确性

由引理1,存在\((a,b)\in Z_{n}\times Z_{n}^{*}\)使得\(g=(1+n)^{a}\cdot b^{n}\ \textrm{mod}\ n^{2}\),则:

\(g^{\lambda}\equiv (1+n)^{a\cdot\lambda}\cdot b^{n\cdot\lambda}\equiv (1+n)^{a\cdot\lambda}\equiv 1+na\lambda\ \textrm{mod}\ n^{2}\)

同理,\(c^{\lambda}\equiv (g^{m}\cdot r^{n})^{\lambda}\equiv [(1+n)^{a}\cdot b^{n}]^{m\lambda}\cdot r^{n\lambda}\equiv (1+n)^{a\cdot m\lambda}\cdot b^{n\cdot m\lambda}\cdot r^{n\lambda}\equiv (1+n)^{a\cdot m\lambda}\equiv 1+mna\lambda\ \textrm{mod}\ n^{2}\)

因此,\(L(c^{\lambda})\cdot [L(g^{\lambda})]^{-1}\equiv ma\lambda\cdot (a\lambda)^{-1}\equiv m\ \textrm{mod}\ n\)

posted @ 2021-03-20 19:26  _Mind  阅读(700)  评论(0编辑  收藏  举报