Thông tin
Trong mật mã học, RSA là một thuật toán mật mã hóa khóa công khai. Đây là thuật toán đầu tiên phù hợp với việc tạo ra chữ ký điện tử đồng thời với việc mã hóa. Nó đánh dấu một sự tiến bộ vượt bậc của lĩnh vực mật mã học trong việc sử dụng khóa công cộng. RSA đang được sử dụng phổ biến trong thương mại điện tử và được cho là đảm bảo an toàn với điều kiện độ dài khóa đủ lớn.
RSA được xây dựng dựa trên lý thuyết số.
Lý thuyết cơ bản toán học trong RSA
Mô tả sơ lược lý thuyết
Để học RSA, chúng ta cần phải biết một số lý thuyết về đồng dư thức, module, số nguyên tố, hàm Euler, định lý số dư Trung Hoa,…
Quá trình tạo khóa và giải mã
Quá trình tạo khóa
- Chọn 2 số nguyên tố lớn \(p\) và \(q\) sao cho \(p \ne q\)
- Tính \(n=pq\)
- Tính giá trị của hàm Euler: \(\phi(n) = \big(p - 1\big)\big(q-1\big)\)
- Chọn một số tự nhiên \(e\) sao cho \(\begin{cases} 1<e<\phi(n) \\ \big(e, \phi(n)\big) = 1 \end{cases}\)
- Tính \(d\) sao cho \(de \equiv 1 \ \big(mod \ \phi(n) \big)\)
Lưu ý
Ớ bước 3: Theo tiêu chuẩn PKCS#1 v2.1 người ta dùng \(\lambda = LCM(p-1,q-1)\) thay cho
\[\phi(n) = \big(p - 1\big)\big(q-1\big)\]Ở bước 5: Ta dễ dàng biến đổi như sau:
\[\begin{align*} de \equiv 1 \ \big(mod \ \phi(n) \big) \Rightarrow & de - 1 \equiv \ \big(mod \ \phi(n) \big) \\ \Rightarrow &de - 1 \vdots \phi(n) \\ \Rightarrow &de - 1 = k .\phi(n) \\ \Rightarrow &d = \frac{k.\phi(n) + 1}{e} = \frac{k(p-1)(q-1) + 1}{e} \end{align*}\]Quá trình mã hóa
Giả sử An là người nhận thông điệp bí mật, chỉ An biết khóa bí mật {d, n} và mọi người có thể biết khóa công khai {e, n}. Nếu người gửi gửi một thông điệp \(m\) cần được giữ bí mật cho An, hãy chọn khóa công khai của An {e, n} và sau đó tính \(c = m^e \ mod \ n\) rồi gửi đến cho An.
Quá trình giải mã
Sau khi nhận được \(c\), An sẽ tính toán theo khóa riêng mà cô ấy có bằng cách tính \(m = c^d \ mod \ n\) Kết quả là thông điệp sẽ được gửi bởi người gửi.
Tham khảo thêm
RSA Số nguyên tố Hàm Euler Định lý số dư Trung Hoa Đồng dư thức
Lời kết
Sau những gì mà tôi đã chia sẻ ở trên mong rằng sẽ giúp ích được phần nào đó cho bạn đọc. Mọi thắc mắc hoặc góp ý bạn đọc có thể liên hệ tại đây. |