>  기사  >  백엔드 개발  >  PHP 암호화 확장 라이브러리 Mcrypt 설치 및 예제

PHP 암호화 확장 라이브러리 Mcrypt 설치 및 예제

怪我咯
怪我咯원래의
2017-07-05 10:56:021509검색

PHP 암호화 확장 라이브러리에는 Mcrypt 및 Mhash가 포함됩니다. 그중 Mcrypt 확장 라이브러리는 암호화 및 암호 해독 기능을 구현할 수 있습니다. 오늘은 Mcrypt의 기능과 예에 대해 이야기합니다.

PHP 프로그래머가 코드 프로그램을 작성할 때. , 코드의 고성능을 보장하는 것 외에도 또 다른 중요한 점은 프로그램의 보안입니다. 여러 가지 자체 암호화 기능 외에도 PHP에는 더욱 포괄적인 PHP 암호화 확장 라이브러리인 Mcrypt 및 Mhash가 있습니다.
그 중 Mcrypt 확장 라이브러리는 암호화 및 복호화 기능을 실현할 수 있습니다. 즉, 일반 텍스트를 암호화하고 암호문을 복원할 수 있습니다.
mcrypt는 PHP의 중요한 암호화 지원 확장 라이브러리입니다. Linux 환경에서는 이 라이브러리가 기본적으로 활성화되어 있지 않습니다. 윈도우 환경: PHP>=5.3에서는 mcrypt 확장이 기본적으로 활성화됩니다.
1. Mcrypt() 라이브러리 설치
mcypt는 매우 강력한 암호화 알고리즘 확장 라이브러리입니다. Mcrypt는 표준 PHP 설치 프로세스 중에 설치되지 않지만 libmcrypt.dll 파일은 PHP 홈 디렉터리에 포함되어 있으므로 PHP 구성 파일의 이 줄에서 Extension=php_mcrypt.dll 앞에 있는 세미콜론만 제거하면 됩니다. 을 클릭한 다음 서버를 다시 시작하여 이 확장 라이브러리를 사용하세요.
지원되는 알고리즘 및 암호화 모드
Mcrypt 라이브러리는 20개 이상의 암호화 알고리즘과 8개의 암호화 모드를 지원합니다. 특히
mcrypt_list_algorithms() 및 mcrypt_list_modes() 함수를 통해 [1]개의 암호화 알고리즘을 표시할 수 있습니다. Mcrypt에서 지원하는 알고리즘 은:
cast-128
gost
rijndael-128
twofish
arcfour
cast-256
loki97
rijndael-192
saferplus
wake
blowfish-compat
des
rijndael-256
serpent
xtea
복어
enigma
rc2
tripledes
암호화 모드
Mcrypt에서 지원하는 암호화 모드는 다음과 같습니다:
cbc
cfb
ctr
ecb
ncfb
nofb
ofb
stream
이러한 알고리즘과 모드는 애플리케이션에서 상수로 표현되어야 하며 접두사 MCRYPT_가 추가됩니다. MCRYPT_를 작성할 때 아래

Mcrypt 애플리케이션 예시

DES 알고리즘은 MCRYPT_DES로 표현됩니다.

ECB 모드는 MCRYPT_MODE_ECB로 표현됩니다.

코드는 다음과 같습니다.

<?php
$str = "我的名字是?一般人我不告诉他!"; //加密内容
$key = "key:111"; //密钥
$cipher = MCRYPT_DES; //密码类型
$modes = MCRYPT_MODE_ECB; //密码模式
$iv = mcrypt_create_iv(mcrypt_get_iv_size($cipher,$modes),MCRYPT_RAND);//初始化向量
echo "加密明文:".$str."<p>";
$str_encrypt = mcrypt_encrypt($cipher,$key,$str,$modes,$iv); //加密函数
echo "加密密文:".$str_encrypt." <p>";
$str_decrypt = mcrypt_decrypt($cipher,$key,$str_encrypt,$modes,$iv); //解密函数
echo "还原:".$str_decrypt;
?>

실행 결과:

Encrypted 일반 텍스트: 내 이름은 무엇입니까? 나는 대부분의 사람들에게 말하지 않습니다!
암호화된 암호문: 锍??]??q???L 웃어??"? ?
복원: 내 이름은 무엇입니까? 일반인에게는 안 알려드려요!
f35d6e602fd7d0f0edfa6f7d103c1b57예제에서 보시다시피, PHP 사용 암호화 확장 라이브러리 Mcrypt는 데이터를 암호화하고 해독하기 전에 먼저 iv라고 하는 초기화 벡터를 생성합니다. $iv = mcrypt_create_iv(mcrypt_get_iv_size($cipher,$modes),MCRYPT_RAND); 초기화 벡터에는 두 가지 매개변수가 필요합니다. size iv의 크기는 iv의 소스이며, 여기서 MCRYPT_RAND 값은 시스템 난수입니다.
2cc198a1d5eb0d3eb508d858c9f5cbdb 함수 mcrypt_get_iv_size($cipher,$modes)는 초기화 벡터를 반환합니다. size, 매개변수 cipher 및 mode는 각각 알고리즘과 암호화 모드를 나타냅니다. $str_encrypt($cipher,$key,$str,$modes,$iv); 함수는 다음과 같습니다: cipher——암호화 알고리즘, 키——key, 데이터(str)——암호화할 데이터, 모드——알고리즘 모드, iv——초기화 벡터
23889872c2e8594e0f446a471a78ec4c $key,$str_encrypt,$modes,$iv); 이 함수와 암호화
함수의 매개변수는 거의 동일하며 유일한 차이점은 데이터입니다. 즉, 데이터는 원래 데이터가 아닌 $str_encrypt를 복호화할 데이터입니다. $str.
참고: 암호화 및 암호 해독 기능의 매개변수 암호, 키 및 모드는 동일해야 합니다. 그렇지 않으면 데이터를 복원할 수 없습니다. 요약
mcrypt 라이브러리 상수

Mcrypt 라이브러리는 20개 이상의 암호화 알고리즘을 지원합니다. 8가지 암호화 모드는 mcrypt_list_algorithms() 및 mcrypt_list_modes()

함수를 통해 볼 수 있습니다.

위 내용은 PHP 암호화 확장 라이브러리 Mcrypt 설치 및 예제의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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