> 백엔드 개발 > 파이썬 튜토리얼 > 추가 비밀 공유 및 공유 자동화 - Python 사용

추가 비밀 공유 및 공유 자동화 - Python 사용

WBOY
풀어 주다: 2023-08-18 15:05:45
앞으로
1676명이 탐색했습니다.

추가 비밀 공유는 비밀을 참가자 그룹에게 공유하는 방법으로, 특정 수의 참가자가 모여 공유를 기여해야만 비밀을 재구성할 수 있습니다. 이 기술은 암호화 및 보안 다자간 계산에 널리 사용됩니다. 이 기사에서는 추가 비밀 공유 및 공유 사전 활성화의 개념과 Python을 사용하여 이를 구현하는 방법에 대해 논의합니다.

추가 비밀 공유 소개

추가 비밀 공유는 개인 참가자에게 비밀을 공개하지 않고 그룹 참가자가 비밀을 공유할 수 있는 기술입니다. 비밀은 공유로 나누어지며, 각 참가자는 하나씩 받습니다. 비밀은 특정 수의 참가자가 모여서 공유를 제공할 때만 재구성될 수 있습니다. 이 기술은 임계값 비밀 공유라고도 합니다.

덧셈 비밀 공유의 기본 아이디어는 비밀을 차수(t-1)의 다항식으로 표현하는 것입니다. 여기서 t는 임계값입니다. 다항식의 계수를 임의의 정수로 선택합니다. 그런 다음 각 참가자에게는 자신의 몫을 나타내는 다항식의 점이 할당됩니다. 참가자가 제공한 포인트를 사용하여 보간함으로써 비밀을 재구성할 수 있습니다.

예를 들어 A, B, C 세 명의 참가자가 공유하고 싶은 비밀 S가 있다고 가정해 보겠습니다. 우리는 임의의 계수를 갖는 2차 다항식을 선택합니다. 이 다항식은 S(x) = a0 + a1x + a2x^2로 표현됩니다. 그런 다음 각 참가자에게 다항식의 점 (x, S(x))이 할당됩니다. 여기서 x는 각 참가자에 대해 선택된 고유 값입니다.

Participant A receives the point (1, S(1))
Participant B receives the point (2, S(2))
Participant C receives the point (3, S(3))
로그인 후 복사

이제 두 명의 참가자가 함께 모여 자신의 점수를 제공하면 다항식과 비밀을 재구성할 수 있습니다. 그러나 단일 참가자가 자신의 포인트만 제공하는 경우 비밀을 재구성할 수 없습니다.

Python에서 추가 비밀 공유 구현

Python에서 추가 비밀 공유를 구현하려면 임계값 비밀 공유를 구현하는 사용하기 쉬운 API를 제공하는 "secretsharing"이라는 Python 라이브러리를 사용할 수 있습니다. 라이브러리는 비밀, 공유 수 및 임계값을 입력으로 받아들이고 공유 목록을 반환하는 "split_secret"이라는 함수를 제공합니다.

다음은 "split_secret" 기능을 사용하여 세 참가자 간에 비밀을 공유하는 예입니다. -

from secretsharing import SecretSharer

# Secret to be shared
secret = "mysecret"

# Number of shares to be generated
n = 3

# Threshold value
t = 2

# Generate shares
shares = SecretSharer.split_secret(secret, n, t)

# Print the shares
for share in shares:
   print(share)
로그인 후 복사

위 예에는 세 당사자가 공유하고 싶은 비밀 "mysecret"이 있습니다. 참가자들 사이에서. 임계값을 2로 설정했는데, 이는 두 명의 참가자가 비밀을 재구성할 수 있음을 의미합니다. "split_secret" 함수는 세 개의 공유를 생성하고 인쇄합니다.

Reconstruct Secret

비밀을 재구성하려면 "secretsharing" 라이브러리에서 제공하는 "recover_secret" 기능을 사용할 수 있습니다. 이 함수는 공유 목록을 입력으로 받아들이고 비밀을 반환합니다. 다음은 "recover_secret" 함수를 사용하여 비밀을 재구성하는 예입니다.

from secretsharing import SecretSharer

# List of shares
shares = ["1-mysecret", "2-mysecret", "3-mysecret"]

# Reconstruct the secret
secret = SecretSharer.recover_secret(shares)

print(secret)
로그인 후 복사

위의 예에는 비밀을 재구성하는 데 사용할 주식 목록이 있습니다. "recover_secret" 함수는 주식 목록을 입력으로 받아 비밀을 반환합니다. 이 예에서 비밀은 "mysecret"입니다.

공유 활성화 소개

공유 활성화는 참가자 그룹이 비밀을 공개하지 않고 적극적으로 공유를 새로 고칠 수 있는 기술입니다. 이 기술은 공유 비밀번호의 경우와 같이 비밀을 자주 변경해야 하는 상황에서 사용됩니다.

공유 활성화의 기본 아이디어는 각 참가자가 새로운 비밀에 대한 새로운 공유를 생성하여 다른 사람에게 보내는 것입니다. 그런 다음 새 공유가 결합되어 새 비밀을 재구성합니다. 이전 공유는 삭제되고 새 공유는 새로운 비밀을 재구성하는 데 사용됩니다.

Python에서 공유 사전 활성화 구현

Python에서 공유 사전 활성화를 구현하려면 추가 비밀 공유와 동일한 "비밀 공유" 라이브러리를 사용할 수 있습니다. 라이브러리는 비밀 및 고유 공유 ID를 입력으로 받아들이고 새 비밀 공유를 반환하는 "create_share"라는 함수를 제공합니다.

다음은 "create_share" 기능을 사용하여 공유를 적극적으로 새로 고치는 예입니다. -

from secretsharing import SecretSharer

# New secret
new_secret = "mynewsecret"

# Share ID
share_id = "1"

# Create a new share
new_share = SecretSharer.create_share(new_secret, share_id)

print(new_share)
로그인 후 복사

위 예에는 세 명의 참가자 간에 공유하려는 새로운 비밀 "mynewsecret"이 있습니다. 또한 새 공유를 생성할 참가자를 나타내는 공유 ID "1"이 있습니다. "create_share" 함수는 새 비밀 및 공유 ID를 입력으로 받아들이고 비밀의 새 공유를 반환합니다.

새 비밀을 재구성하려면 이전과 동일한 "recover_secret" 기능을 사용할 수 있습니다. 그러나 이번에는 각 참가자가 생성한 새로운 공유를 사용합니다.

from secretsharing import SecretSharer

# List of new shares
new_shares = ["1-mynewsecret", "2-mysecret", "3-mysecret"]

# Reconstruct the new secret
new_secret = SecretSharer.recover_secret(new_shares)

print(new_secret)
로그인 후 복사

위의 예에는 새로운 비밀을 재구성하는 데 사용할 새로운 재고 목록이 있습니다. "recover_secret" 함수는 새 주식 목록을 입력으로 사용하고 새 비밀(이 경우 "mynewsecret")을 반환합니다.

결론

추가 비밀 공유 및 공유 자동화는 참가자 그룹 간에 민감한 정보를 안전하게 공유하는 데 사용할 수 있는 강력한 기술입니다. Python의 "secretsharing" 라이브러리는 이러한 기술을 구현하기 위한 사용하기 쉬운 API를 제공합니다. "split_secret" 및 "create_share" 기능을 사용하면 추가 비밀 공유 및 공유 자동화를 각각 쉽게 구현할 수 있습니다. 또한 "recover_secret" 기능을 사용하면 비밀 또는 새로운 비밀을 쉽게 재구성할 수 있습니다.

위 내용은 추가 비밀 공유 및 공유 자동화 - Python 사용의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:tutorialspoint.com
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿