Đồ án Tìm hiểu Chữ kí nhóm và ứng dụng trong giao dịch điện tử

Ngày nay, cùng với sự phát triển của khoa học công nghệ hiện đại và Công nghệ thông tin, ngành mật mã đã có những bước phát triển mạnh mẽ vượt bậc và đạt được nhiều kết quả lý thuyết sâu sắc đã đặt nền móng cho việc phát triển các giải pháp bảo mật, an toàn thông tin trong mọi lĩnh vực hoạt động của con người. Đặc biệt là những ưu điểm nổi bật của chữ ký số. Chữ ký số được biết đến khi sự trao đổi thông tin ngày càng phổ biến trên các mạng truyền thông ở nơi mà chữ ký tay không thể phát huy tác dụng. Trong lĩnh vực ngân hàng, CNTT và hội nhập kinh tế quốc tế đã dẫn đến sựbùng nổ về các loại hình dịch vụ. Ngoài việc góp phần giảm tỉ trọng tiền mặt trong lưu thông, các hình thức dịch vụmới như thẻ tín dụng, máy rút tiền mặt ATM. đã làm cho cầu tiền phản ứng một cách nhanh hơn trước các diễn biến của lãi suất, tức là đã làm tăng độ co dãn của cầu tiền đối với lãi suất. Một cách tổng quát hơn, việc đổi mới công nghệngân hàng trên cơsở ứng dụng CNTT đã góp phần thúc đẩy sự phát triển của thị trường tài chính, đồng thời đẩy nhanh tốc độ chu chuyển của các luồng vốn, làm cho cung cầu tiền tệ trở nên khó dự báo hơn, cơ chế truyển tải chính sách tiền tệ nhạy cảm hơn.

pdf65 trang | Chia sẻ: lylyngoc | Lượt xem: 2734 | Lượt tải: 1download
Bạn đang xem trước 20 trang tài liệu Đồ án Tìm hiểu Chữ kí nhóm và ứng dụng trong giao dịch điện tử, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
(mod N). Nếu P có thể trả lời đúng cả hai yêu cầu khi V gửi b thì chữ ký S trên thông điệp m đúng là của P . Còn nếu một trong hai câu có kết quả sai hoặc cả hai câu đều sai thì chữ ký S trên thông điệp m không phải là chữ ký của P. Blob B có thể được tính bằng cách sau: Z chọn các phần tử sinh gp và hq của *pZ và *qZ và tính g ≡ ⎩⎨ ⎧ ql pg p mod mod và h ≡ ⎩⎨ ⎧ qh pl q mod mod sử dụng CRT Để tính B(y) thì P chọn r1, r2 ∈ (1, …, N) và tính B(y) = y 21 rr hg mod N Khóa bí mật của P : s Công khai : N, m, S, Ω; m, s ∈ Z *N , Ω = [ ] [ ]{ }12,, −NN K ⊂ N Chứng minh với V : m s ≡ S (mod N) và s ∈ Ω Đồ án tốt nghiệp Tìm hiểu Chữ kí nhóm và ứng dụng trong giao dịch điện tử Sinh viên: Phạm Thị Hiểu Lớp CT702 37 Trong giao thức này, chúng ta tạo một giao thức xác nhận, vì P muốn chứng minh cho người nhận V rằng P đưa cho một V chữ ký có giá trị S. Trường hợp này được giải quyết như sau : Giao thức xác nhận 2 Giao thức 2 1. Chứng minh tồn tại s sao cho ms ≡ S (mod N) và s ∈ Ω bằng giao thức 1, thực hiện k lần. 2. Chứng minh rằng s|v như sau: Giao thức 2 3.3.2.2. Giao thức chối bỏ Nếu P muốn chứng minh cho V rằng S không phải là chứ ký của anh ta trên thông điệp m, trường hợp này sẽ được giải quyết như sau: Giao thức chói bỏ Khóa bí mật của P : s Công khai : N, m, S, Ω; m, s ∈ Z *N , Ω = [ ] [ ]{ }12,, −NN K ⊂ N Chứng minh với V : m s ≡ S (mod N) và s ∈ Ω và s|v (s là ước của v) P V a ≡ Sr Chọn r ∈ (1,…, N) b ≡ av/s B(b) Kiểm tra a r Mở blob Kiểm tra blob và b ≡ mvr Khóa bí mật của P : s Công khai : N, m, S, Ω; m, s ∈ Z *N Chứng minh với V : m s ≡ S (mod N) và s ∈ Ω và s|v (s là ước của v) Đồ án tốt nghiệp Tìm hiểu Chữ kí nhóm và ứng dụng trong giao dịch điện tử Sinh viên: Phạm Thị Hiểu Lớp CT702 38 Z công bố ( hg , ) được sinh trong nhóm Z *N (cách tính hg , như sau: chọn các số nguyên a1, a2, b1, b2 thỏa mãn gcd(a1, b1, p-1) = gcd (a2, b2, q-1) = 1 và công khai 2121 ~,~ bbaa hghhgg ≡≡ với g, h là các phần tử sinh của Zp* và Z*q), cùng đó là một thư mục công khai tin cậy chứa ( tên thành viên, ss hg ~,~ ). Lấy l là một hằng số rất nhỏ để việc tìm kiếm toàn diện trên (0, …, 1) là khả thi. Chú ý rằng nếu S ≡ ms, thì p không thể tính a từ ( )as Sm / , vì khi đó ( )as Sm / = 1. Khi đó anh ta sẽ phải đoán a. Giao thức 3 Do chữ ký được tạo ra là chữ ký không thể chối bỏ, ta có thể sử dụng giao thức chối bỏ của sơ đồ chữ ký không thể chối bỏ do chính tác giả David Chaum sáng tác để thưc hiện việc chứng minh chữ ký S không phải là chữ ký của P trên thông điệp m với V . Z công bố g~ và isg~ (mod N), S-1i (mod ϕ(N)) tương ứng từng thành viên. Giao thức 4 sẽ giải quyết vấn đề chối bỏ chữ ký như sau : Giao thức 4 Bước 1 : V chọn ngẫu nhiên 2 số nguyên x1, x2 ∈ Ф, tính ( ) 21 ~ xsx gSc= mod N, sau đó gửi cho P Bước 2 : P tính ( ) 1−= scd mod N, gửi d cho V Bước 3 : V thử điều kiện d ≠ 21 ~ xx gm mod N. Nếu đúng thì tiếp tục bước 4. Nếu sai thì chữ ký đúng là của P P V 2~~ ra hgm ≡ Sr Chọn r1, r2 ∈ (1,…, N) và a ∈ (0, …, 1) ( ) ( ) 21 ~~ rsrsa hgS Tính a từ ( )as Sm / B(b) Bằng cách kiểm tra Toàn bộ các số r1, r2 Mở blob Kiểm tra blob Đồ án tốt nghiệp Tìm hiểu Chữ kí nhóm và ứng dụng trong giao dịch điện tử Sinh viên: Phạm Thị Hiểu Lớp CT702 39 Bước 4 : V chọn ngẫu nhiên 2 số nguyên tố x’1, x’2 ∈ Ф tính ( ) 2'1' ~' xsx gSc = mod N, sau đó gửi c’ cho P . Bước 5 : P tính ( ) 1'' −= scd mod N, sau đó gửi d’ cho V Bước 6 : V thử điều kiện d’ ≠ 2'1' ~ xx gm mod N. Nếu đúng thì tiếp tục bước 7. Nếu sai thì chữ ký đúng là của P . Bước 7 : V kiểm tra ( ) ( ) 1'2'12 ~~ ' xxxx gdgd −− ≡ mod N ? Nếu đồng dư thức đùng thì kết luận chữ ký không phải là của P. Ví dụ : Một ví dụ về sơ đồ chữ ký nhóm dựa trên hệ mật mã RSA ™ Thành lập một nhóm có 5 thành viên, quá trình cài đặt nhóm do người quản lý nhóm thực hiện như sau : Z chọn p = 101, q = 113, N = pq = 11413, ϕ(N) = (p-1)(q-1) = 11200, Z chọn khóa bí mật của Z là Sz = 149, gp = 3, hq = 2 là các phần tử sinh của Z*p và Z *q. Chọn a1 = 3, a2 = 7, b1 = 11, b2 = 13. Tính 21~ aa hgg = mod N = 3456 và 21~ bb hgh = mod N = 2448 Các khóa bí mật của các thành viên như sau : s1= 107,s2 = 113, s3 = 123, s4 = 129, s5 = 137 Khóa công khai của các thành viên ( là nghịch đảo của khóa bí mật của các thành viên trong trường mod ϕ(N)) được gửi lên TPD như sau (không theo thư tự ): 5443, 2577, 3187, 8769, 10873. Các khóa công khai này sẽ được người nhận thông điệp dùng để xác minh có đúng hay không. Khóa công khai của nhóm là N = 11413 v = ∏ iz ss =3916191121461 ™ Ký văn bản : ký văn bản m = 1234 thì Chữ ký của từng thành viên lần lượt là : 278, 6093, 6541, 6528, 8331 ™ Xác nhận chữ ký ( sử dụng giao thức 1) Thành viên 1 muốn xác nhận chữ ký S = 278 đúng là của anh ta ( gọi là P ) trên văn bản m = 1234 với người xác nhận ( gọi là V ) thì anh ta thực hiện giao thức xác nhận ( giao thức 1) Bước 1 : P chọn β = 57, chọn r = 23. Tính z1 = 123423 mod 11413 = 4016, z2 = 123423-57 = mod 11413 = (1234-1)34 mod 11413 = 951734 mod 11413 = 2429. Tính các blob : g = 1922, h = 4748, chọn r1 = 5,r2 = 7. B(z1) = 4016.19225.47487 mod 11413 = 8712 B(z2) = 2429.19225.47487 mod 11413 = 1518 Đồ án tốt nghiệp Tìm hiểu Chữ kí nhóm và ứng dụng trong giao dịch điện tử Sinh viên: Phạm Thị Hiểu Lớp CT702 40 Bước 2 : V chọn b = 0 hoặc b = 1 rồi gửi cho P Bước 3 : P gửi cho V Nếu b = 0 thì r = 23, β = 57, mở các blob g = 1922, h = 4748, r1 = 5,r2 = 7, z1 = 4016, z2 = 2429 Nếu b = 1 thì r = 107 + 23 = 130, z = 4016 Bước 4 : V xác định Nếu b = 0 thì r ∈ (0, …, β) và kiểm tra z1 = 4016, z2 = 3418 sau đó kiểm tra B(4016) = 8712 và B(3418) = 5505 theo thứ tự nào đó mà P đã gửi ở bước 1. Nếu kiểm tra thỏa mãn thì chữ ký là đúng . Nếu b = 1 thì kiểm tra 1234130 ≡ 4016.278 (mod 11413) ↔9387 ≡ 9387. do đó chữ ký là đúng. ™ Chối bỏ chữ ký ( sử dụng giao thức 4). Giả sử thành viên thứ 1 ký thông điệp m = 1234, chữ ký S = 278, thành viên thứ 3 muốn chứng minh rằng đó không phải là chữ ký của anh ta. Khi đó người quản lý nhóm công bố : N = 11413, g~ = 1299, sg~ = 4528 (mod N) (công khai), s-1 = 3187 (mod ϕ(N)) ( cho thành viên cần phải chứng minh biết P). Bước 1 : V chọn x1 = 3, x2 = 5. Tính c = 2783.45285 (mod N) = 6595. Gửi c cho P Bước 2 : P tính d = 65953187 (mod N) = 5172. Rồi gửi cho V Bước 3 : V thử 5172 ≡ 12343 12995 (mod 11413)? →5172 ≡ 4285 Bước 4 : V tính c’ = 2784.45286 (mod N) = 1236 rồi gửi c’ cho P Bước 5 : P tính d’ = 12363187 (mod N) = 6038 rồi gửi cho V Bước 6 : V thử 6038 ≡ 1234412996(mod 11413)? →6038 ≡ 694 Bước 7 : V kiểm tra ( ) ( )( ) ( )⎪⎩ ⎪⎨ ⎧ = = − − 2682mod1299.5172 2682mod1299.6038 45 36 N N do đó chữ ký không phải là của P ™ Một vài nhận xét đối với sơ đồ chữ ký nhóm thứ hai Nếu tất cả thành viên của nhóm có âm mưu loại một người thì khóa bí mật của người này sẽ bị lộ. Việc này có thể dễ dàng được giải quyết khi Z là một thành viên của nhóm, khi đó Z sẽ tính v = ∏ iz ss , trong đó sz là một khóa bí mật mà chỉ Z mới biết. Độ dài của khóa công khai v tuyến tính với số thành viên của nhóm, do đó việc tăng một số lũy thừa của v sẽ là một lần tuyến tính số thành viên của nhóm. Đồ án tốt nghiệp Tìm hiểu Chữ kí nhóm và ứng dụng trong giao dịch điện tử Sinh viên: Phạm Thị Hiểu Lớp CT702 41 3.3.3. Sơ đồ chữ ký nhóm thứ ba Chúng ta giả sử rằng có một thư mục công khai tin cậy trong đó các modulo RSA của mỗi thành viên được liệt kê ( số mũ RSA công khai không cần trong sơ đồ này) Khóa bí mật của thành viên thứ I sẽ là thừa số của modulo RSA của anht a Ni= piqi. trong suốt quá trình cài đặt, Z chọn một số modulo RSA N độc lập với tất cả các Ni của các thành viên. Lấy M là một số nguyên công khai sao cho pi∈Ф=[ ] [ ]{ }12...,, −MM và qi> 4 M (đối với mọi i). nếu thành viên i muốn ký thông điệp m, anh ta chọn ngẫu nhiên một bộ Γ người ( bao gồm cả anh ta ), chữ ký của anh ta sẽ là : ( )( ) ipmf,Γ mod N Và anh ta sẽ phải đưa ra một chứng cớ không tiết lộ thông tin rằng sử dụng thừa số pi ∈ Ф và pi là một ước số của modulo RSA của các người trong Γ . Điều này có thể được giải quyết bằng Giao thức 2 ( với Ω = Ф). Nếu một thành viên muốn chối bỏ một chữ ký, anh ta có thể sử dụng Giao thức 3. 3.3.3.1. Vấn đề “ mở ” chữ ký Trong trường hợp cần thiết, người quản lý nhóm có thể xác định một chữ ký là do thành viên nào trong nhóm ký bằng cách thực hiện giao thức chối bỏ với từng thành viên trong nhóm. Bởi vì chữ ký, mà mỗi thành viên ký là một chữ ký không thể chối bỏ, do đó nếu sử dụng giao thức chối bỏ ( Giao thức 3) thì một thành viên sẽ không thể phủ nhận chữ ký mà mình đã ký. Và khi đó người quản lý nhóm sẽ biết được chữ ký đó là của ai. 3.3.3.2. Nhận xét Các sơ đồ chữ ký nhóm của D.Chaum đều dựa trên hệ mã RSA và việc tính logarit rời rạc đối với một số nguyên tố lớn là khó. Các thông tin về người ký là an toàn, không ai trong nhóm có thể biết được ( tất nhiên là trừ người đã ký). Trong các sơ đồ thì số người trong nhóm là cố định, riêng trong sơ đồ thứ ba, khi một người muốn ký một văn bản mà không muốn lộ tên anh ta thì đồng thời anh ta tạo một nhóm người (các khóa công khai lấy từ thư mục công khai tin cậy) và anh ta sẽ chứng minh rằng anh ta thuộc nhóm người này. Chữ ký được tạo ra là chữ ký không thể chối bỏ. Độ dài của khóa công khai tuyến tính với số người trong nhóm. 3.4. Sơ đồ chữ ký nhóm của Jan Camenish và Stadler David Chaum và Van Heyst đã đưa ra các sơ đồ chữ ký nhóm đầu tiên trên thế giới, nhưng trong các sơ đồ của họ thì số thành viên trong nhóm phải là cố định, nhưng thực tế một số nhóm luôn luôn thay đổi thành viên, để khắc phục được nhược điểm Đồ án tốt nghiệp Tìm hiểu Chữ kí nhóm và ứng dụng trong giao dịch điện tử Sinh viên: Phạm Thị Hiểu Lớp CT702 42 này, năm 1997 Jan Camenish và Stadler đã đưa ra một sơ đồ chữ ký số nhóm mới mà theo đó số thành viên trong nhóm sẽ có thể thay đổi được. Sơ đồ chữ ký số nhóm do Jan Camenish và Stadler gồm 5 thủ tục: ™ Setup: Sinh khóa công khai của nhóm và khóa bí mật của người quản lý nhóm ™ Join: Thủ tục tương tác giữa người quản lý nhóm và một thành viên mới của nhóm để cung cấp cho thành viên này khóa bí mật và chứng nhận thành viên. ™ Sign: Thủ tục ký một thông điệp của một thành viên trong nhóm. ™ Verify: Thủ tục kiểm tra chữ ký trên một thông điệp xem có đúng là chữ ký của nhóm đó hay không. ™ Open: Là thủ tục để xác định xem chữ ký S trên thông điệp m là của thành viên nào trong nhóm. 3.4.1. Một số khái niệm cần thiết Khái niệm 1 Một chữ ký dựa trên kiến thức về logarit rời rạc kép của y theo g, và a trên thông điệp m với một tham số an toàn l kí hiệu là : ( )[ ]( )mgySKLOGLOG al αα = Là một nhóm ( )lsssc ...,,,, 21 ∈ { } lml Zx1,0 thỏa mãn : ( )ll PPPagymHc ...,,,,,,, 21= Trong đó ( ) [ ] ( ) [ ]⎪⎩ ⎪⎨ ⎧ ≠↔ =↔= 0 0 icy icg P is is a a i Khái niệm 2 Một chữ ký dựa trên kiến thức về logarit rời rạc thành phần gốc thứ e của y theo g trên thông điệp m được ký hiệu: ( )[ ]( )mgySKROOTLOG el αα = Là một nhóm ( )lsssc ...,,,, 21 ∈ { } lml Zx1,0 thỏa mãn : ( )ll PPPagymHc ...,,,,,,, 21= Trong đó ( ) [ ] ( ) [ ]⎪⎩ ⎪⎨ ⎧ ≠↔ =↔= 0 0 icy icg P e i e i s s i Đồ án tốt nghiệp Tìm hiểu Chữ kí nhóm và ứng dụng trong giao dịch điện tử Sinh viên: Phạm Thị Hiểu Lớp CT702 43 3.4.2. Sơ đồ chữ ký ™ Setup : Người quản trị nhóm chọn tham số an toàn l rồi làm các bước sau : ¾ Một cặp khóa công khai RSA(n, e) và một khóa bí mật d. Trong đó n có độ dài tối thiểu là 21bit, n = pq, p = P + 1, q = 2Q + 1 p, q, P, Q là các số nguyên tố ¾ Một nhóm Cyclic G = ¾ Một phần tử *nZ∈α ngẫu nhiên. ¾ Một số mũ λ và một hằng số μ >1, μ càng lớn thì hệ thống càng an toàn ™ Join : A muốn tham gia vào nhóm thì phải thực hiện các bước sau: ¾ Lấy một khóa bí mật { }12...,,1,0 −∈ λx ¾ Tính y = ax (mod n) ¾ Tính khóa thành viên z = gy, A sẽ sử dụng khóa bí mật của mình để ký z. ¾ Để có được chứng nhận thành viên của nhóm, A gửi (y, z) cho người quản lý nhóm, anh ta sẽ cấp cho A chứng nhận thành viên : v≡(y+1)d(mod n) ™ Sign : Để ký một thông điệp m, A làm theo các bước sau : ¾ rgg =~ với r ∈ Zn ¾ ( )ry zgz == ~~ ¾ [ ] ( )mgzSKLOGLOGV l ~~1 == α ¾ [ ]( )mggzSKROOTLOGV l ββ ~~~2 == Chữ ký trên thông điệp m gồm s = ( )21,,~,~ VVzg ™ Verify : Để xác thực chữ ký s đúng là chữ ký trên m ta phải làm các bước sau : ¾ Kiểm tra V1 thỏa mãn 1~~~ += αaggz hay không ¾ Kiểm tra V2 là chữ ký dựa trên hàm logarit rời rạc của phần tử gốc thứ e. ™ Open : Với chữ ký s = ( )21,,~,~ VVzg trên thông điệp m, người quản lý nhóm có thể xác định người ký bằng cách kiểm tra xem pygz ~~ = với mọi thành viên P của nhóm với yp = logg zp và zp là khóa bí mật của thành viên P. Đồ án tốt nghiệp Tìm hiểu Chữ kí nhóm và ứng dụng trong giao dịch điện tử Sinh viên: Phạm Thị Hiểu Lớp CT702 44 Chương IV ỨNG DỤNG CHỮ KÝ NHÓM 4.1. Tìm hiểu về giao dịch điện tử Giao dịch điện tử là giao dịch được thực hiện thông qua các phương tiện điện tử và cũng có giá trị pháp lý như nó được ghi chép, hoặc mô tả bằng văn bản theo phương pháp truyền thống. Có thể coi văn bản pháp lý đầu tiên ở Việt Nam về giao dịch điện tử là quyết định của Thủ tướng Chính phủ số 44, năm 2002 về chấp nhận chữ ký điện tử trong thanh toán liên ngân hàng. Ngày 28/10/2005, kỳ họp thứ 8 Quốc hội Khóa XI đã thảo luận về Dự thảo Luật Giao dịch điện tử. Tham gia phiên thảo luận, Bộ trưởng Bộ Bưu chính Viễn thông Đỗ Trung Tá đã phát biểu ý kiến về nội dung quan trọng trong Dự thảo Luật Giao dịch điện tử “Chính phủ quy định cụ thể về việc thừa nhận chữ ký điện tử và chứng thư điện tử nước ngoài”. Hiện nay, ngành ngân hàng đang ứng dụng một số giao dịch điện tử như gửi, nhận, cung cấp thông tin qua mạng, xử lý chứng từ kế toán, giao dịch giữa ngân hàng với khách hàng. Giao dịch điện tử gồm các hình thức thông điệp dữ liệu, chữ ký điện tử, chứng thực điện tử, giao kết và thực hiện hợp đồng điện tử... 4.2. Thẻ thanh toán điện tử Trước đây, các hệ thống thanh toán trên thế giới phần lớn do các ngân hàng thương mại (NHTM) tự liên kết với nhau đứng ra thành lập và vận hành, Ngân hàng Trung ương chỉ là nơi quyết toán vốn. Những năm gần đây, khi công nghệ thông tin phát triển nhanh, các trung tâm thanh toán cũ gặp rất nhiều khó khăn trong việc đầu tư mới và nâng cấp kỹ thuật công nghệ, mặt khác, rủi ro trong hoạt động ngân hàng nói chung và trong hệ thống thanh toán nói riêng thực sự đe doạ sự mất an toàn hệ thống là một thách thức đối với các Ngân hàng Trung ương. Do vậy, nhiều Ngân hàng Trung ương đã tự đầu tư xây dựng mới hệ thống thanh toán điện tử liên ngân hàng xử lý các khoản thanh toán giá trị cao hoặc hợp nhất các trung tâm thanh toán thành những trung tâm lớn hơn để quản lý và giám sát. Xuất phát từ đặc điểm, một hệ thống thanh toán hoàn chỉnh phải hội đủ hai yếu tố. Một là, nói đến hệ hệ thống thanh toán là nói đến yếu tố kỹ thuật (nhanh, chậm, chính xác...); Hai là, hệ thống phải quản lý được dòng chu chuyển vốn bằng việc quản lý số dư tài khoản thanh toán, quyết toán, bù trừ. Chữ ký nhóm có rất nhiều ứng dụng trong thực tế như: Bỏ phiếu điện tử, thanh toán điện tử. Hiện nay các loại thẻ thanh toán điện tử, thẻ rút tiền tự động ATM (automated teller machine) đã trở thành phổ biến trên thế giới và cũng đang rất phát triển tại Việt Nam. Tuy nhiên nếu mỗi ngân hàng đều phát hành một loại thẻ riêng thì chi phí bỏ ra Đồ án tốt nghiệp Tìm hiểu Chữ kí nhóm và ứng dụng trong giao dịch điện tử Sinh viên: Phạm Thị Hiểu Lớp CT702 45 sẽ rất cao, và người tiêu dùng khi muốn thanh toán hoặc rút tiền sẽ phải tìm đến đúng điểm (pos) cho phép của ngân hàng đó mới có thể thực hiện giao dịch. Điều này sẽ gây cản trở trong việc phát triển các hệ thống thanh toán trực tuyến, rút tiền tự động… Chính vì thế mà việc đòi hỏi có một loại thẻ chung giữa các ngân hàng, và các máy kiểm tra thẻ, máy rút tiền tự động có thể thực hiện giao dịch đối với thẻ của các ngân hàng. Chữ ký nhóm sẽ được ứng dụng trong trường hợp này. Một liên minh ngân hàng (hay một nhóm các ngân hàng) trong đó mỗi ngân hàng là một thành viên trong nhóm đó với người quản lý nhóm là một ngân hàng trung tâm ( phải là ngân hàng có rất uy tín và thường là ngân hàng trung ương ). Ngân hàng trung tâm sẽ tạo ra các khóa bí mật và khóa công khai của nhóm, tạo các khóa bí mật cho các ngân hàng thành viên. Khi đó các ngân hàng sẽ tạo trên thẻ thanh toán do ngân hàng mình phát hành dựa trên khóa bí mật của mình. Khi một người tiêu dùng có thẻ của liên minh ngân hàng đó, anh ta có thể thanh toán, rút tiền,…tại các địa điểm hỗ trợ của liên minh ngân hàng. Các máy kiểm tra thẻ sẽ kiểm tra chữ ký của ngân hàng phát hành trên thẻ đó, xem thẻ có hợp lệ hay không, và sẽ đưa ra quyết định thực hiện giao dịch. Khóa công khai của liên minh ngân hàng sẽ tuyến tính theo số lượng của các ngân hàng thành viên. Bất kì sự liên minh nào trong liên minh ngân hàng (không bao gồm ngân hàng trung tâm) đều không thể biết được khóa bí mật của ngân hàng khác, do đó sẽ không thể làm giả được thẻ của ngân hàng khác. Cùng với sự phát triển của thế giới thương mại điện tử cũng đang rất được quan tâm và phát triển, một số công ty thực hiện bán hàng trực tuyến qua mạng do đó việc áp dụng chữ ký nhóm là rất hữu ích, giảm tiện, kinh tế hơn, thuận tiện cho người sử dụng và rất cần thiết. 4.3.Việc ứng dụng và phát triển công nghệ tại Việt Nam hiện nay Công ty Cổ phần Chuyển mạch Tài chính Quốc gia Việt Nam (Banknetvn) được Thống đốc NHNN (ngân hàng nhà nước) Việt Nam cấp Giấy phép hoạt động ngày 09/07/2004 và khai trương hoạt động vào ngày 09/08/2004. Banknetvn được thành lập trên cơ sở góp vốn của các cổ đông và có số vốn điều lệ là 94,5 tỷ đồng. Hiện nay Banknetvn có 8 thành viên cổ đông sáng lập, bao gồm: Ngân hàng Nông nghiệp và Phát triển nông thôn Việt nam (VBARD), Ngân hàng Đầu tư và Phát triển Việt nam (BIDV), Ngân hàng Công thương Việt nam (ICB), Ngân hàng Sài gòn Thương tín (Sacombank), Ngân hàng Sài gòn Công thương (Saigonbank), Ngân hàng Á Châu (ACB), Ngân hàng Đông Á (EAB) và Công ty Điện toán và truyền số liệu (VDC). Banknetvn hoạt động theo luật doanh nghiệp và các luật chuyên Ngành liên quan. Mục tiêu hoạt động kinh doanh chính là thực hiện kết nối các hệ thống thanh toán thẻ ngân hàng, thẻ thanh toán giữa các ngân hàng được phép phát hành, chấp nhận, thanh Đồ án tốt nghiệp Tìm hiểu Chữ kí nhóm và ứng dụng trong giao dịch điện tử Sinh viên: Phạm Thị Hiểu Lớp CT702 46 toán thẻ và các tổ chức khác được phép cung ứng dịch vụ thanh toán; thực hiện thanh toán bù trừ đối với các giao dịch thanh toán thẻ ngân hàng và cung ứng các dịch vụ có liên quan trong lĩnh vực thẻ thanh toán. Tình hình về phát hành thẻ và dịch vụ ATM ở các Ngân hàng thương mại ở Việt Nam Vài năm gần đây, với sự phát triển của công nghệ trên toàn thế giới và bằng những nỗ lực của mình, Việt Nam đã ứng dụng được nhiều công nghệ mới, tiên tiến và đã có những thành quả đáng ghi nhận trong lĩnh vực thẻ thanh toán. Tuy nhiên, việc sử dụng công nghệ mới trong phương thức thanh toán không dùng tiền mặt Việt Nam còn hạn chế, đơn giản với doanh số chưa nhiều. Về lĩnh vực thẻ, các Ngân hàng Việt Nam mới đang phát triển hệ thống thẻ từ, trong khi trên thế giới các Ngân hàng đã và đang chuyển sang hệ thống thẻ thông minh theo chuẩn EMV (Europay, Mastercard và Visa) Những máy giao dịch tự động (ATM) và những chiếc thẻ ATM đầu tiên ở Việt Nam được triển khai trong một dự án do Ngân hàng Nhà nước Việt nam chủ trì từ năm 1996. Vào thời gian đó ATM và thẻ ATM là những thứ rất lạ đối với thị trường Việt Nam. Có thể nói, khi đó những người hiểu biết về ATM và thẻ ATM rất ít ỏi, hơn nữa, những điều kiện cần có để phát triển dịch vụ ATM vào thời gian này cũng chưa có gì. Vietcombank là Ngân hàng thương mại đầu tiên thực hiện việc thử nghiệm này. Và trong khoảng thời gian 5 năm 1996-2000 chỉ có một vài ngân hàng lớn tiếp tục thực hiện việc nghiên cứu, thử nghiệm dịch vụ ATM. Vào thời kỳ này số lượng ATM ở Việt nam còn khá ít, tổng cộng chỉ vài chục chiếc. Thẻ ATM phát hành chủ yếu cho cán bộ ngân hàng (để thí điểm) là chính. Ngoài thẻ ATM một số ngân hàng có dịch vụ chấp nhận thanh toán thẻ tín dụng quốc tế (Visa, MasterCard v.v.) nhưng đều thực hiện bằng phương pháp thủ công. Smart card (thẻ thông minh), một dạng ví điện tử cũng được số ít ngân hàng thử nghiệm trong phạm vi rất nhỏ. Như vậy, có thể nói giai đoạn 1996-2000 là thời kỳ mở đầu, chủ yếu nghiên cứu, tiếp cận thị trường thanh toán thẻ ở Việt Nam. Từ năm 2001 đến năm 2005 chúng ta đã được chứng kiến sự phát triển vượt bậc của thị trường thẻ thanh toán. Nhiều ngân hàng, kể cả các NHTM Nhà nước và các NHTM cổ phần đã triển khai các dịch vụ thanh toán thẻ với việc ứng dụng công nghệ thông tin, trang bị hệ thống công nghệ thẻ hiện đại và phát hành nhiều loại thẻ khác nhau. Theo số liệu khảo sát của Banknetvn, vào thời điểm cuối năm 2005 ở Việt Nam đã có khoảng 2,7 triệu thẻ thanh toán các loại được phát hành, có trên 1.700 máy ATM và trên 9.000 điểm chấp nhận thẻ (POS) đã được lắp đặt sử dụng. Các loại thẻ thanh toán được phát hành và sử dụng khá phong phú, bao gồm: thẻ ATM, thẻ ghi nợ, thẻ tín dụng, thẻ nội địa, thẻ quốc tế, thẻ tiền mặt v.v. Tốc độ phát triển thẻ thanh toán trong thời kỳ này rất cao, thường xuyên tăng từ trên 200%/năm. Các dịch vụ thanh toán dựa Đồ án tốt nghiệp Tìm hiểu Chữ kí nhóm và ứng dụng trong giao dịch điện tử Sinh viên: Phạm Thị Hiểu Lớp CT702 47 trên thẻ cũng ngày được tăng cường. Nó không chỉ dừng ở dịch vụ rút tiền mặt trên ATM mà đã mở rộng ra các dịch vụ chuyển khoản, thanh toán hàng hóa, thanh toán hóa đơn, mua vé, thanh toán cước phí v.v. Nhiều ngân hàng đã kết nối thực hiện thanh toán và phát hành thẻ quốc tế (Visa, MasterCard, Amex, JCB v.v.). Trong thời gian này chủ yếu các Ngân hàng tự đầu tư phát triển dịch vụ thẻ. Điều đáng mừng là việc nhận thức và sự chấp nhận sử dụng các dịch vụ thanh toán thẻ của nhiều tầng lớp nhân dân, nhất là giới trẻ đã được cải thiện đáng kể. Những năm gần đây, đã có những sự liên minh, liên kết giữa các nhóm Ngân hàng để tạo ra các mạng thanh toán thẻ rộng hơn. Nhưng các liên minh thanh toán thẻ này còn nhỏ, lẻ và chưa đáp ứng được nhu cầu kết nối tạo ra một mạng thanh toán thẻ chung thống nhất trong quy mô quốc gia. Từ năm 2006 thị trường thẻ thanh toán Việt Nam tiếp tục phát triển với tốc độ cao. Chỉ tính đến cuối tháng 8/2006 theo ước tính của Banknetvn ở Việt Nam đã có gần 4 triệu thẻ thanh toán được phát hành, trên 2.700 ATM và 12.000 POS được lặp đặt sử dụng. Nhiều Ngân hàng tích cực ứng dụng công nghệ hiện đại, mạnh dạn đầu tư phát triển dịch vụ thanh toán thẻ. Các dịch vụ thanh toán thẻ đã trở nên phổ biến hơn, gần gũi, thân thiện hơn với nhiều người dân. Các Ngân hàng và liên minh thẻ cũng đang xích lại gần nhau hơn. Chắc chắn một mạng thanh toán thẻ chung cho tất cả các ngân hàng sẽ được hình thành trong thời gian không xa. Bởi theo dự báo chủ quan của chúng tôi thị trường thẻ Việt Nam sẽ còn phát triển mạnh trong thời gian ít nhất là 5 năm tới. Với phương châm “đi tắt, đón đầu” trong lĩnh vực thanh toán bằng thẻ, Chính phủ đã ban hành đề án thanh toán không dùng tiền mặt giai đoạn 2006 - 2010. Dự kiến, đến năm 2010, thẻ do một ngân hàng phát hành có thể sử dụng được ở nhiều máy ATM và POS của các ngân hàng khác. Đề án mới về thanh toán không dùng tiền mặt còn nêu rõ, đối với khu vực dân cư sẽ khuyến khích, tạo điều kiện cho các tổ chức cung ứng dịch vụ thanh toán tập trung đầu tư cơ sở hạ tầng, thiết bị phục vụ cho các giao dịch thanh toán hiện đại. Trong kế hoạch từ nay đến 2010, sẽ tập trung chủ yếu cho dịch vụ thẻ và tạo điều kiện phát triển thanh toán qua internet, mobile, đồng thời tiếp cận nhanh chóng với công nghệ hiện đại trên thế giới theo cách thức “đi tắt, đón đầu”. Bên cạnh đó, Chính phủ sẽ chỉ đạo xây dựng trung tâm chuyển mạch thẻ thống nhất, kết nối các hệ thống máy tính ATM của các liên minh thẻ hiện hành thành một hệ thống thống nhất, nhằm tăng tính thuận tiện cho người sử dụng dịch vụ thẻ ngân hàng. Theo đề án, thẻ do một ngân hàng phát hành có thể sử dụng ở nhiều máy ATM và POS của các ngân hàng khác. Đồ án tốt nghiệp Tìm hiểu Chữ kí nhóm và ứng dụng trong giao dịch điện tử Sinh viên: Phạm Thị Hiểu Lớp CT702 48 Một trong những mục tiêu không kém phần quan trọng của đề án là phấn đấu đến cuối năm 2010, tất cả các Bộ, cơ quan ngang Bộ, các cấp chính quyền tỉnh, thành phố đều thực hiện chi tiêu bằng phương tiện thanh toán không dùng tiền mặt. Từ 2011 - 2020 sẽ triển khai mở rộng đến các đối tượng là Sở, Ban, ngành, các cấp chính quyền huyện, xã trên phạm vi toàn quốc. Theo lộ trình, đến cuối năm 2010 sẽ có khoảng 20 triệu tài khoản cá nhân; 70% cán bộ hưởng lương ngân sách và 50% công nhân lao động trong khu vực doanh nghiệp, tư nhân được trả lương qua tài khoản. Đến năm 2020, sẽ là 45 triệu tài khoản cá nhân; 95% cán bộ hưởng lương ngân sách và 80% lao động được trả lương qua tài khoản. Tại khu vực doanh nghiệp, sẽ có khoảng 80% các khoản thanh toán giữa doanh nghiệp với nhau được thực hiện qua tài khoản tại ngân hàng và đạt 95% vào năm 2020. Với đề án này, tương lai không xa “ví tiền” của cán bộ, viên chức và công nhân lao động sẽ thu gọn trong 1 tấm thẻ. 4.4. Chương trình a. Mã nguồn #include #include #include #include #include //========================================== int roso(char s); char rochu(int s); void kyvb(char *tep); int Kiemthu(); long int kha_nghich(long int b, long int n); void output(); void Elgamal(); long exp_mod(long x, long b, long n); long Extended_Euclidean(long b, long n); int kiemtra_ngto(long pq); long USCLN(long n,long m); long Ktra_ngto_cungnhau(long b,long phi_N); long Kitep(int Ki); long Doctep(long n); Đồ án tốt nghiệp Tìm hiểu Chữ kí nhóm và ứng dụng trong giao dịch điện tử Sinh viên: Phạm Thị Hiểu Lớp CT702 49 void Ky_RSA(); void chaum(); //=========================================== long int p,a,alpha,k,beta,k1; long int delta,gamma; int chuky[500],sl; //=========================================== int roso(char s) { return s; } char rochu(int s) { return s; } //================ky van ban============== void kyvb(char *tep) { clrscr(); char c,c1; long int so; int so1,so2,l,i; FILE *f,*f1; char *tep1; char *s; sl=1; chuky[0]=gamma; f=fopen(tep,"a+t"); if(f==NULL) { printf("Loi mo tep!!!"); getch(); exit(0); } while(!feof(f)) { fscanf(f,"%c",&c); //doc tung ky tu trong tep. if(c!=10) Đồ án tốt nghiệp Tìm hiểu Chữ kí nhóm và ứng dụng trong giao dịch điện tử Sinh viên: Phạm Thị Hiểu Lớp CT702 50 { so=roso(c); //lay gia tri so cua tung ky tu c. delta=((so-a*gamma)*k1)%(p-1); //tinh gia tri ky la gamma. delta=delta+(p-1); //vi delta<0 chuky[sl]=delta; //gia tri ky tren tung ky tu. sl++; } } fclose(f); } //============Ham kiem thu chu ky================= int Kiemthu() { char *tep,*tep1; char c; int d; long int so; FILE *f,*f1; printf("Nhap ten tep can kiem thu:");fflush(stdin); gets(tep); printf("Nhap ten tep chua chu ky can kiem thu:");fflush(stdin); gets(tep1); f=fopen(tep,"rt"); f1=fopen(tep1,"rt"); int kt=1; fscanf(f1,"%2d",&sl); fscanf(f1,"%2d\n",&gamma); int i=1; while(i<sl-1) { fscanf(f,"%c",&c); so=roso(c); fscanf(f1,"%3d",&d); if((a*gamma+k*d)%(p-1)!=so) { kt=0; return kt;} i++; } Đồ án tốt nghiệp Tìm hiểu Chữ kí nhóm và ứng dụng trong giao dịch điện tử Sinh viên: Phạm Thị Hiểu Lớp CT702 51 fclose(f1); fclose(f); return kt; } //===========Tinh Kha nghich ================ long int kha_nghich(long int b, long int n) { long int n0, b0; long int t, t0, temp, q, r; n0=n; b0=b; t0=0; t=1; q=floor(n0/b0); r=n0-q*b0; while(r>0){ temp=t0-q*t; if (temp < 0) temp = n- ((-temp) % n); else temp = temp % n; t0=t; t=temp; n0=b0; b0=r; q=floor(n0/b0); r=n0-q*b0; } if(b0!=1) { printf("Khong co a"); return 0;} else return(t%n); } //=================================================== void output() { char c; char *tep; FILE *f; printf("Nhap ten tep can luu chu ky:");fflush(stdin); gets(tep); Đồ án tốt nghiệp Tìm hiểu Chữ kí nhóm và ứng dụng trong giao dịch điện tử Sinh viên: Phạm Thị Hiểu Lớp CT702 52 f=fopen(tep,"wt"); if(f==NULL) { printf("\nLoi mo tep!!!!!!"); getch(); exit(0); } fprintf(f,"%d",sl); fprintf(f," %d\n",chuky[0]); for(int i=1;i<sl;i++) { fprintf(f," %2d",chuky[i]); } fclose(f); } //=============Hàm chinh============================== void Elgamal() { printf("\n\n =====* CHU KY ELGAMAL *======"); long int x,y; int ch; char *tep,*tep1; FILE *f,*f1; char c; printf("\n\nNhap so nguyen to p:");scanf("%ld",&p); printf("Nhap a:");scanf("%ld",&a); printf("Nhap alpha:");scanf("%ld",&alpha); printf("Nhap khoa k:");scanf("%ld",&k); beta=exp_mod(a,alpha,p); gamma=exp_mod(k,alpha,p); k1=kha_nghich(k,p-1); while(1) { printf("\n\nCAC LUA CHON CHO CHU KY SO ELGAMAL\n"); printf("[1].Ky \n"); printf("[2].Hien thi \n"); printf("[3].Kiem thu\n"); printf("[0].Thoat!!\n"); Đồ án tốt nghiệp Tìm hiểu Chữ kí nhóm và ứng dụng trong giao dịch điện tử Sinh viên: Phạm Thị Hiểu Lớp CT702 53 printf("\n\nMoi ban chon:");scanf("%d",&ch); switch(ch) { case 1:{ printf("Nhap ten tep:");fflush(stdin); gets(tep); kyvb(tep); output(); }break; case 2:{ printf("Nhap ten can hien thi:");fflush(stdin); gets(tep); printf("Nhap tep ten chua chu ky tuong ung:");fflush(stdin); gets(tep1); f=fopen(tep,"r+t"); int d; printf("\n\n VAN BAN\n\n"); while(!feof(f)) { fscanf(f,"%c",&c); printf("%c",c); } f1=fopen(tep1,"r+t"); printf("\n\n CHU KY\n\n"); fscanf(f1,"%d",&sl); fscanf(f1,"%d",&gamma); printf("do dai xau:%2d" "gia tri gamma:%2d\n",sl,gamma); for(int i=0;i<sl-1;i++) { fscanf(f1,"%d",&d); printf(" %2d",d); } fclose(f1); fclose(f1); }break; case 3:{ if(Kiemthu()==1)printf("Chu ky dung!!"); else printf("Chu ky gia!!"); Đồ án tốt nghiệp Tìm hiểu Chữ kí nhóm và ứng dụng trong giao dịch điện tử Sinh viên: Phạm Thị Hiểu Lớp CT702 54 } case 0:break; } if(ch==0) break; } getch(); } //=========== Tinh Mod ============ long exp_mod(long x, long b, long n) { long a = 1l, s = x; while (b != 0) { if (b & 1l) a = (a * s) % n; b >>= 1; if (b != 0) s = (s * s) % n; } if (a < 0) a += n; return a; } //============= Tinh theo Euclidean mo rong =========== long Extended_Euclidean(long b, long n) { long b0 = b, n0 = n, t = 1, t0 = 0, temp, q, r; q = n0 / b0; r = n0 - q * b0; while (r > 0) { temp = t0 - q * t; if (temp >= 0) temp = temp % n; else temp = n - (- temp % n); t0 = t; t = temp; n0 = b0; b0 = r; q = n0 / b0; r = n0 - q * b0; } if (b0 != 1) return 0; Đồ án tốt nghiệp Tìm hiểu Chữ kí nhóm và ứng dụng trong giao dịch điện tử Sinh viên: Phạm Thị Hiểu Lớp CT702 55 else return t % n; } //====================================================== void chaum() { printf("\n\n =====* GIAO THUC CHOI BO *====="); long a0, a1 = 144, a2 = 874, b1 = 1873, b2 = 2345; long alpha = 25, beta = 1866, gamma1 = 5065; long gamma2 = 5076, p = 5087, q = (p - 1) >> 1; long r, s, x = 4785, y1 = 2219, y2 = 458, z1, z2; r = (gamma1 * exp_mod(gamma2, x, p)) % p; s = (exp_mod(alpha, y1, p) * exp_mod(beta, y2, p)) % p; if (r == s) printf("\nChu ky duoc chap nhan\n"); else printf("\nChu ky khong duoc chap nhan\n"); z1 = (a1 + x * b1) % q; z2 = (a2 + x * b2) % q; if (z2 > y2) a0 = ((y1 - z1) * Extended_Euclidean(z2 - y2, q)) % q; else a0 = ((z1 - y1) * Extended_Euclidean(y2 - z2, q)) % q; if (a0 < 0) a0 += q; printf("alpha = %ld\n", alpha); printf("beta = %ld\n", beta); printf("p = %ld\n", p); printf("q = %ld\n", q); printf("gamma1 = %ld\n", gamma1); printf("gamma2 = %ld\n", gamma2); printf("a1 = %ld\n", a1); printf("a2 = %ld\n", a2); printf("b1 = %ld\n", b1); printf("b2 = %ld\n", b2); printf("x = %ld\n", x); printf("y1 = %ld\n", y1); printf("y2 = %ld\n", y2); printf("sig(%ld) = (%ld, %ld)\n", x, z1, z2); printf("a0 = %ld\n", a0); Đồ án tốt nghiệp Tìm hiểu Chữ kí nhóm và ứng dụng trong giao dịch điện tử Sinh viên: Phạm Thị Hiểu Lớp CT702 56 if (beta == exp_mod(alpha, a0, p)) printf("a0 duoc xac nhan\n"); else printf("a0 khong duoc chap nhan\n"); getch(); } //============================================================ ====== int kiemtra_ngto(long pq) { for(long i=2;i<=(long)sqrt(pq);i++) if(pq%i==0) { printf("\n\n Khong phai so nguyen to!\n\nMoi ban nhap lai!"); return 0; } return 1; } //============================================================ ====== long USCLN(long n,long m) { while(m!=0&&n!=0) if(n>m) n=n-m; else m=m-n; if(n==0) return m; else return n; } //============================================================ ====== long Ktra_ngto_cungnhau(long b,long phi_N) { if(USCLN(b,phi_N)!=1) { printf("\n\nb khong phai la nguyen to cung nhau voi phi_N\n\n moi chon lai b!"); return 0; Đồ án tốt nghiệp Tìm hiểu Chữ kí nhóm và ứng dụng trong giao dịch điện tử Sinh viên: Phạm Thị Hiểu Lớp CT702 57 } else return 1; } //============================================================ ====== long Kitep(int Ki) { FILE *f; char *tentep; long n; mt:printf("\n\nNhap vao ten tep can Ki:");fflush(stdin);gets(tentep); f=fopen(tentep,"a+t"); if(f==NULL) { printf("\n\nTep %s khong ton tai! Moi nhap lai!",tentep); getch(); goto mt; } fseek(f,0,SEEK_END); n=ftell(f); fseek(f,n,SEEK_SET); fprintf(f,"%d",Ki); fclose(f); return n; } //============================================================ ===== long Doctep(long n) { FILE *f; char *tentep; mt:printf("\n\nNhap vao ten tep can mo:");fflush(stdin);gets(tentep); f=fopen(tentep,"a+t"); if(f==NULL) { printf("\n\nTep %s khong ton tai! Moi nhap lai!",tentep); goto mt; } Đồ án tốt nghiệp Tìm hiểu Chữ kí nhóm và ứng dụng trong giao dịch điện tử Sinh viên: Phạm Thị Hiểu Lớp CT702 58 long ki; fseek(f,n,SEEK_SET); fscanf(f,"%ld",&ki); fclose(f); return ki; } //============================================================ ======= void Ky_RSA() { clrscr(); long x,a,b,n,phi_N,p,q; long Kthuocvb; int Ki,Kiem_thu; printf("\n=====* CHU KY RSA *======"); p:printf("\nNhap so nguyen to p=");scanf("%ld",&p); if(kiemtra_ngto(p)!=1)goto p; q:printf("\nNhap so nguyen to q=");scanf("%ld",&q); if(kiemtra_ngto(q)!=1)goto q; n=p*q; phi_N=(p-1)*(q-1); b:printf("\nMoi ban chon so b (1<b<phi_N) sao cho gcd(b,phi_N)==1\n\n b="); scanf("%ld",&b); if(Ktra_ngto_cungnhau(b,phi_N)!=1)goto b; a=kha_nghich(b,phi_N); printf("\n\n LAP CHU KI "); printf("\nKhoa bi mat dung de tao chu ki la K1(a)=%ld",a); printf("\nNhap vao so de lap chu ki so x=");scanf("%ld",&x); Ki=exp_mod(x,a,n); printf("\nVoi so x ta tao duoc ra chu Ki la :%d",Ki); Kthuocvb=Kitep(Ki); printf("\nVan ban da duoc ki!"); printf("\n\n KIEM THU CHU KI "); printf("\nKiem thu voi khoa cong khai la K2(b,n)=(%ld,%ld)",b,n); Kiem_thu=Doctep(Kthuocvb); printf("\nChu ki duoc lay tu tep la:%d",Kiem_thu); printf("\nKiem thu chu ki so ta duoc x=%d ",exp_mod(Kiem_thu,b,n)); if(exp_mod(Kiem_thu,b,n)==x) Đồ án tốt nghiệp Tìm hiểu Chữ kí nhóm và ứng dụng trong giao dịch điện tử Sinh viên: Phạm Thị Hiểu Lớp CT702 59 printf("\n\n CHU KI TREN LA DUNG!"); else printf("\n\n KHONG PHAI LA CHU KI!"); getch(); } //============================================================ ====== void menu() { int c; while(1) { clrscr(); printf("\n\n =====* CHUONG TRINH CHU KY SO *======="); printf("\n\n [1].CHU KY RSA"); printf(" [2].CHU KY ELGAMAL"); printf("\n [3].GIAO THUC CHOI BO"); printf(" [4].THOAT KHOI CHUONG TRINH"); printf("\n\n MOI BAN CHON:");scanf("%d",&c); switch(c) { case 3: chaum(); break; case 4: return; case 2: Elgamal(); break; case 1: Ky_RSA(); break; } } } //=========================================== void main() Đồ án tốt nghiệp Tìm hiểu Chữ kí nhóm và ứng dụng trong giao dịch điện tử Sinh viên: Phạm Thị Hiểu Lớp CT702 60 {clrscr(); menu(); } b. Kết quả chương trình Đồ án tốt nghiệp Tìm hiểu Chữ kí nhóm và ứng dụng trong giao dịch điện tử Sinh viên: Phạm Thị Hiểu Lớp CT702 61 Kết luận Ngày nay, cùng với sự phát triển của khoa học công nghệ hiện đại và Công nghệ thông tin, ngành mật mã đã có những bước phát triển mạnh mẽ vượt bậc và đạt được nhiều kết quả lý thuyết sâu sắc đã đặt nền móng cho việc phát triển các giải pháp bảo mật, an toàn thông tin trong mọi lĩnh vực hoạt động của con người. Đặc biệt là những ưu điểm nổi bật của chữ ký số. Chữ ký số được biết đến khi sự trao đổi thông tin ngày càng phổ biến trên các mạng truyền thông ở nơi mà chữ ký tay không thể phát huy tác dụng. Trong lĩnh vực ngân hàng, CNTT và hội nhập kinh tế quốc tế đã dẫn đến sự bùng nổ về các loại hình dịch vụ. Ngoài việc góp phần giảm tỉ trọng tiền mặt trong lưu thông, các hình thức dịch vụ mới như thẻ tín dụng, máy rút tiền mặt ATM... đã làm cho cầu tiền phản ứng một cách nhanh hơn trước các diễn biến của lãi suất, tức là đã làm tăng độ co dãn của cầu tiền đối với lãi suất. Một cách tổng quát hơn, việc đổi mới công nghệ ngân hàng trên cơ sở ứng dụng CNTT đã góp phần thúc đẩy sự phát triển của thị trường tài chính, đồng thời đẩy nhanh tốc độ chu chuyển của các luồng vốn, làm cho cung cầu tiền tệ trở nên khó dự báo hơn, cơ chế truyển tải chính sách tiền tệ nhạy cảm hơn. Trong bối cảnh đó, các Ngân hàng Trung ương phải đặc biệt quan tâm đến việc ứng dụng CNTT trong các hoạt động của mình nói chung và trong điều hành chính sách tiền tệ nói riêng. Đề tài đã nghiên cứu và giới thiệu một số sơ đồ chữ ký nhóm được đưa ra từ trước tới nay, cùng với những ứng dụng hữu ích của chữ ký nhóm trong việc tạo ra một thẻ chung của liên minh các ngân hàng nhằm bảo mật thông tin và xác thực thông tin qua mạng. Chữ ký nhóm là một công cụ trợ giúp đắc lực cho việc toàn vẹn thông tin và xác thực thông tin cho những giao dịch trực tuyến. Do hạn chế về thời gian và điều kiện, việc nghiên cứu đề tài mới chỉ là cơ bản. do đó sẽ khó có thể tránh khỏi một vài thiếu sót, rất mong được sự đóng góp ý kiến của quý thầy, cô và các bạn. Đồ án tốt nghiệp Tìm hiểu Chữ kí nhóm và ứng dụng trong giao dịch điện tử Sinh viên: Phạm Thị Hiểu Lớp CT702 62 Tài liệu tham khảo ™ Lý thuyết mật mã và an toàn thông tin – Phan Đình Diệu – NXB Đại Học Quốc Gia Hà Nội 2002 ™ Giáo trình an toàn và bảo mật thông tin trong các hệ thống điều hành sản xuất – Sở bưu chính viễn thông 2005 ™ Jan Camenisch, Jens Groth, Group Signatures : Better Efficiency and New Theoritical Aspects ™ David Chaum, Hans van Antwerpen. Undeniable Signature.CRYPTO ’89 tr 212 – 216. ™ David Chaum, van Heyst. Group signature. Advances in Cryptology – EUROCRYPT ’91,1991 tr 257 – 265 ™ Jan Camenisch. Efficient and Gneralize Group Signatures. Đồ án tốt nghiệp Tìm hiểu Chữ kí nhóm và ứng dụng trong giao dịch điện tử Sinh viên: Phạm Thị Hiểu Lớp CT702 63 MỤC LỤC LỜI NÓI ĐẦU ................................................................................................ 1 Chương I .............................................................................................................................. 2 CÁC KHÁI NIỆM CƠ BẢN .......................................................................... 2 1.1 Cơ sở toán học ............................................................................................................... 2 1.1.1. Ước số - Bội số .......................................................................................................... 2 1.1.2. Số nguyên tố .............................................................................................................. 2 1.1.3. Khái niệm nhóm ........................................................................................................ 2 1.1.4. Nhóm hữu hạn ........................................................................................................... 2 1.1.5. Nhóm con .................................................................................................................. 3 1.1.6. Nhóm Cyclic .............................................................................................................. 3 1.1.7. Các thuật toán trong Z ............................................................................................... 3 1.1.9. Thuật toán Euclide mở rộng ...................................................................................... 4 1.1.10. Định nghĩa hàm Φ Euler .......................................................................................... 4 1.1.11. Đồng dư thức ........................................................................................................... 4 1.1.12. Số nghịch đảo .......................................................................................................... 4 1.1.13. Nhóm nhân Z*n ....................................................................................................... 5 1.1.14. Định nghĩa thặng dư bậc 2 ....................................................................................... 5 1.1.15. Phần dư China CRT ( Chinese Remainder Theorem) ............................................. 5 1.1.16. Độ phức tạp tính toán .............................................................................................. 5 1.1.17. Các thuật toán trong Zn ........................................................................................... 6 1.1.18. Thuật toán ( Tính các nghịch đảo trong Zn ) ........................................................... 6 1.1.19. Hàm một phía - Hàm một phía có cửa sập .............................................................. 8 1.2 Tìm hiểu về mật mã ....................................................................................................... 8 1.2.1. Mã cổ điển ................................................................................................................. 9 1.2.1.1. Mã dịch chuyển .......................................................................................... 10 1.2.1.2. Mã thay thế ................................................................................................. 11 1.2.1.3. Mã Affine ................................................................................................... 12 1.2.1.4. Mã Vingenere ............................................................................................. 13 1.2.1.5. Mã Hill ........................................................................................................ 13 1.2.1.6. Mã hoán vị .................................................................................................. 15 1.2.2. Mã khóa công khai .................................................................................................. 16 1.2.2.1. Mã RSA ...................................................................................................... 17 1.2.2.2. Mã Elgamal ................................................................................................ 18 Chương II ........................................................................................................................... 20 CHỮ KÍ ĐIỆN TỬ ....................................................................................... 20 2.1. Tìm hiểu về chữ ký điện tử ( electronic signature ) .................................................... 20 2.1.1. Khái quát về chữ ký điện tử ? .................................................................................. 20 2.1.2. Định nghĩa về sơ đồ ký điện tử ................................................................................ 21 2.1.3. Sơ đồ chữ ký RSA ................................................................................................... 22 2.1.4. Sơ đồ chữ ký Elgamal .............................................................................................. 23 2.1.5. Sơ đồ chữ ký DSS ................................................................................................... 24 2.2. Chữ ký không thể chối bỏ ........................................................................................... 25 2.3. Chứng minh không tiết lộ thông tin ............................................................................ 26 2.3. Vấn đề ký số trên đại diện văn bản ............................................................................. 27 2.3.1. Sơ lược về hàm băm (Hash Function) ..................................................................... 28 2.3.1.1. Giới thiệu .................................................................................................... 28 Đồ án tốt nghiệp Tìm hiểu Chữ kí nhóm và ứng dụng trong giao dịch điện tử Sinh viên: Phạm Thị Hiểu Lớp CT702 64 2.3.1.2. Định nghĩa hàm Hash ................................................................................. 28 2.3.1.3. Tính chất của hàm băm ............................................................................... 29 2.3.1.4. Thuật toán MD5 ......................................................................................... 29 2.4. Xác thực ...................................................................................................................... 30 Chương III ......................................................................................................................... 32 CHỮ KÝ NHÓM .......................................................................................... 32 3.1. Khái niệm về chữ ký nhóm( Groups Signature ) ....................................................... 32 3.2. Những đặc điểm của chữ ký nhóm ............................................................................. 32 3.2.1. Ta có hệ chữ ký nhóm ............................................................................................. 32 3.2.2. Một sơ đồ chữ ký nhóm gồm thành phần cơ bản ................................................... 33 3.2.3. Một sơ đồ chữ ký nhóm thường bao gồm 5 thủ tục ............................................... 33 3.2.4. Hiệu quả của chữ ký nhóm ...................................................................................... 34 3.2.5. Việc đảm bảo an ninh đối với chữ ký nhóm. ........................................................... 34 3.3. Các sơ đồ chữ ký nhóm của David Chaum và Van Heyst .......................................... 35 3.3.1. Sơ đồ chữ ký nhóm thứ nhất. ................................................................................... 35 3.3.2. Sơ đồ chữ ký nhóm thứ hai ...................................................................................... 35 3.3.2.1. Giao thức xác nhận ..................................................................................... 36 3.3.2.2. Giao thức chối bỏ ....................................................................................... 37 3.3.3. Sơ đồ chữ ký nhóm thứ ba ....................................................................................... 41 3.3.3.1. Vấn đề “ mở ” chữ ký ................................................................................. 41 3.3.3.2. Nhận xét ...................................................................................................... 41 3.4. Sơ đồ chữ ký nhóm của Jan Camenish và Stadler ...................................................... 41 3.4.1. Một số khái niệm cần thiết ...................................................................................... 42 3.4.2. Sơ đồ chữ ký ............................................................................................................ 43 Chương IV ......................................................................................................................... 44 ỨNG DỤNG CHỮ KÝ NHÓM .................................................................... 44 4.1. Tìm hiểu về giao dịch điện tử ..................................................................................... 44 4.2. Thẻ thanh toán điện tử ................................................................................................ 44 4.3.Việc ứng dụng và phát triển công nghệ tại Việt Nam hiện nay ................................... 45 4.4. Chương trình ............................................................................................................... 48 Kết luận ......................................................................................................... 61 Tài liệu tham khảo ....................................................................................... 62 MỤC LỤC ..................................................................................................... 63

Các file đính kèm theo tài liệu này:

  • pdfin_3_ban_844.pdf