d/. Một cử tri đăng ký bỏ phiếu nhiều lần:
Giải quyết: Sử dụng “nhóm” thẩm định hồ sơ: Khóa giải mã hồ sơ đƣợc chia sẻ
thành nhiều mảnh và mỗi ngƣời trong ban thẩm định giữ một mảnh.
Cử tri
Id đã bị làm mù, Số CMT, Hộ khẩu,…
Ban ĐK
- Kiểm tra các giấy tờ của CT. Nếu hợp lệ thì ký trên Id đã làm mù do CT gửi về.
- Ghi lại Số CMT của CT để tránh việc CT đăng ký 2 lần. Xóa mù để thu đƣợc
Chữ kýtrên Id
e/. Ban bầu cử ký nhiều lá phiếu cho một cử tri:
Giải quyết:
+ Cách 1: Chia sẻ khóa ký mù đơn, mỗi ngƣời trong ban ĐK giữ 1 mảnh khóa.
+ Cách 2: Ký mù nhóm
+ Cách 3: Ký mù bội
Mỗi lá phiếu phải có thông tin định danh. Nó có thể là một con số x nào đó, và phải khác nhau. Trên mỗi lá phiếu phải có chữ ký trên số định danh x, thì lá phiếu mới có giá trị để bầu cử. Nếu cử tri chuyển ngay số định danh x cho ban KP ký, thì lập tức họ xác lập đƣợc mối liên hệ giữa cử chi và x (ví dụ qua địa chỉ nơi gửi trên Internet).
Đó là điều cử tri không muốn vì sợ rắc rối sau này.Để tránh tình huống trên, cử tri biến đổi x thành y trƣớc khi đƣa cho ban ĐK kí xác nhận.ban ĐK ký vào y, mà không biết đó là số định danh x đã bị che dấu (làm mù). Họ trao chữ ký trên y là z cho cử chi. Cử tri “xoá mù” trên z sẽ đƣợc chữ ký của ban ĐK trên số định danh x, nhƣ vậy cử chi có quyền bầu cử.
Để phòng tránh sự gian lận “thông đồng” giữa một ngƣời nào đó trong ban KP và cử tri, hệ thống dùng “đa chữ ký mù” để bảo đảm sự nhất trí cao khi cấp quyền bỏ phiếu cho cử tri.
3.3.2. Bài toán trong giai đoạn bỏ phiếu
Quy trình trong giai đoạn bỏ phiếu đƣợc chi tiết trong hình 3.3.
a/. Bảo mật nội dung lá phiếu: Phòng tránh lá phiếu bị xem trộm.
Giải quyết: Dùng phƣơng pháp mã hóa để mã hóa lá phiếu.
Giải quyết: Dùng phƣơng pháp mã hóa, chữ ký số, … Hình 3.3. Quy trình bỏ phiếu Chọn ý kiến cho lá phiếu của mình Cử tri
- Chữ ký của Ban đăng ký. - Lá phiếu đã mã hóa bằng khóa công khai của Ban KP.
- “Chứng minh không tiết lộ thông tin”. -
- Kiểm tra chữ ký (Liên hệ với Ban ĐK).
- Thực hiện các giao thức tƣơng tác với CT để kiểm tra tính hợp lệ của lá phiếu.
- Mã hóa lại lá phiếu, gửi về Ban KP. - Chứng minh không tiết lộ thông tin
XMTT Bankiểm phiếu
3.3.3. Bài toán trong Giai đoạn Kiểm phiếu
Quy trình giai đoạn Kiểm phiếu đƣợc chi tiết trong hình 3.4
a/. Thành viên Ban kiểm phiếu thông gian: Sửa đổi nội dung Lá phiếu.
Theo suy nghĩ thông thƣờng, khi cử tri chuyển lá phiếu tới ban KP thì họ chỉ cần mã hóa nội dung lá phiếu là đủ. Vì tiếp theo ban KP chỉ cần giải mã nội dung lá phiếu là tính đƣợc kết quả (kiểm phiếu).
Nhƣng trên thực tế có thể xảy ra các tình huống sau: ban KP hay một nhóm thành viên ban KP không trung thực đã gian lận phiếu thăm dò, ví dụ sửa lại nội dung lá phiếu sau khi giải mã (trƣớc khi kiểm phiếu). Để khắc phục tình hình này, ngƣời ta sử dụng kỹ thuật “mã hóa đồng cấu - chia sẻ bí mật”. Với giải pháp này ban KP không phải giải mã từng lá phiếu nhƣng vẫn tính đƣợc kết quả.
Giải quyết:
+ Cách 1: Dùng phƣơng pháp chia sẻ khóa giải mãlá phiếu, mỗi ngƣời kiểm
phiếu giữ 1 mảnh khóa.
+ Cách 2: Mã hóa lá phiếu nhiều lần với các khóa công khai của từng thành viên
ban KP. Sau đó Trộn thứ tự các lá phiếu sau mỗi lần giải mã.
+ Cách 3: Chiasẻ lá phiếu thành nhiều mảnh, mỗi ngƣời trong ban KP giữ một
mảnh.
Chia sẻ khóa giải mã và chia sẻ lá phiếu:
Chìa khoá để giải mã nội dung lá phiếu đƣợc chia thành m mảnh, mỗi ngƣời trong ban KP giữ 1 mảnh, và phải bảo đảm rằng 1 nhóm ngƣời ít hơn m không thể khôi phục đƣợc khoá giải mã.
Bản thân nội dung lá phiếu có thể đƣợc chia thành m mảnh.Cử tri gửi cho m thành viên của ban KP, mỗi ngƣời giữ 1 mảnh và phải bảo đảm rằng 1 nhóm ngƣời ít hơn m không thể xác định đƣợc nội dung lá phiếu.
Với kỹ thuật này, cuộc bỏ phiếu bảo đảm đƣợc bí mật và kiểm soát đƣợc kết quả bỏ phiếu: cụ thể là tránh gian lận phiếu.
Hiện nay có nhiều loại sơ đồ “chia sẻ bí mật” để thực hiện các công việc nhƣ trên, ví dụ: sơ đồ chia sẻ bí mật ngƣỡng Shamir, cấu trúc mạch đơn điệu, không gian Vector Brickell,…
b/. Phòng tránh cử tri bán lá phiếu cho ứng cử viên:
Giải quyết: Dùng ngƣời XMTT mã hóa lá phiếu lần thứ 2. Do đó cử tri không
Giải quyết: Kiểm tra định danh, kiểm tra chữ ký của ban ĐK
Hình 3.4. Quy trình kiểm phiếu
3.3.4. Bài toán trong kiểm tra phiếu của ngƣời XMTT a/. Kiểm tra tính hợp lệ lá phiếu của CT: a/. Kiểm tra tính hợp lệ lá phiếu của CT:
Giải quyết: Dùng phƣơng pháp “Chứng minh không tiết lộ thông tin”.
Chứng minh không tiết lộ thông tin
+ Khái niệm:Chứng minh không tiết lộ thông tin là phép chứng minh để một
ngƣời P thuyết phục một ngƣời V tin vào một điều gì đó có thật mà không để lộ thông tin.
Chứng minh không tiết lộ thông tin đƣợc Goldwasser, Micali và Rackoff năm 1981 (đƣợc viết tắt GRM) có ảnh hƣởng rất lớn trong lĩnh vực khoa học máy tính.
+ Giao thức :
Giao thức là giao thức “hỏi - đáp” 3 bƣớc, để P chứng minh cho V một vấn đề nào đó.
- Bƣớc 1: P gửi cho V: một giá trị ngẫu nhiên.
- Bƣớc 2: V gửi lại P: một giá trị ngẫu nhiên nhƣ là giá trị dùng để kiểm thử. - Bƣớc 3: P gửi đáp lại V: một giá trị.
Kết quả V thừa nhận hoặc bác bỏ vấn đề P chứng minh.
Hòm phiếu Mạng trộn Ban KP - Khôi phục khóa bí mật. - Tính kết quả bầu cử. - Công bố kết quả lên bảng niêm yết công khai
Phép chứng minh không tiết lộ thông tin đã đƣợc mô hình hóa bởi Quisquater và Guillou trong ví dụ về “hang động của Ali Baba”. Ví dụ này đƣợc minh họathông qua hình 3.5 và đƣợcgiải thích nhƣ sau:
Hình 3.5. Ví dụ minh họa chứng minh không tiết lộ thông tin
Từ bây giờ chúng ta sẽ coi Peggy là Prover (ngƣời chứng minh), còn Victor là Verifier (ngƣời kiểm thử). Peggy(P) muốn chứng minh với Victor(V) rằng cô ta biết câu thần chú có thể mở đƣợc cánh cửa bí mật tại các điểm R-S, nhƣng cô ta không muốn tiết lộ bí mật đó với Victor.
Quá trình đến nơi đó diễn ra nhƣ sau: Victor đi tới P và đợi đến khi Peggy đi khỏi R hoặc S. Sau đó Victor di chuyển đến Q và gọi Peggy ra ngoài từ bên trái hoặc bên phải của đƣờng hầm(kỹ thuật cut and choose). Nếu Peggy không biết câu thần chú, cô ta chỉ có 50% khả năng ra ngoài từ bên đúng. Giao thức có thể đƣợc lặp lại nhiều lần đến khi Victor tin rằng Peggy đã biết câu thần chú. Nếu giao thức đƣợc lặp lại k lần, xác suất lừa gạt của Peggy là 2k.Và nó không có nghĩa là giao thức đã đƣợc lặp bao nhiêu lần.Victor vẫn không biết đƣợc bí mật.
Ý nghĩa chính ẩn trong nguyên nhân là: Peggy muốn chứng minh một sự thật hiển nhiên F1 nhƣng cô ta không muốn tiết lộ sự chứng minh này. Vì thế cô ta đi tìm những sự thật F2 khác, mà có thể tiết lộ công khai, nhƣ là F2 là đúngnếu F1 đúng
(điều kiện cần thiết).Vì thế cô ta “thay thế” phép chứng minh của F1 chỉ bằng chứng minh F2. Trong ví dụ, F1 là câu thần chú bí mật,và F2 là khả năng xuất hiện từ mọi phía của đƣờng hầm. Nếu Victor đồng ý rằng F2 không thể đúng nếu F1 không đúng, sau đó giao thức có thể tiến hành.
Theo quy trình trong hình 3.3 giai đoạn CT chuyển lá phiếu tới Ban KP, phải thực hiện giao thức nhƣ trong bảng 3.1. Tức là CT sẽ mã hóa lá phiếu bằng hệ mã hóa Elgamal, lá phiếu đã mã hóa đƣợc gửi tới ngƣời XMTT kèm theo “Chứng minh không tiết lộ thông tin” cho tính hợp lệ của lá phiếu đó. Giả sử trong cuộc bầu cử “chọn 1 trong k”, nếu cử tri nào đó chọn Gi là ứng cử viên thứ i trong danh sách thì lá phiếu
thành (x, y) = (gα, hαGi). Nhƣ vậy CT muốn chứng minh với ngƣời XMTT rằng lá phiếu (x, y) là hợp lệ, thì anh ta phải chỉ ra một trong k đẳng thức sau là đúng: (logg x = logh (y/G1))… (logg x = logh (y/Gk)). Để chứng minh đẳng thức trên là đúng mà không bị lộ Gi, CT và ngƣời XMTT thống nhất dùng giao thức “Chứng minh không tiết lộ thông tin” nhƣ sau:
Bảng 3.1. Giao thức cử tri chứng minh lá phiếu hợp lệ
Cử tri Ngƣời XMTT
- Mã hóa lá phiếu [(x, y) = (gα, hαGi)] - Chọn ngẫu nhiên wZ p Tính ai = gw, bi = hw - Với j = 1,…, i - 1, i + 1,…, k Chọn ,dj, rj Zpf(chƣa chọn di, ri) Tính a j= 𝑔𝑟𝑖𝑥𝑑𝑖, b j= ℎ𝑟𝑖(𝑦 𝐺𝑗)𝑑𝑖 - Đặt (A,B)= (a1,b1),…,(ak,bk) (Sử dụng ai, bi đã tính ở trên) (x, y), (A,B) c Chọn ngẫu nhiên c Zp - Tinh: di= c- 𝑗 ≠𝑖𝑑𝑗 r i=w-𝛼𝑑𝑗 d, r = (d1, r1),…, (dk, rk) d, r -Kiểm tra: c=d1+d2+...dk Cho j = 1,…, k aj= 𝑔𝑟𝑖𝑥𝑑𝑖 và bj=ℎ𝑟𝑖(𝑦 𝐺𝑗)𝑑𝑖 Nếu đều đúng ngƣời XMTT kết luận: Lá phiếu hợp lệ
b/. Kiểm tra tính hợp lệ khóa mã hóa của ngƣời XMTT:
Giải quyết: Dùng phƣơng pháp “Chứng minh không tiết lộ thông tin”.
Theo quy trình trong hình 3.3 ngƣời XMTT sẽ thực hiện Giao thức 2. Tức là sau khi xác minh lá phiếu của CT là hợp lệ ngƣời XMTT làm “mù” hoặc mã hóa lá phiếu
tính hợp lệ của lá phiếu đã bị làm “mù”. Ngƣời XMTT làm “mù” hoặc mã hóa lá phiếu thông qua cặp (u, v) và dựa trên giá trị bí mật f. Để chứng minh lá phiếu bị làm “mù” hoặc đã đƣợc mã hóa vẫn hợp lệ, ngƣời XMTT phải chứng minh đƣợc là anh ta sở hữu giá trị bí mật thỏa mãn u=g, v=h. Nhƣng mặt khác ngƣời XMTT không muốn để lộ . Có một giao thức hiệu quả để ngƣời XMTT làm việc này: giao thức ∑. Trong sơ đồ sau đây, ngƣời XMTT là ngƣời chứng minh (P), ngƣời kiểm tra (V) là CT, ban KP,..
Bảng 3.2. Chứng minh lá phiếu đã làm mù hoặc mã hóa hợp lệ
Ngƣời XMTT (P) Ngƣời kiểm tra (V)
- Có [(u, v)= (g, h)] - Chọn wZp -Tính (a,b) = (gw,hw) (a,b) c - V chọn cZp - Tính r := w +c r - Kiểm tra: gr =a.uc, hr=b.vc
Nếu đều đúng V thừa nhận với P sở hữu giá trị
3.3.5. Kỹ thuật trộn các lá phiếu (mixing the votes)
3.3.5.1. Khái niệm:
Khi bỏ phiếu từ xa, để đám bảo tính bí mật, cử tri phải mã hóa nội dung lá phiếu. Ban kiểm phiếu phải giải mã mới biết lá phiếu ghi gì. Có thể có một ngƣời hay một nhóm ngƣời trong ban kiểm phiếu muốn biết nội dung cũng nhƣ tác giả của lá phiếu, điều đó có thể dẫn đến rắc rối đối với cử tri sau này.
Để tránh những rắc rối trên, ngƣời ta sử dụng kĩ thuật “Trộn các lá phiếu”.
Theo kĩ thuật này thì danh tính của cử tri (ví dụ: nhƣ số định danh) không cần phải ẩn đi, vì số định danh cử tri và lá phiếu đã bị xáo trộn.
Với kỹ thuật này, cuộc bỏ phiếu đảm bảo đƣợc bí mật và kiểm soát đƣợc kết quả bỏ phiếu.
3.3.5.2. Kỹ thuật trộn các lá phiếu
1/. Giai đoạn bỏ phiếu:
Giả sử có n cử tri ghi ý kiến của mình vào lá phiếu, ban kiểm phiếu gồm m
ngƣời.
CT sử dụng khóa công khai của m ngƣời để mã hóa lá phiếu của mình. Nhƣ vậy mỗi cử tri phải mã hóa lá phiếu m lần (m bậc)
2/. Giai đoạn kiểm phiếu:
Ngƣời kiểm phiếu 1: Có n lá phiếu đã mã hóa.
- Anh ta chỉ giữ 1 khóa giải mã của mình nên chỉ giải mã bậc 1, không thể biết đƣợc nội dung lá phiếu nhƣng có thể biết ai đã gửi lá phiếu đó
- Sau khi giải mã bậc 1, anh ta hoán vị các lá phiếu đó một cách ngẫu nhiên. - Anh ta gửi hoán vị này cho các cử tri, họ sẽ biết hành trình của các lá phiếu để kiểm tra kết quả có đúng nhƣ lựa chọn của họ hay không.
- Mặt khác anh ta chuyển hoán vị các lá phiếu trên cho ngƣời kiểm phiếu thứ 2
Ngƣời kiểm phiếu 2: Thực hiện tƣơng tự các công việc nhƣ ngƣời kiểm phiếu 1. - Tức là giải mã bậc 2 cho các lá phiếu. Hoán vị các lá phiếu này một cách ngẫu nhiên gửi chúng cho ngƣời kiểm phiếu số 3
- Ngƣời kiểm phiếu tiếp theo sẽ thực hiện các việc tƣơng tự nhƣ ngƣời kiểm phiếu trƣớc đó.
Ngƣời kiểm phiếu thứ m: Nhận đƣợc toàn bộ các phiếu với đầy đủ nội dung. - Do thứ tự của các lá phiếu đã đƣợc thay đổi nên ngƣời kiểm phiếu 1 không nhận ra lá phiếu của ai mặc dù trƣớc đây anh đã biết [4].
3.3.5.3. Ví dụ “Trộn các lá phiếu” : + Có ba ứng cử viên: 1. Nguyễn Văn A 2. Đỗ Văn B 3. Lê Thị C + Có ba cử tri là : CT1, CT2, CT3
+ Ban kiểm phiếu gồm ba ngƣời là: KP1, KP2, KP3 Cuộc bỏ phiếu chọn một trong ba ngƣời
Ban kiểm phiếu dùng hệ mã hóa RSA cho việc mã hóa và giải mã nội dung lá phiếu.Mỗi thành viên trong ban kiểm phiếu đều có một khóa công khai b và một khóa bí mật a.
Cử tri sẽ dùng ba khóa công khai b để mã hóa ba lần lá phiếu của mình.
* Công việc chuẩn bị của ban kiểm phiếu :
+ Kiểm phiếu 1 chọn p1 = 3, q1 = 17 n1 = 51, (n1) = 32 Chọn b1 = 13 ngẫu nhiên nguyên tố cùng nhau với (n1)
Tìm a1=5 là nghịch đảo của b1 theo công thức a*b=1mod((n1)). Công khai (n1,b1) bí mật a1.
+ Kiểm phiếu 2 chọn p2 = 17, q2 = 31 n2 = 527, (n2) = 480 Chọn b2 = 91 ngẫu nhiên nguyên tố cùng nhau với (n2)
Tìm a2=211 là nghịch đảo của b1 theo công thức a*b=1mod(n). Công khai (n2,b2) bí mật a2.
+ Kiểm phiếu 3 chọn p3 = 577, q3 = 673 n3 = 388321, (n3) = 387072 Chọn b3 = 107 ngẫu nhiên nguyên tố cùng nhau với (n3)
Tìm a3=7235 là nghịch đảo của b1 theo công thức a*b=1mod(n).Công khai (n3,b3) bí mật a3
* Công việc của cử tri:
Bƣớc 1: Ghi nội dung lá phiếu. CT dùng hệ cơ số 5 để biểu diễn: + CT1 chọn ông A ông B tƣơng ứng với lựa chọn 1 và 2 Lá phiếu của cử tri 1 có dạng là v1 = 1*50 + 2*51 = 11 + CT 2 chọn ông A bà C tƣơng ứng với lựa chọn 1 và 3 Lá phiếu của cử tri 1 có dạng là v1 = 1*50 + 3*51 = 17 + CT 3 chọn ông B bà C tƣơng ứng với lựa chọn 2 và 3 Lá phiếu của cử tri 1 có dạng là v1 = 2*50 + 3*51 = 26 Bƣớc 2: Mã hóa nội dung lá phiếu
+ CT mã hóa lá phiếu của mình bằng khóa công khai của ba ngƣời kiểm phiếu. Do không gian thực hiện các phép tính của các thành viên trong ban kiểm phiếu là khác nhau (Tùy thuộc vào số n họ chọn) nên việc mã hóa lá phiếu theo thứ tự từ thấp đến cao của n (Bởi vì kết quả mã hóa thực hiện trong không gian lớn thì không
Trong ví dụ trên ta có n1<n2<n3 nên việc mã hóa lá phiếu theo thứ tự bằng khóa công khai của KP1, KP2 và KP3
+ CT1 mã hóa lá phiếu 11 thành 1113 mod 51 = 41 mã hóa tiếp thành 4191 mod 527 = 320 mã hóa tiếp thành 320107 mod 388321= 237827
Đây là giá trị lá phiếu sẽ đƣợc gửi tới ban kiểm phiếu
+ CT2 mã hóa lá phiếu 17 thành 1713 mod 51 = 17 mã hóa tiếp thành 1791 mod 527 = 17 mã hóa tiếp thành 17107 mod 388321= 328336
Đây là giá trị lá phiếu sẽ đƣợc gửi tới ban kiểm phiếu
+ CT3 mã hóa lá phiếu 26 thành 2613 mod 51 = 8 mã hóa tiếp thành 891 mod 527 = 70 mã hóa tiếp thành 70107 mod 388321= 370057
Đây là giá trị lá phiếu sẽ đƣợc gửi tới ban kiểm phiếu