Chữ ký số là một cơ chế mã hóa được sử dụng để xác minh tính xác thực và tính toàn vẹn của dữ liệu số. Chúng ta có thể coi nó như một phiên bản kỹ thuật số của chữ ký viết tay thông thường nhưng có mức độ phức tạp và bảo mật cao hơn.

Nói một cách đơn giản, chúng ta có thể mô tả chữ ký số như một mã được đính kèm vào tin nhắn hoặc tài liệu. Sau khi được tạo, mã này đóng vai trò là bằng chứng cho thấy tin nhắn không bị giả mạo trong quá trình truyền từ người gửi đến người nhận.

Mặc dù khái niệm bảo mật thông tin liên lạc bằng mật mã đã có từ xa xưa, nhưng sơ đồ chữ ký số đã trở thành hiện thực vào những năm 1970 - nhờ vào sự phát triển của Mật mã khóa công khai (PKC). Vì vậy, để tìm hiểu cách chữ ký số hoạt động, trước tiên chúng ta cần hiểu những kiến ​​​​thức cơ bản về hàm băm và mật mã khóa công khai.


Hàm băm

Băm là một trong những yếu tố cốt lõi của hệ thống chữ ký số. Quá trình băm bao gồm việc chuyển đổi dữ liệu có kích thước bất kỳ thành đầu ra có kích thước cố định. Điều này được thực hiện bằng một loại thuật toán đặc biệt được gọi là hàm băm. Đầu ra do hàm băm tạo ra được gọi là giá trị băm hoặc thông báo tóm tắt.

Khi kết hợp với mật mã, cái gọi là hàm băm mật mã có thể được sử dụng để tạo ra giá trị băm (thông báo) hoạt động như một dấu vân tay kỹ thuật số duy nhất. Điều này có nghĩa là bất kỳ thay đổi nào trong dữ liệu đầu vào (thông báo) sẽ dẫn đến kết quả đầu ra hoàn toàn khác (giá trị băm). Và đó là lý do hàm băm mật mã được sử dụng rộng rãi để xác minh tính xác thực của dữ liệu số.


Mật mã khóa công khai (PKC)

Mật mã khóa công khai, hay PKC, đề cập đến một hệ thống mật mã sử dụng một cặp khóa: một khóa chung và một khóa riêng. Hai khóa này có liên quan về mặt toán học và có thể được sử dụng cho cả mã hóa dữ liệu và chữ ký số.

Là một công cụ mã hóa, PKC an toàn hơn các phương pháp mã hóa đối xứng thô sơ hơn. Trong khi các hệ thống cũ dựa vào cùng một khóa để mã hóa và giải mã thông tin, PKC cho phép mã hóa dữ liệu bằng khóa chung và giải mã dữ liệu bằng khóa riêng tương ứng.

Ngoài ra, sơ đồ PKC cũng có thể được áp dụng trong việc tạo chữ ký số. Về bản chất, quy trình này bao gồm việc băm một tin nhắn (hoặc dữ liệu số) cùng với khóa riêng của người ký. Tiếp theo, người nhận tin nhắn có thể kiểm tra xem chữ ký có hợp lệ hay không bằng cách sử dụng khóa chung do người ký cung cấp.

Trong một số trường hợp, chữ ký số có thể liên quan đến mã hóa nhưng không phải lúc nào cũng như vậy. Ví dụ: chuỗi khối Bitcoin sử dụng PKC và chữ ký số, nhưng không giống như nhiều người thường tin, không có mã hóa trong quy trình. Về mặt kỹ thuật, Bitcoin triển khai cái gọi là Thuật toán chữ ký số đường cong Elliptic (ECDSA) để xác thực các giao dịch.


Cách chữ ký số hoạt động

Trong bối cảnh tiền điện tử, hệ thống chữ ký số thường bao gồm ba bước cơ bản: băm, ký và xác minh.

Băm dữ liệu

Bước đầu tiên là băm thông điệp hoặc dữ liệu số. Điều này được thực hiện bằng cách gửi dữ liệu thông qua thuật toán băm để tạo ra giá trị băm (tức là bản tóm tắt thông báo). Như đã đề cập, các thông báo có thể có kích thước khác nhau đáng kể, nhưng khi chúng được băm, tất cả các giá trị băm của chúng đều có cùng độ dài. Đây là thuộc tính cơ bản nhất của hàm băm.

Tuy nhiên, việc băm dữ liệu không phải là điều bắt buộc để tạo chữ ký số vì người ta có thể sử dụng khóa riêng để ký một tin nhắn chưa được băm. Nhưng đối với tiền điện tử, dữ liệu luôn được băm vì việc xử lý các bản tóm tắt có độ dài cố định sẽ tạo điều kiện thuận lợi cho toàn bộ quá trình.

Ký tên

Sau khi thông tin được băm, người gửi tin nhắn cần ký tên. Đây là thời điểm mật mã khóa công khai phát huy tác dụng. Có một số loại thuật toán chữ ký số, mỗi loại có cơ chế riêng. Nhưng về cơ bản, tin nhắn được băm sẽ được ký bằng khóa riêng và người nhận tin nhắn sau đó có thể kiểm tra tính hợp lệ của nó bằng cách sử dụng khóa chung tương ứng (do người ký cung cấp).

Nói cách khác, nếu khóa riêng không được bao gồm khi chữ ký được tạo, người nhận tin nhắn sẽ không thể sử dụng khóa chung tương ứng để xác minh tính hợp lệ của nó. Cả khóa chung và khóa riêng đều do người gửi tin nhắn tạo ra, nhưng chỉ có khóa chung được chia sẻ với người nhận.

Điều đáng chú ý là chữ ký số có liên quan trực tiếp đến nội dung của từng tin nhắn. Vì vậy, không giống như chữ ký viết tay có xu hướng giống nhau bất kể tin nhắn nào, mỗi tin nhắn được ký điện tử sẽ có một chữ ký điện tử khác nhau.

Đang xác minh

Hãy lấy một ví dụ để minh họa toàn bộ quá trình cho đến bước xác minh cuối cùng. Hãy tưởng tượng Alice viết một tin nhắn cho Bob, băm nó và sau đó kết hợp giá trị băm với khóa riêng của cô ấy để tạo chữ ký số. Chữ ký sẽ hoạt động như một dấu vân tay kỹ thuật số duy nhất của tin nhắn cụ thể đó.

Khi Bob nhận được tin nhắn, anh ta có thể kiểm tra tính hợp lệ của chữ ký số bằng cách sử dụng khóa chung do Alice cung cấp. Bằng cách này, Bob có thể chắc chắn rằng chữ ký được tạo bởi Alice vì chỉ có cô ấy mới có khóa riêng tương ứng với khóa chung đó (ít nhất đó là những gì chúng ta mong đợi).

Vì vậy, điều quan trọng đối với Alice là giữ bí mật khóa riêng của mình. Nếu người khác có được khóa riêng của Alice, họ có thể tạo chữ ký điện tử và giả vờ là Alice. Trong bối cảnh Bitcoin, điều này có nghĩa là ai đó có thể sử dụng khóa riêng của Alice để di chuyển hoặc tiêu Bitcoin mà không có sự cho phép của cô ấy.


Tại sao chữ ký số lại quan trọng?

Chữ ký số thường được sử dụng để đạt được ba kết quả: tính toàn vẹn dữ liệu, xác thực và chống chối bỏ.

  • Toàn vẹn dữ liệu. Bob có thể xác minh rằng tin nhắn của Alice không bị thay đổi trong quá trình gửi. Bất kỳ sửa đổi nào trong tin nhắn sẽ tạo ra một chữ ký hoàn toàn khác.

  • Tính xác thực. Miễn là khóa riêng của Alice được giữ bí mật, Bob có thể sử dụng khóa chung của cô ấy để xác nhận rằng chữ ký số được tạo bởi Alice chứ không phải ai khác.

  • Không bác bỏ. Khi chữ ký đã được tạo, Alice sẽ không thể phủ nhận việc đã ký nó trong tương lai, trừ khi khóa riêng của cô ấy bị xâm phạm bằng cách nào đó.


Trường hợp sử dụng

Chữ ký số có thể được áp dụng cho nhiều loại tài liệu và chứng chỉ số. Như vậy, họ có một số ứng dụng. Một số trường hợp sử dụng phổ biến nhất bao gồm:

  • Công nghệ thông tin. Để tăng cường tính bảo mật của hệ thống truyền thông Internet.

  • Tài chính. Chữ ký số có thể được triển khai để kiểm toán, báo cáo chi phí, thỏa thuận cho vay, v.v.

  • Hợp pháp. Ký kỹ thuật số tất cả các loại hợp đồng kinh doanh và thỏa thuận pháp lý, bao gồm cả các giấy tờ của chính phủ.

  • Chăm sóc sức khỏe. Chữ ký số có thể ngăn ngừa gian lận đơn thuốc và hồ sơ y tế.

  • Chuỗi khối. Sơ đồ chữ ký số đảm bảo rằng chỉ những chủ sở hữu hợp pháp của tiền điện tử mới có thể ký giao dịch để chuyển tiền (miễn là khóa riêng của họ không bị xâm phạm).


Hạn chế

Những thách thức chính mà các sơ đồ chữ ký số phải đối mặt phụ thuộc vào ít nhất ba yêu cầu:

  • Thuật toán. Chất lượng của các thuật toán được sử dụng trong sơ đồ chữ ký số là rất quan trọng. Điều này bao gồm việc lựa chọn các hàm băm và hệ thống mật mã đáng tin cậy.

  • Thực hiện. Nếu thuật toán tốt nhưng việc triển khai không tốt thì hệ thống chữ ký số có thể sẽ xuất hiện sai sót.

  • Khóa riêng. Nếu khóa riêng bị rò rỉ hoặc bị xâm phạm bằng cách nào đó, các thuộc tính xác thực và chống chối bỏ sẽ bị vô hiệu. Đối với người dùng tiền điện tử, việc mất khóa riêng có thể dẫn đến tổn thất tài chính đáng kể.


Chữ ký điện tử so với chữ ký số

Nói một cách đơn giản, chữ ký số liên quan đến một loại chữ ký điện tử cụ thể - đề cập đến bất kỳ phương thức điện tử nào để ký tài liệu và tin nhắn. Vì vậy, tất cả chữ ký số đều là chữ ký điện tử, nhưng điều ngược lại không phải lúc nào cũng đúng.

Sự khác biệt chính giữa chúng là phương pháp xác thực. Chữ ký số triển khai các hệ thống mật mã, chẳng hạn như hàm băm, mật mã khóa công khai và kỹ thuật mã hóa.


Bớt tư tưởng

Hàm băm và mật mã khóa công khai là cốt lõi của hệ thống chữ ký số, hiện được áp dụng cho nhiều trường hợp sử dụng. Nếu được triển khai đúng cách, chữ ký số có thể tăng cường tính bảo mật, đảm bảo tính toàn vẹn và tạo điều kiện thuận lợi cho việc xác thực tất cả các loại dữ liệu số.

Trong lĩnh vực blockchain, chữ ký số được sử dụng để ký và ủy quyền các giao dịch tiền điện tử. Chúng đặc biệt quan trọng đối với Bitcoin vì chữ ký đảm bảo rằng tiền chỉ có thể được sử dụng bởi những cá nhân sở hữu khóa riêng tương ứng.

Mặc dù chúng tôi đã sử dụng cả chữ ký điện tử và chữ ký số trong nhiều năm nhưng vẫn còn rất nhiều cơ hội để phát triển. Phần lớn bộ máy quan liêu ngày nay vẫn dựa trên thủ tục giấy tờ, nhưng chúng ta có thể sẽ thấy nhiều sơ đồ chữ ký số được áp dụng hơn khi chúng ta chuyển sang một hệ thống số hóa hơn.