>백엔드 개발 >파이썬 튜토리얼 >Python md5 및 sha1 암호화 알고리즘에 대한 자세한 소개

Python md5 및 sha1 암호화 알고리즘에 대한 자세한 소개

零下一度
零下一度원래의
2017-07-16 13:55:053007검색

이 글에서는 md5 레벨 sha1 암호화 알고리즘의 개념과 원리를 간략하게 소개하고, 이를 예시 형태로 분석합니다. Python hashlib 모듈을 사용하여 암호화 기능을 구현하는 구체적인 운영 기술이 필요한 친구들은 참고할 수 있습니다

만약 md5, sha1 암호화된 내용이 너무 많으니 이렇게 사용하시면 됩니다:

[python]  
m = hashlib.md5()  
m.update('a')  
m.update('b')  
s = m.hexdigest()  
#效果等于m = hashlib.md6('ab').hexd

MD5

MD5의 풀네임은 Message-Digest Algorithm 5(Message-AbstractAlgorithm)인데, 1990년대 초 MIT 컴퓨터 과학 연구소 및 RSA 데이터에서 개발되었으며 Security Inc의 Ronald L. Rivest가 개발했으며 MD2, MD3 및 MD4에서 개발되었습니다. 이는 되돌릴 수 없는 암호화 알고리즘입니다. 현재 가장 신뢰할 수 있는 암호화 알고리즘 중 하나입니다. 작업을 되돌릴 수 있는 프로그램은 아직 개발되지 않았습니다. 문자열을 고유한 고정 길이 코드로 암호화할 수 있습니다.

특징:

우선, MD5 코드의 원본 텍스트가 무엇인지 알 수 있는 체계적인 방법이 없습니다.

두 번째로, 이 코드는 매우 이산적이며 따라야 할 규칙이 없습니다. 원본 정보의 작은 변화라도 MD5에서는 큰 변화로 이어질 것입니다. 생성된 MD5 코드는 예측할 수 없다고도 할 수 있습니다.

마지막으로 이 코드는 128비트 길이이므로 모든 메시지 간에 동일한 MD5 코드가 포함될 가능성은 매우 낮으며 일반적으로 불가능하다고 간주됩니다.

용도:

일반적으로 MD5 코드는 원본 정보의 특성을 고유하게 표현할 수 있다고 믿어지며 일반적으로 비밀번호의 암호화 저장, 디지털 서명, 파일 무결성 확인 등에 사용됩니다.

SHA1

SHA1의 전체 이름은 Secure Hash Algorithm(SecureHash 알고리즘)입니다. NIST NSA에서 DSA와 함께 사용하도록 설계되었으며 길이가 264보다 작은 입력에 대해 길이가 160비트인 해시 값을 생성합니다. 무차별 대입에 저항하는 것이 더 좋습니다. SHA-1은 MD4와 동일한 원리를 기반으로 설계되었으며 이 알고리즘을 모방합니다. SHA-1은 NIST(National Institute of Standards and Technology)에서 발표한 국가 표준으로, 현재 가장 널리 사용되는 해시 함수 알고리즘이자 가장 발전된 암호화 기술로 정부 부서와 개인 소유자가 민감한 정보를 처리하는 데 사용됩니다. . SHA-1은 MD4를 기반으로 하는 MD5를 기반으로 합니다. SHA-1은 MD5보다 암호문 비트가 32개 더 많아 더 안전합니다. 같은 이유로 MD5는 SHA-1보다 빠르게 작동합니다.

사용 예: Python의 hashlib 모듈은 해시 알고리즘을 특별히 제공하는 라이브러리입니다. 이제 md5, sha1, sha224, sha256, sha384 및 sha512가 포함되어 있습니다. 사용법은 다음과 같습니다:

import hashlib
hash_new = hashlib.sha1() #或hashlib.md5()
with open('driver.xml.tar.bz2','rb') as fp: #打开文件,一定要以二进制打开
  while True:
    data = fp.read() #读取文件块
    if not data: #直到读完文件
      break
    hash_new.update(data)
hash_value = hash_new.hexdigest() #生成40位(sha1)或32位(md5)的十六进制字符串
print hash_value

위 내용은 Python md5 및 sha1 암호화 알고리즘에 대한 자세한 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.