PKG efectuează următorii pași
- Alege $p,q \in \mathbb{P}$.
- calculati $N=pq$.
- calculati $\phi (n)=(p-1)(q-1)$.
- Alege $e$ cu $gcd(e,\phi(n))=1$ și $1 < e < \phi(n)$.
- Lăsați-l să fie $e = {p^{e_1}_1} \cdot {p^{e_2}_2} \cdot \ldots
{p^{e_k}_k}$ factorizarea prime a $e$ pentru $i \in k:p_i \in \mathbb{P},e_i \in \mathbb{N}$.
Alegeți o mapare injectivă $H$ cu
\begin{align*}
H &: \begin{cases}
\{0,1\}^i \rightarrow \mathbb{Z} / N \mathbb{Z} și \
ID \mapsto m = {p^{e_{m_1}}_1} \cdot {p^{e_{m_2}}_2} \cdot \ldots {p^{e_{m_k}}_k} & (i \in k :p_i \in \mathbb{P},e_{m_i} \in
\mathbb{N})
\end{cazuri}
\end{align*}
și $eH(ID)<\phi(n)$ pentru $i \in \mathbb{n}$. Parametrii disponibili public sunt $\texttt{params} = \langle e, N, H \rangle$ si $\texttt{cheia principală}$ este $\phi(n) \in \mathbb{Z} / N \mathbb{Z}$.
PKG ia apoi un $ID \în \{0,1\}^{*}$ (de la Alice) și calculează Cheia Secretă corespunzătoare $d_{ID}$ cu
\begin{align*}
(e H(ID)) d_{ID} \equiv 1 \text{ mod } \phi(n)
\end{align*}
Când Bob vrea să cripteze un mesaj $m \in \mathbb{Z} / N \mathbb{Z}$, el ia $\texttt{params}$ si calculeaza
\begin{align*}
c \equiv m^{e H(ID)} \text{ mod } N
\end{align*}
Alice decriptează acest text cifrat $c$ cu
\begin{align*}
m \equiv c^{d_{ID}} \text{ mod } N
\end{align*}
EXEMPLU
$p = 1010231362240711373894507355467 \in \mathbb{P}$ și
$q = 793738224882014450642935586909 \in \mathbb{P}$.
$N=pq=801859248185081566400631735533731882269717325788593134781503$
$\phi(N) = 2^3 \cdot 31 \cdot 283 \cdot 29347 \cdot 39547129
\cdot 422250739 \cdot 1354514929 \cdot 17211833615713895353775639$.
$e = 5 \cdot 7 \cdot 11 \cdot 13 \cdot 17 \cdot 19 \cdot 23
\cdot 29$.
Se aplica $ID \în \{0,1\}^8$ cu $ID=\langle b_1,b_2,\ldots,b_8
\rangle$ pentru $i \in 8:b_i \in \{0,1\}$. Alege $H$ la fel de:
\begin{align*}
H &: \begin{cases}
\{0,1\}^8 \rightarrow \mathbb{Z} / N \mathbb{Z} și \
ID \mapsto m = {5^{{b_1}}} \cdot {7^{{b_2}}} \cdot \ldots \cdot {29^{{b_8}}} &
\end{cazuri}
\end{align*}
Parametrii disponibili public sunt
\begin{align*}
\texttt{params} &= \langle 1078282205, 801859248185081566400631735533731882269717325788593134781503, H \rangle
\end{align*}
The $\texttt{cheia principală}$ este
\begin{align*}
\phi(N) &= 801859248185081566400631735531927912682594599964055691839128
\end{align*}
PKG ia atunci ID USD = 01101111$ ca ID-ul utilizatorului „o”. Atunci $H(ID) = 5^0 \cdot 7^1 \cdot 11^1 \cdot 13^0 \cdot 17^1 \cdot 19^1 \cdot 23^1 \cdot 29^1 = 16588957$, $eH(ID)=17887577132610185$ și $d_{ID}=308315206989333722335381678529602981822693965290742774973561$.
Utilizatorul „i” dorește acum să cripteze mesajul 3463463463463424234234234. El calculează
\begin{align*}
c &\equiv 3463463463463424234234234^{17887577132610185} \text{ mod N} \
&\equiv 353097511425650359803351296367609508451542189692844760010085 \text{ mod N}
\end{align*}
Utilizatorul „o” decriptează textul cifrat cu:
\begin{align*}
m &\equiv 353097511425650359803351296367609508451542189692844760010085^{D_{ID}} \text{ mod N} \
&\equiv 3463463463463424234234234 \text{ mod N}
\end{align*}