Benaloh cryptosystem explained

The Benaloh Cryptosystem is an extension of the Goldwasser-Micali cryptosystem (GM) created in 1985 by Josh (Cohen) Benaloh. The main improvement of the Benaloh Cryptosystem over GM is that longer blocks of data can be encrypted at once, whereas in GM each bit is encrypted individually.[1] [2] [3]

Scheme Definition

Like many public key cryptosystems, this scheme works in the group

(Z/nZ)*

where n is a product of two large primes. This scheme is homomorphic and hence malleable.

Key Generation

Given block size r, a public/private key pair is generated as follows:

  1. Choose large primes p and q such that

r\vert(p-1),\operatorname{gcd}(r,(p-1)/r)=1,

and

\operatorname{gcd}(r,(q-1))=1

  1. Set

n=pq,\phi=(p-1)(q-1)

  1. Choose

y\in

*
Z
n
such that

y\phi/r\not\equiv1\modn

.

Note: If r is composite, it was pointed out by Fousse et al. in 2011[4] that the above conditions (i.e., those stated in the original paper) are insufficient to guarantee correct decryption, i.e., to guarantee that

D(E(m))=m

in all cases (as should be the case). To address this, the authors propose the following check: let

r=p1p2...pk

be the prime factorization of r. Choose

y\in

*
Z
n
such that for each factor

pi

, it is the case that
\phi/pi
y

\ne1\modn

.
  1. Set

x=y\phi/r\modn

The public key is then

y,n

, and the private key is

\phi,x

.

Message Encryption

To encrypt message

m\inZr

:
  1. Choose a random

u\in

*
Z
n
  1. Set

Er(m)=ymur\modn

Message Decryption

To decrypt a ciphertext

*
c\inZ
n
:
  1. Compute

a=c\phi/r\modn

  1. Output

m=logx(a)

, i.e., find m such that

xm\equiva\modn

To understand decryption, first notice that for any

m\inZr

and
*
u\inZ
n
we have:

a=(c)\phi/r\equiv(ymur)\phi/r\equiv(ym)\phi/r(ur)\phi/r\equiv(y\phi/r)m(u)\phi\equiv(x)m(u)0\equivxm\modn

To recover m from a, we take the discrete log of a base x. If r is small, we can recover m by an exhaustive search, i.e. checking if

xi\equiva\modn

for all

0...(r-1)

. For larger values of r, the Baby-step giant-step algorithm can be used to recover m in

O(\sqrt{r})

time and space.

Security

The security of this scheme rests on the Higher residuosity problem, specifically, given z,r and n where the factorization of n is unknown, it is computationally infeasible to determine whether z is an rth residue mod n, i.e. if there exists an x such that

z\equivxr\modn

.

Notes and References

  1. Josh . Cohen . Michael . Ficsher . A Robust and Verifiable Cryptographically Secure Election Scheme . 372–382 . 1985 . Proceedings of 26th IEEE Symposium on Foundations of Computer Science . PDF.
  2. Josh . Benaloh . Verifiable Secret-Ballot Elections (Ph.D. thesis). . 1987 . PDF.
  3. Josh . Benaloh . Dense Probabilistic Encryption. . Workshop on Selected Areas of Cryptography . 120–128 . 1994 . PDF.
  4. 1008.2991. AFRICACRYPT--> . 2011 . Benaloh's Dense Probabilistic Encryption Revisited . Laurent . Fousse . Pascal . Lafourcade . Mohamed . Alnuaimi. cs.CR .