DANH MỤC CÁC KÝ HIỆU, CÁC CHỮ VIẾT TẮT .vi
DANH MỤC CÁC HÌNH VẼ .ix
DANH MỤC CÁC BẢNG . x
MỞ ĐẦU. 1
Chương I: TỔNG QUAN VỀ VẤN ĐỀ NGHIÊN CỨU . 8
1.1. Tổng quan về bài toán trao đổi khóa. 8
1.1.1. Khái niệm giao thức trao đổi khóa. 11
1.1.2. Các tính chất an toàn của giao thức trao đổi khóa . 12
1.1.3. Giao thức trao đổi khóa an toàn . 17
1.1.4. Bài toán trao đổi khóa nhóm . 20
1.2. Tổng quan về lược đồ chữ ký số. 23
1.2.1. Cơ sở toán học. 24
1.2.2. Lược đồ chữ ký số. 27
1.3. Kết luận chương 1 . 38
Chương II: PHÁT TRIỂN GIAO THỨC TRAO ĐỔI KHÓA CÓ XÁC
THỰC DỰA TRÊN HAI BÀI TOÁN KHÓ . 40
2.1. Phát triển lược đồ chữ ký số dựa trên hai bài toán khó. 40
2.1.1. Lược đồ thứ nhất (Rabin và Schnorr) . 48
2.1.2. Lược đồ thứ hai (RSA và Schnorr) . 49
2.1.3. Đánh giá khả năng bảo mật . 50iv
2.2. Phát triển giao thức trao đổi khóa có xác thực dựa trên hai
bài toán khó. 52
2.2.1. Một số phát triển giao thức trao đổi khóa an toàn. 53
2.2.2. Mô tả giao thức DH–MM–KE . 60
2.2.3. Đánh giá giao thức . 65
2.3. Kết luận chương 2 . 68
Chương III: PHÁT TRIỂN GIAO THỨC KÝ VÀ MÃ HÓA ĐỒNG THỜI
DỰA TRÊN HAI BÀI TOÁN KHÓ. 69
3.1. Giao thức ký và mã hóa đồng thời . 69
3.1.1. Phương pháp ký rồi mã hóa. 70
3.1.2. Phương pháp ký và mã hóa đồng thời. 71
3.1.3. Một số nghiên cứu về ký và mã hóa đồng thời . 73
3.2. Phát triển giao thức ký và mã hóa đồng thời DH–MM–SC. 75
3.2.1. Mô tả giao thức. 75
3.2.2. Đánh giá giao thức . 76
3.3. Phát triển giao thức ký và mã hóa đồng thời có thể chối từ
DH–MM–DSC. 79
3.3.1. Mô tả giao thức. 82
3.3.2. Đánh giá giao thức . 84
3.4. Kết luận chương 3 . 87
Chương IV: PHÁT TRIỂN GIAO THỨC TRAO ĐỔI KHÓA NHÓM. 88
4.1. Đặt vấn đề. 88
4.1.1. Giao thức IKA.1 . 90v
4.1.2. Giao thức IKA.2 . 91
4.2. Đề xuất giao thức trao đổi khóa nhóm. 93
4.3. Đánh giá giao thức . 94
4.3.1. Không để lộ khóa cặp. 94
4.3.2. Dễ dàng hoán vị để hình thành khóa mới. 95
4.3.3. Đánh giá độ phức tạp. 96
4.4. Kết luận chương 4 . 97
KẾT LUẬN. 98
DANH MỤC CÁC CÔNG TRÌNH KHOA HỌC ĐÃ CÔNG BỐ . 100
TÀI LIỆU THAM KHẢO. 101
147 trang |
Chia sẻ: trungkhoi17 | Lượt xem: 421 | Lượt tải: 0
Bạn đang xem trước 20 trang tài liệu Luận án Nghiên cứu phát triển giao thức trao đổi khóa an toàn, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
i gian của phép tính nghịch đảo modulo.
+ 𝑇𝐶𝑅𝑇 là độ phức tạp thời gian của phép tính đồng dư Trung Hoa.
Bảng 2.1 so sánh độ phức tạp tính toán của hai lược đồ mới đề xuất và
hai lược đồ của Ismail [26] [27].
Bảng 2.1. So sánh độ phức tạp thời gian
Độ phức tạp
thời gian (lược
đồ thứ nhất)
Độ phức tạp
thời gian (lược
đồ thứ hai)
Độ phức tạp
thời gian [26]
Độ phức tạp
thời gian [27]
Sinh
khóa
𝑻𝑬𝑿𝑷 𝑻𝑬𝑿𝑷 + 𝑻𝑰𝑵𝑽 𝑻𝑬𝑿𝑷 + 𝑻𝑰𝑵𝑽 𝑻𝑬𝑿𝑷 + 𝑻𝑰𝑵𝑽
Sinh
chữ ký
𝑻𝑬𝑿𝑷 + 𝑻𝑴𝑼𝑳
+𝑻𝑪𝑹𝑻 + 𝑻𝑯
𝟐𝑻𝑬𝑿𝑷 + 𝑻𝑴𝑼𝑳
+𝑻𝑯
5𝑇𝐸𝑋𝑃
+3𝑇𝑀𝑈𝐿 + 𝑇𝐻
𝑇𝐸𝑋𝑃 + 3𝑇𝑀𝑈𝐿
+𝑇𝐻
Xác
thực
chữ ký
𝟑𝑻𝑬𝑿𝑷 + 𝑻𝑴𝑼𝑳
+𝑻𝑯
𝟑𝑻𝑬𝑿𝑷 + 𝑻𝑴𝑼𝑳
+𝑻𝑯
𝟓𝑻𝑬𝑿𝑷
+𝟐𝑻𝑴𝑼𝑳
+ 𝑻𝑯
𝟒𝑻𝑬𝑿𝑷
+𝟐𝑻𝑴𝑼𝑳 + 𝑻𝑯
2.2. Phát triển giao thức trao đổi khóa có xác thực dựa trên hai
bài toán khó
Như đã trình bày, giao thức trao đổi khóa công khai Diffie–Hellman
(DHKE) không đảm bảo xác thực giữa hai bên tham gia giao thức [64]. Từ thực
tế này, đã xuất hiện hướng nghiên cứu mới nhằm phát triển các giao thức trao
đổi khóa dựa trên sự tích hợp giao thức DHKE và lược đồ chữ ký số. Giao thức
được đề xuất theo hướng này kết hợp được các ưu điểm của DHKE và lược đồ
chữ ký số khi triển khai ứng dụng trong thực tiễn.
Định nghĩa 2: Một giao thức trao đổi khóa được gọi là an toàn dựa trên
hai bài toán khó HP1 và HP2 nếu việc tìm được khóa thỏa thuận theo giao thức
và việc giả mạo để thực hiện này với người trong hệ thống đều cần phải giải
đồng thời hai bài toán nói trên.
53
2.2.1. Một số phát triển giao thức trao đổi khóa an toàn
Giao thức trao đổi khóa của Arazi:
Năm 1993, Arazi là người đầu tiên phát triển giao thức trao đổi khóa theo
hướng tích hợp giao thức DHKE với lược đồ chữ ký số DSA [7]. Giao thức này
dùng các khóa công khai chỉ sử dụng một lần (one–time), còn gọi là khóa công khai
ngắn hạn (ephemeral) cho giao thức DHKE. Ngoài ra, các khóa công khai ngắn hạn
được ký bằng cách sử dụng lược đồ chữ ký số DSA để xác thực các khóa này.
Mô tả giao thức:
Các tham số công khai (𝑝, 𝑞, 𝑔) được xác định như cách thiết lập tham
số hệ thống của lược đồ chữ ký số DSA [2]. Cặp khóa bí mật/công khai của A
là (𝑥𝐴, 𝑦𝐴) và cặp khóa tương ứng của B là (𝑥𝐵, 𝑦𝐵) (Hình 2.1).
Hình 2.1. Giao thức trao đổi khóa Arazi
54
Để tiết kiệm băng thông, giao thức Arazi có thể được thay đổi bằng cách
A và B trao đổi (𝑟𝐴, 𝑠𝐴) và (𝑟𝐵, 𝑠𝐵) thay vì trao đổi (𝑅𝐴, 𝑠𝐴) và (𝑅𝐵, 𝑠𝐵).
Đánh giá giao thức:
Năm 1994, Nyberg và Rueppel chỉ ra rằng giao thức của Arazi không có
thuộc tính về sự an toàn dựa trên khóa đã biết [30]. Các khóa bí mật ngắn hạn
được chia sẻ có thể được tính từ khóa bí mật dài hạn và các thông tin
không bí mật khác.
Một số sửa đổi của L. Harn trên giao thức trao đổi khóa Arazi:
Năm 1995, L. Harn và các cộng sự đề xuất sửa đổi giao thức trao đổi
khóa của Arazi [33]. Thay vì phân phối một khóa công khai đơn lẻ trong mỗi
phiên giao tiếp, nhóm L. Harn đề xuất phân phối nhiều khóa công khai trong
mỗi phiên [34].
Mô tả giao thức:
Các thông tin công khai sẽ được thỏa thuận bởi các bên tham gia giao
thức như sau:
- 𝑝 là một số nguyên tố lớn thỏa mãn 2511 < 𝑝 < 2512
- 𝑞 là một ước số nguyên tố của 𝑝 − 1 thỏa mãn 2159 < 𝑝 < 2160
- Chọn 𝑔 = 𝛼(𝑝−1)/𝑞 𝑚𝑜𝑑 𝑝, với 𝑔 ∈ 𝑍𝑝
∗ thỏa mãn: 1 < 𝑔 < 𝑝 và
𝑔𝑞 𝑚𝑜𝑑 𝑝 = 1, ở đây 𝛼 ∈ 𝑍𝑝
∗ .
- 𝑥𝑖 là khóa bí mật của người dùng 𝑖, thỏa mãn 2
159 < 𝑥𝑖 < 2
160
- 𝑦𝑖 là khóa công khai tương ứng của người dùng 𝑖, 𝑦𝑖 = 𝑔
𝑥𝑖 𝑚𝑜𝑑 𝑝
- 𝐻 là một hàm băm an toàn (SHA–1) đưa ra bởi NIST.
Trong đó (𝑝, 𝑞, 𝑔, 𝑦𝑖) là các giá trị công khai và 𝑥𝑖 là khóa bí mật.
Harn giả sử rằng A muốn chia sẻ ba khóa phiên bí mật với B. Giao thức
của Harn hoạt động như mô tả trong Hình 2.2.
55
Hình 2.2. Giao thức trao đổi khóa L. Harn
Đánh giá độ an toàn của giao thức:
Harn đánh giá độ an toàn của giao thức trên theo cách thức tấn công dựa
trên khóa đã biết (known–key attack) mà Nyberg và Rueppel đã đưa ra.
Chúng ta đã biết, kết thúc giao thức trên thu được ba khóa bí mật được
chia sẻ giữa A và B như sau:
+ 𝐾𝐴𝐵1 = 𝑚𝐵1
𝑣1 𝑚𝑜𝑑 𝑝
+ 𝐾𝐴𝐵2 = 𝑚𝐵2
𝑣2 𝑚𝑜𝑑 𝑝
+ 𝐾𝐴𝐵3 = 𝑚𝐵1
𝑣2 𝑚𝑜𝑑 𝑝
Trong đó:
𝑣1 + 𝑣2 = 𝑠𝐴
−1[𝐻(𝑚𝐴1||𝑚𝐴2)] + 𝑥𝐴𝑟𝐴 𝑚𝑜𝑑 𝑞 (2.1)
𝑤1 + 𝑤2 = 𝑠𝐵
−1[𝐻(𝑚𝐵1|| 𝑚𝐵2)] + 𝑥𝐵𝑟𝐵 𝑚𝑜𝑑 𝑞 (2.2)
56
Nhân hai vế của hai phương trình (2.1) và (2.2) ta có phương trình sau:
𝑣1𝑤1 + 𝑣1𝑤2 + 𝑣2𝑤1 + 𝑣2𝑤2 = 𝑠𝐴
−1𝑠𝐵
−1[𝐻(𝑚𝐴1, 𝑚𝐴2)
𝐻(𝑚𝐵1, 𝑚𝐵2) + 𝐻(𝑚𝐴1, 𝑚𝐴2)𝑥𝐵𝑟𝐵 + 𝐻(𝑚𝐵1, 𝑚𝐵2)𝑥𝐴𝑟𝐴
+𝑥𝐴𝑟𝐴𝑥𝐵𝑟𝐵] 𝑚𝑜𝑑 𝑞
(2.3)
Nhân hai vế của phương trình (2.3) với 𝑠𝐴𝑠𝐵, sau đó nâng lũy thừa với
hệ số 𝑔, số mũ là hai vế của phương trình thu được, ta được phương trình sau:
(𝐾𝐴𝐵1𝐾𝐴𝐵2𝐾𝐴𝐵3𝑔
𝑣1𝑤2)𝑠𝐴𝑠𝐵 = 𝑔𝐻(𝑚𝐴1,𝑚𝐴2)𝐻(𝑚𝐵1,𝑚𝐵2)
𝑦𝐵
𝐻(𝑚𝐴1,𝑚𝐴2)𝑟𝐵𝑦𝐴
𝐻(𝑚𝐵1,𝑚𝐵2)𝑟𝐴(𝑔𝑥𝐴𝑥𝐵)𝑟𝐴𝑟𝐵 𝑚𝑜𝑑 𝑝
(2.4)
Xem xét dưới góc độ tấn công dựa trên khóa đã biết, do 𝑔𝑣1𝑤2 không bao
giờ được dùng làm khóa phiên bí mật, tất cả các tham số trong (2.4) đều được
biết công khai hoặc được gửi giữa các bên tham gia giao thức ngoại trừ 𝑔𝑣1𝑤2
và 𝑔𝑥𝐴𝑥𝐵 nên dù đối phương có biết được các khóa 𝐾𝐴𝐵1, 𝐾𝐴𝐵2, 𝐾𝐴𝐵3 trong một
phiên truyền thông thì cũng không thể tính được các khóa này trong các phiên
khác. Vì vậy, phương pháp tấn công dựa trên khóa đã biết không thể thực hiện
thành công trong giao thức của L. Harn.
Giao thức này cho phép trao đổi 𝑛 cặp khóa công khai giữa hai bên tham
gia giao thức và xác lập được (𝑛2 − 1) khóa phiên bí mật. Ngoài ra, nó cung
cấp thêm tính chất an toàn là chống lại tấn công dựa trên khóa đã biết.
Giao thức trao đổi khóa Phan:
Năm 2005, Phan đã chỉ ra rằng giao thức của Harn không thể cung cấp
hai tính chất về chuẩn bảo mật mà các giao thức cần có đó là an toàn phía trước
(forward secrecy) và làm mới khóa (key freshness) [52].
Không có tính chất an toàn về phía trước: Trong giao thức của Harn,
khóa phiên theo hướng từ A tới B được tính bởi A như sau:
𝐾𝐴𝐵 = 𝑦𝐵
𝑣 𝑚𝑜𝑑 𝑝 (= 𝑔𝑥𝐵𝑣 𝑚𝑜𝑑 𝑝) (2.5)
Trong khi đó nó được tính bởi B như sau:
57
𝐾𝐵𝐴 = 𝑚𝐴
𝑥𝐵 𝑚𝑜𝑑 𝑝 (= 𝑔𝑥𝐵𝑣 𝑚𝑜𝑑 𝑝) (2.6)
Vì vậy, khi khóa riêng dài hạn 𝑥𝐵 của B bị lộ thì người tấn công có thể
dễ dàng tính được bất kỳ khóa phiên 𝐾𝐴𝐵 nào đã được thành lập trước đó bởi
phương trình (2.5). Điều tương tự cũng sẽ xảy ra với 𝐾𝐵𝐴 khi 𝑥𝐴 bị lộ.
Không có tính chất làm mới khóa: Trong các giao thức của Harn, A tính
𝐾𝐴𝐵 thông qua (2.6), cho thấy 𝐾𝐴𝐵 phụ thuộc vào khóa công khai 𝑦𝐵 (A luôn
biết khóa này) của B và một giá trị bí mật ngẫu nhiên 𝑣 (được lựa chọn bởi A).
Vì vậy, A có thể quyết định rằng 𝐾𝐴𝐵 phải bằng một giá trị đã được định trước.
B cũng có thể làm điều tương tự với 𝐾𝐵𝐴 như A.
Phan đưa ra cải tiến của mình trên giao thức của Harn để giao thức có
thể cung cấp hai tính chất nói trên (an toàn phía trước và làm mới khóa).
Mô tả giao thức:
Giao thức của Phan được mô tả trong Hình 2.3.
Hình 2.3. Giao thức trao đổi khóa Phan
58
Đánh giá giao thức:
Thứ nhất, dễ dàng nhận thấy giao thức của Phan đảm bảo giữ nguyên các
ưu điểm của giao thức của Harn do các khóa phiên đều được xác nhận vì có
trong phương trình ký.
Thứ hai, trong giao thức trao đổi khóa của Phan ta có khóa phiên theo
hướng từ A tới B được tính bởi A như sau:
𝐾𝐴𝐵 = (𝑚𝐴)
𝑥𝐵𝑤 𝑚𝑜𝑑 𝑝 (= 𝑔𝑥𝐵𝑣𝑤 𝑚𝑜𝑑 𝑝)(= 𝑦𝐵
𝑣𝑤 𝑚𝑜𝑑 𝑝) (2.7)
Trong khi đó nó được tính bởi B như sau:
𝐾𝐴𝐵 = (𝑛𝐵)
𝑣 𝑚𝑜𝑑 𝑝 (= 𝑔𝑥𝐵𝑣𝑤 𝑚𝑜𝑑 𝑝) (2.8)
Căn cứ vào (2.7) và (2.8) ta nhận thấy dù 𝐾𝐴𝐵 có được tính theo cách nào
đi chăng nữa thì nếu khóa riêng dài hạn 𝑥𝐵 của B bị lộ, người tấn công cũng
không thể tính được khóa phiên 𝐾𝐴𝐵 vì 𝐾𝐴𝐵 còn phụ thuộc vào các khóa bí mật
ngắn hạn của A và B. Tương tự với 𝐾𝐵𝐴 khi 𝑥𝐴 bị lộ. Do đó, giao thức trao đổi
khóa của Phan cung cấp tính chất an toàn phía trước.
Thứ ba, trong giao thức này A tính 𝐾𝐴𝐵 thông qua (2.7) cho thấy 𝐾𝐴𝐵
không những phụ thuộc vào khóa công khai 𝑦𝐵 (A luôn biết khóa này) của B
và một giá trị bí mật ngẫu nhiên 𝑣 (được lựa chọn bởi A) mà còn phụ thuộc vào
giá trị bí mật ngẫu nhiên 𝑤 (được lựa chọn bởi B). Vì vậy, A không thể định
trước được 𝐾𝐴𝐵. Tương tự B cũng không thể định trước được 𝐾𝐵𝐴. Tóm lại cả
A và B đều không thể định trước được các khóa phiên được đàm phán giữa hai
bên. Do đó, giao thức trao đổi khóa Phan cung cấp tính chất làm mới khóa.
Tuy nhiên, trong giao thức trao đổi khóa Phan ta có:
𝐾𝐵𝐴 = 𝑔
𝑥𝐴𝑣𝑤 𝑚𝑜𝑑 𝑝 (2.9)
Suy ra:
𝐾𝐴𝐵
𝑥𝐴 = 𝐾𝐵𝐴
𝑥𝐵 𝑚𝑜𝑑 𝑝 (2.10)
Rõ ràng có một mối quan hệ hiện (explicit relation) giữa hai khóa phiên
được đàm phán giữa hai bên, 𝐾𝐴𝐵 và 𝐾𝐵𝐴. Mối quan hệ này có thể gây ra một
59
số lỗ hổng trong tương lai. Ví dụ, khi các khóa riêng dài hạn 𝑥𝐴 và 𝑥𝐵 bị tổn
thương đồng thời, người tấn công có thể tính toán 𝐾𝐴𝐵 từ 𝐾𝐵𝐴 và ngược lại.
Mặc dù không có cuộc tấn công nào tồn tại trên giao thức ngay bây giờ nhưng
các giao thức sẽ an toàn hơn nếu không có mối quan hệ rõ ràng giữa hai khóa
phiên được thỏa thuận.
Giao thức trao đổi khóa Jie Liu và Jianhua Li:
Năm 2010, hai tác giả Jie Liu và Jianhua Li [38] đã đề xuất một cải tiến
tốt hơn, an toàn hơn bằng cách khắc phục nhược điểm mối quan hệ hiện trong
giao thức trao đổi khóa Phan [52].
Mô tả giao thức:
Giao thức của Jie Liu và Jianhua Li hoạt động như Hình 2.4.
Hình 2.4. Giao thức trao đổi khóa của Jie Liu và Jianhua Li
Đánh giá giao thức:
Cải thiện của giao thức này đó là có thêm hai số nguyên ngẫu nhiên tạm
thời so với giao thức trao đổi khóa của Phan (trong giao thức của Phan thì mỗi
60
bên tham gia giao thức chọn một số nguyên ngẫu nhiên còn trong giao thức Liu
& Li mỗi bên chọn hai số nguyên ngẫu nhiên). Giao thức này vẫn cung cấp
được tính an toàn của giao thức của Phan. Cụ thể đó là nó có thể cung cấp cả
hai tính chất chất an toàn phía trước và làm mới khóa.
Các khóa phiên trong giao thức cải tiến này được kết hợp bởi các số
nguyên ngẫu nhiên khác nhau như được chỉ ra trong (2.11) và (2.12) cho nên
không có bất kỳ mối quan hệ hiện nào giữa 𝐾𝐴𝐵 và 𝐾𝐵𝐴. Do đó, giao thức cải
tiến này khắc phục được nhược điểm mối quan hệ hiện giữa hai khóa phiên
được thỏa thuận giữa hai bên. Chính vì lẽ đó nó an toàn hơn so với giao thức
trao đổi khóa Phan.
Độ phức tạp tính toán của giao thức này tương đương với giao thức trao
đổi khóa của Phan. Việc thêm hai số nguyên ngẫu nhiên tạm thời làm cho độ
phức tạp của giao thức tăng lên nhưng nó làm cho giao thức an toàn hơn.
Tuy nhiên, qua (2.11) và (2.12), ta thấy giao thức của Jie Liu và Jianhua
Li không cung cấp tính chất an toàn: chống lại tấn công lộ khóa phiên.
Như vậy, bắt đầu từ Arazi là người đầu tiên đề xuất kết hợp chữ ký số
nhằm cung cấp khả năng xác thực cho giao thức trao đổi khóa, đã có nhiều đề
xuất, cải tiến nhằm nâng cao tính bảo mật của các giao thức trao đổi khóa an
toàn. Tuy nhiên, có thể thấy, các giao thức này đều chỉ dựa trên một bài toán
khó. Vì vậy, Luận án này sẽ phát triển giao thức trao đổi khóa an toàn dựa trên
hai bài toán khó nhằm khắc phục những điểm yếu đã phân tích ở trên.
2.2.2. Mô tả giao thức DH–MM–KE
Các tham số miền (𝑝𝐴, 𝑝𝐵 , 𝑛𝐴, 𝑛𝐵) được định nghĩa như lược đồ chữ ký
số thứ hai trong phần 2.1.
𝐾𝐴𝐵 = 𝑔
𝑥𝐵𝑣1𝑤1 𝑚𝑜𝑑 𝑝 (= 𝑦𝐵
𝑣1𝑤1 𝑚𝑜𝑑 𝑝) (2.11)
𝐾𝐵𝐴 = 𝑔
𝑥𝐴𝑣2𝑤2 𝑚𝑜𝑑 𝑝 (= 𝑦𝐴
𝑣2𝑤2 𝑚𝑜𝑑 𝑝) (2.12)
61
Với người gửi A: 𝑝𝐴 = 2𝑛𝐴 + 1, trong đó 𝑛𝐴 = 𝑞𝐴
′ 𝑞𝐴, 𝑞𝐴
′ và 𝑞𝐴 là các số
nguyên tố lớn với kích thước ít nhất là 1024 bit. Các tham số khóa của người
A, khóa công khai (𝑒𝐴, 𝑦𝐴) và khóa bí mật (𝑥𝐴, 𝑑𝐴).
Với người nhận B: 𝑝𝐵 = 2𝑛𝐵 + 1, trong đó 𝑛𝐵 = 𝑞𝐵
′ 𝑞𝐵, 𝑞𝐵
′ và 𝑞𝐵 là các
số nguyên tố lớn với kích thước ít nhất là 1024 bit. Các tham số khóa của người
B, khóa công khai (𝑒𝐵, 𝑦𝐵) và khóa bí mật (𝑥𝐵, 𝑑𝐵).
Thủ tục chọn tham số cho từng bên được thực hiện theo Thủ tục 2.1:
Thủ tục 2.1. Chọn tham số
Input: độ dài bit (length) của tham số
Output: các tham số q, q1, n, p, x, y, e, d, g
Function GenerateParameter()
q := RandomPrime(length);//sinh số nguyên tố ngẫu nhiên
có độ dài bit là length
q1 := RandomPrime(length);//sinh số nguyên tố ngẫu nhiên
có độ dài bit là length
n := q * q1;
p := n * 2 + 1;
//tìm p
while true do
if p is prime then
break
else
q := RandomPrime();
q1 := RandomPrime();
n := q * q1;
p := n * 2 + 1;
end if
end while
//tìm g
while true do
62
tmp := RandomInteger();
g := (tmp pow ((p - 1) / q)) mod p;
if g > 1 then
break
else
tmp := RandomInteger();
end if
end while
phiN := (q - 1) * (q1 - 1);
x := RandomInteger(1, p – 1);//sinh số tự nhiên ngẫu nhiên
trong khoảng [1, p-1]
e := RandomInteger(1, n - 1);
y := (g pow x) mod p;
//tìm e
while gcd(e, phiN) != 1 do
e := RandomInteger(1, n - 1);
end while
d := e multiple_inverse_mod phiN;
return (q, q1, n, p, x, y, e, d, g);
end function
Tính toán giá trị 𝑔 như là một phần tử sinh trong 𝑍𝑝𝐴
∗ và 𝑍𝑝𝐵
∗ . Với một
xác suất cụ thể (xấp xỉ 1/4), giá trị ngẫu nhiên cho 𝑔 là một phần tử sinh trong
𝑍𝑝𝐴
∗ và 𝑍𝑝𝐵
∗ . Chính vì thế có thể thử nhiều giá trị của 𝑔 để xem nó có phải là
phần tử sinh trong cả hai nhóm trên không.
Ký hiệu {𝑝𝐴} = {0, 1, , 𝑝𝐴 − 1} và {𝑝𝐵} = {0, 1, , 𝑝𝐵 − 1}.
Tìm tập 𝑝 = 𝑝𝐴 ∩ 𝑝𝐵. Từ đó, giá trị 𝑔 cũng là phần tử sinh của 𝑍𝑝
∗ .
Chọn 𝑛 chung: nếu 𝑛𝐴 < 𝑛𝐵, 𝑛 = 𝑛𝐴, nếu không, 𝑛 = 𝑛𝐵.
Tham số chung 𝑝 được tính theo Thủ tục 2.2:
63
Thủ tục 2.2. Chọn tham số chung
Input: p_A và p_B của hai bên A và B
Output: tham số p chung
Function FindCommonParameter ()
p := RandomPrime();
if p_A < p_B then
p := p_A;
else
p := p_B;
end if
return p;
end function
Giả định rằng A muốn chia sẻ khóa phiên bí mật với B. Vậy thì:
1) A thực hiện như sau:
- Lựa chọn 𝑘𝐴 ∈𝑅 [1, 𝑛 − 1].
- Tính 𝑅𝐴1 = 𝑔
𝑘𝐴 𝑚𝑜𝑑 𝑝 và 𝑅𝐴2 = 𝑔
𝑥𝐴 𝑚𝑜𝑑 𝑝
- Gửi cặp (𝑅𝐴1, 𝑅𝐴2) cho B.
2) B thực hiện như sau:
- Chọn 𝑍 ∈𝑅 [1, 𝑛 − 1].
- Tính 𝑤 = 𝑍𝑒𝐴 𝑚𝑜𝑑 𝑛
- Chọn 𝑘𝐵 ∈𝑅 [1, 𝑛 − 1].
- Tính 𝑇𝐵 = (𝑅𝐴2
𝑥𝐵𝑅𝐴1
𝑘𝐵) 𝑚𝑜𝑑 𝑝 = 𝑔𝑥𝐴𝑥𝐵+𝑘𝐴𝑘𝐵 𝑚𝑜𝑑 𝑝.
- Tính toán khóa bí mật được chia sẻ 𝐾𝐵𝐴 = 𝐻(𝑍||𝑇𝐵)
- Tính 𝑅𝐵1 = 𝑔
𝑘𝐵 𝑚𝑜𝑑 𝑝 và 𝑅𝐵2 = 𝑔
𝑥𝐵 𝑚𝑜𝑑 𝑝
- Tính 𝐸𝐵 = 𝐻(𝑍||𝐾𝐵𝐴||𝑅𝐴1||𝑅𝐵1||𝑅𝐴2||𝑅𝐵2) và
𝑆𝐵 = (𝑘𝐵 − 𝑥𝐵𝐸𝐵)
𝑑𝐵 𝑚𝑜𝑑 𝑛
- Gửi lại các giá trị (𝑤, 𝑅𝐵1 , 𝑅𝐵2 , 𝐸𝐵, 𝑆𝐵) cho người A.
64
3) A sau đó tiếp tục thực hiện như sau:
- Tính 𝑍 = 𝑤𝑑𝐴 𝑚𝑜𝑑 𝑛
- Tính 𝑇𝐴 = (𝑅𝐵2
𝑥𝐴𝑅𝐵1
𝑘𝐴) 𝑚𝑜𝑑 𝑝 = 𝑔𝑥𝐵𝑥𝐴+𝑘𝐵𝑘𝐴 𝑚𝑜𝑑 𝑝
- Tính khóa bí mật chia sẻ 𝐾𝐴𝐵 = 𝐻(𝑍||𝑇𝐴)
- Xác thực (𝐸𝐵, 𝑆𝐵)
- Tính 𝐸𝐴 = 𝐻(𝑍||𝐾𝐴𝐵||𝑅𝐴1||𝑅𝐵1||𝑅𝐴2||𝑅𝐵2)
- Tính 𝑆𝐴 = (𝑘𝐴 − 𝑥𝐴𝐸𝐴)
𝑑𝐴 𝑚𝑜𝑑 𝑛
- Gửi (𝐸𝐴, 𝑆𝐴) cho B.
4) B thực hiện:
- Xác thực (𝐸𝐴, 𝑆𝐴).
Giao thức DH-MM-KE được mô tả hoạt động trên Hình 2.5.
Hình 2.5. Giao thức DH–MM–KE
65
Tính đúng đắn của giao thức:
Ta có: 𝑇𝐴 = (𝑅𝐵2
𝑥𝐴𝑅𝐵1
𝑘𝐴) 𝑚𝑜𝑑 𝑝 = 𝑔𝑥𝐵𝑥𝐴+𝑘𝐵𝑘𝐴 𝑚𝑜𝑑 𝑝 = 𝑇𝐵
=> 𝐾𝐴𝐵 = 𝐻(𝑍||𝑇𝐴) = 𝐻(𝑍||𝑇𝐵) = 𝐾𝐵𝐴
2.2.3. Đánh giá giao thức
2.2.3.1. Độ an toàn của giao thức
Tính chất 2.1: Giao thức DH–MM–KE đảm bảo tính chất an toàn đầy
đủ về phía trước (Perfect Forward Secrecy).
Chứng minh: Ta cần chứng minh nếu khóa bí mật dài hạn của A và B bị
lộ thì các khóa phiên 𝐾𝐴𝐵 và 𝐾𝐵𝐴 được tạo ra trước đó vẫn không bị ảnh hưởng.
Khóa phiên theo hướng từ A tới B được A tính như sau:
𝐾𝐴𝐵 = 𝐻(𝑍||𝑇𝐴) = 𝐻(𝑍||𝑔
𝑥𝐵𝑥𝐴+𝑘𝐵𝑘𝐴 𝑚𝑜𝑑 𝑝) (2.13)
Còn B tính như sau:
𝐾𝐵𝐴 = 𝐻(𝑍||𝑇𝐵) = 𝐻(𝑍||𝑔
𝑥𝐴𝑥𝐵+𝑘𝐴𝑘𝐵 𝑚𝑜𝑑 𝑝) (2.14)
𝐾𝐴𝐵 và 𝐾𝐵𝐴 phụ thuộc vào giá trị ngẫu nhiên 𝑘𝐴 và 𝑘𝐵
Do đó, khi một khóa dài hạn (𝑥𝐴, 𝑑𝐴), (𝑥𝐵 , 𝑑𝐵) của A và B bị lộ, người
tấn công không thể tính bất kỳ khóa phiên đã sử dụng 𝐾𝐴𝐵 và 𝐾𝐵𝐴 bằng (2.13)
và (2.14). Do đó, giao thức này đảm bảo tính an toàn đầy đủ về phía trước.
Tính chất 2.2: Giao thức DH–MM–KE thỏa mãn tính chất khóa độc lập.
Chứng minh: Trong giao thức DH–MM–KE, A và B tính như sau:
𝐾𝐴𝐵 = 𝐻(𝑍||𝑔
𝑥𝐵𝑥𝐴+𝑘𝐵𝑘𝐴𝑚𝑜𝑑 𝑝) và 𝐾𝐵𝐴 = 𝐻(𝑍||𝑔
𝑥𝐴𝑥𝐵+𝑘𝐴𝑘𝐵𝑚𝑜𝑑 𝑝)
Các khóa phiên đều phụ thuộc vào khóa bí mật (𝑥𝐴, 𝑥𝐵) và số ngẫu nhiên
(𝑘𝐴, 𝑘𝐵). Điều này có nghĩa là các khóa phiên được tính độc lập.
Tính chất 2.3: Giao thức DH–MM–KE an toàn với tấn công SSR
(session-state reveal).
Chứng minh: Ta cần chứng minh nếu người tấn công thu được các trạng
thái trung gian trong quá trình thực hiện giao thức cũng không thể tính được
khóa bí mật chia sẻ.
66
Theo công thức (2.13) và (2.14), khóa phiên 𝐾𝐴𝐵 và 𝐾𝐵𝐴 phụ thuộc vào
khóa bí mật (𝑥𝐴, 𝑥𝐵) của A và B.
Do đó, khi các số ngẫu nhiên 𝑘𝐴 và 𝑘𝐵 hoặc các thành phần trung gian
khác bị lộ, người tấn công cũng không thể tính được khóa phiên vì không tính
được 𝑇𝐴 (𝑇𝐵).
Do đó, giao thức DH–MM–KE an toàn với tấn công SSR.
Tính chất 2.4: Giao thức DH–MM–KE an toàn trước tấn công giả mạo
khóa thỏa thuận (key compromise impersonation – KCI).
Chứng minh: Giao thức này sử dụng một quá trình xác thực chung giữa
A và B.
Do đó, quá trình xác thực sẽ thất bại nếu người tấn công hoạt động và
không đồng thời biết về 𝑘𝐴 và (𝑥𝐴, 𝑑𝐴) hoặc 𝑘𝐵 và (𝑥𝐵, 𝑑𝐵).
Do đó, cách duy nhất của người tấn công là tính trực tiếp khóa phiên, giả
sử người tấn công biết khóa bí mật dài hạn của A (𝑥𝐴, 𝑑𝐴) và khóa phiên tạm
thời của B (𝑘𝐵), vì khóa phiên là 𝐾𝐴𝐵 = 𝐻(𝑍||𝑔
𝑥𝐵𝑥𝐴+𝑘𝐵𝑘𝐴 𝑚𝑜𝑑 𝑝) và người
tấn công có thể tính 𝑍. Tuy nhiên, trong trường hợp này, người tấn công vẫn
không thể tính được 𝑔𝑥𝐵𝑥𝐴+𝑘𝐵𝑘𝐴.
Do đó, giao thức DH–MM–KE an toàn trước tấn công giả mạo khóa thỏa
thuận KCI.
Tính chất 2.5: Giao thức DH–MM–KE an toàn trước tấn công không
biết khóa chia sẻ (unknown key-share).
Chứng minh: Việc xác nhận khóa có thể ngăn chặn tấn công không biết
khóa chia sẻ.
B xác nhận với A rằng đã nhận được khóa chia sẻ bí mật 𝐾𝐵𝐴 bằng việc
kí khóa này cùng với (𝑍, 𝑅𝐴1, 𝑅𝐵1, 𝑅𝐴2, 𝑅𝐵2). Vì khóa bí mật chia sẻ 𝐾𝐵𝐴 là một
hàm băm một chiều của các số ngẫu nhiên (𝑅𝐴1, 𝑅𝐴2) của A, A tin rằng nội
dung tin nhắn không bị lặp và biết rằng nó thực sự là từ phía B.
67
B cũng làm những điều tương tự với 𝐾𝐴𝐵 giống như A.
Tính chất 2.6: Giao thức DH–MM–KE an toàn dựa trên hai bài toán khó.
Chứng minh: Ta cần chứng minh để phá giải giao thức DH–MM–KE,
người tấn công phải giải quyết đồng thời hai bài toán khó.
Trong giao thức DH–MM–KE, A và B tính khóa chia sẻ 𝐾𝐴𝐵 và 𝐾𝐵𝐴 theo
công thức (2.13) và (2.14).
Các giá trị này phụ thuộc vào (𝑍, 𝑇𝐴 hoặc 𝑇𝐵).
Để tính 𝑍, người tấn công phải tính được 𝑑, muốn tính được giá trị của
𝑑 thì lại cần tìm được (𝑛) mà muốn tìm được (𝑛) thì lại cần phải giải tiếp
bài toán phân tích 𝑛 thành thừa số nguyên tố.
Để tính 𝑇𝐴 (hoặc 𝑇𝐵) người tấn công phải tính được giá trị của (𝑥𝐴, 𝑘𝐴)
hoặc (𝑥𝐵, 𝑘𝐵).
Ta có: (𝑅𝐴1 = 𝑔
𝑘𝐴 𝑚𝑜𝑑 𝑝 và 𝑅𝐴2 = 𝑔
𝑥𝐴 𝑚𝑜𝑑 𝑝) và (𝑅𝐵1 = 𝑔
𝑘𝐵 𝑚𝑜𝑑 𝑝
và 𝑅𝐵2 = 𝑔
𝑥𝐵 𝑚𝑜𝑑 𝑝).
Do đó, để tính được (𝑥𝐴, 𝑘𝐴) hoặc (𝑥𝐵, 𝑘𝐵), người tấn công phải giải bài
toán logarithm rời rạc.
Như vậy, giao thức DH–MM–KE an toàn dựa trên hai bài toán khó.
2.2.3.2. Độ phức tạp của giao thức
Độ phức tạp thời gian của giao thức DH–MM–KE được trình bày trong
Bảng 2.2.
Bảng 2.2. Độ phức tạp thời gian của giao thức DH–MM–KE
Giai đoạn Độ phức tạp thời gian
1 2𝑇𝐸𝑋𝑃
2 6𝑇𝐸𝑋𝑃 + 2𝑇𝑀𝑈𝐿 + 𝑇𝐻
3 7𝑇𝐸𝑋𝑃 + 3𝑇𝑀𝑈𝐿 + 2𝑇𝐻
4 3𝑇𝐸𝑋𝑃 + 𝑇𝑀𝑈𝐿 + 𝑇𝐻
Tổng 18𝑇𝐸𝑋𝑃 + 6𝑇𝑀𝑈𝐿 + 4𝑇𝐻
68
2.3. Kết luận chương 2
Chương 2 nghiên cứu về các lược đồ chữ ký số dựa trên hai bài toán khó
trước đây. Các lược đồ này có một nhược điểm là chỉ cần giải một trong hai bài
toàn khó là có thể phá được toàn bộ lược đồ. Do đó, Luận án đã đề xuất hai
lược đồ chữ ký số mới nhằm khắc phục nhược điểm này. Các lược đồ được đề
xuất có hai ưu điểm nổi bật. Thứ nhất, chúng được phát triển từ một số lược đồ
chữ ký số mà tính bảo mật và hiệu quả đã được chứng minh, nên được thừa
hưởng những đặc tính từ các lược đồ này. Thứ hai, sự an toàn của các lược đồ
được đề xuất dựa trên hai bài toán khó. Vì vậy, nó vẫn là an toàn ngay cả khi
có một thuật toán hiệu quả để giải một trong hai bài toán khó. Do đó, các lược
đồ được đề xuất là phù hợp cho các ứng dụng đòi hỏi mức an ninh cao trong hệ
thống hạn chế về nguồn lực.
Tiếp theo, Luận án nghiên cứu, phân tích các giao thức trao đổi khóa an
toàn có tích hợp chữ ký số đã được công bố. Các giao thức này vẫn còn tồn tại
các nhược điểm về tính an toàn và chỉ dựa trên một bài toán khó. Do vậy, dựa
trên cơ sở lược đồ chữ ký số mới đề xuất, Luận án đã xây dựng giao thức trao
đổi khóa mới, tích hợp chữ ký số và dựa trên hai bài toán khó, nhằm khắc phục
những nhược điểm của các giao thức trước đây, đồng thời nâng cao tính bảo
mật của giao thức.
Kết quả nghiên cứu đạt được trong chương này là cơ sở để tiếp tục nghiên
cứu chuyên sâu hơn và tiến tới đề xuất xây dựng các giao thức ký và mã hóa
đồng thời, ký và mã hóa đồng thời có thể chối từ.
69
Chương III: PHÁT TRIỂN GIAO THỨC KÝ VÀ MÃ HÓA
ĐỒNG THỜI DỰA TRÊN HAI BÀI TOÁN KHÓ
Nội dung chính của chương này: Dựa trên cơ sở kết quả nghiên cứu của
chương 2, trong chương này Luận án đề xuất một giao thức ký và mã hóa đồng
thời (DH–MM–SC) và một giao thức ký và mã hóa đồng thời có thể chối từ
(DH–MM–DSC). Các giao thức này đều dựa trên việc tích hợp chữ ký số và
kết hợp hai bài toán khó. Tiếp theo, Luận án chứng minh tính đúng đắn, khả
năng bảo mật và tính hiệu quả của các giao thức mới đề xuất.
3.1. Giao thức ký và mã hóa đồng thời
Hiện nay, an toàn thông tin đã trở thành một khía cạnh quan trọng trong
tất cả các lĩnh vực truyền thông. Khi gửi một thông điệp tới cho một cá nhân
trên một kênh không an toàn (như Internet), ta cần phải đảm bảo tính bí mật,
toàn vẹn của thông điệp, có thể xác thực người gửi và người gửi không thể chối
bỏ thông điệp đã gửi. Trước đây, mật mã học chỉ đơn thuần bảo đảm tính bí
mật của thông điệp, ngăn chặn người khác đọc được khi không có những thông
tin bí mật. Trong thời hiện đại, mật mã học đã được mở rộng phạm vi, không
chỉ đảm bảo tính bí mật của truyền thông mà còn cung cấp khả năng kiểm tra
tính toàn vẹn của thông điệp, xác thực người gửi/người nhận,.... Hiện nay, mật
mã có hai dạng chính là hệ mật khóa bí mật và hệ mật khóa công khai. Với hệ
mật khóa bí mật, hai bên tham gia sẽ thỏa thuận một giá trị khóa chung và giữ
bí mật khóa này với bên ngoài. Truyền khóa trong môi trường không an toàn
trở thành vấn đề quan trọng trong việc đảm bảo tính an toàn của hệ mật. Trong
hệ mật khóa công khai, mỗi bên tham gia sẽ có một cặp khóa bí mật/khóa công
khai, khi mã hóa, người gửi sẽ dùng khóa công khai để mã hóa, người nhận sẽ
dùng khóa bí mật để giải mã. Với phương pháp này, ta không cần quan tâm đến
việc giữ bí mật khóa trên môi trường công cộng. Tuy nhiên, nhược điểm của
hệ mật khóa công khai là khối lượng tính toán lớn hơn nhiều so với hệ mật khóa
70
bí mật. Để xác thực thông điệp, người gửi cần phải ký lên đó trước khi gửi nó
tới người nhận. Để làm được việc này, người gửi có thể sử dụng các lược đồ
chữ ký số như RSA, Rabin, Schnorr, DSA,...
Tính bảo mật của thông điệp và khả năng xác thực là những vấn đề quan
trọng trong truyền thông trên Internet. Trước đây, mã hóa và chữ ký số là những
phương thức quan trọng nhưng riêng rẽ và không có liên kết [27], [66] trong
các hệ thống mã hóa. Trong hệ mã khóa công khai, phương pháp truyền thống
là ký lên thông điệp rồi mã hóa nó và gửi tới cho người nhận. Người nhận sẽ
giải mã thông điệp rồi xác thực nó. Đây là phương pháp ký rồi mã hóa
(signature-then-encryption). Nhược điểm lớn nhất của phương pháp này là việc
tạo chữ ký và mã hóa làm tăng độ phức tạp của giao thức và làm tăng kích
thước của thông điệp ban đầu. Từ đó, nhiều phương pháp được đưa ra để kết
hợp các bước này vào một phép tính duy nhất. Phương pháp này gọi là ký và
mã hóa đồng thời (signcryption). Một giao thức ký và mã hóa đồng thời cung
cấp tính bảo mật của cả mã hóa và chữ ký số: bảo mật, toàn vẹn, không thể
chỉnh sửa và chống chối từ.
3.1.1. Phương pháp ký rồi mã hóa
Để gửi một thông điệp bí mật đi và đảm bảo nó không bị chỉnh sửa, người
gửi sẽ thực hiện các bước sau:
- Ký lên thông điệp sử dụng lược đồ chữ ký số (RSA, DSA, Rabin,...).
- Mã hóa thông điệp và c
Các file đính kèm theo tài liệu này:
- luan_an_nghien_cuu_phat_trien_giao_thuc_trao_doi_khoa_an_toa.pdf