> 백엔드 개발 > PHP 튜토리얼 > PHP 암호화 확장 라이브러리 - Mcrypt 확장 라이브러리 사용 예

PHP 암호화 확장 라이브러리 - Mcrypt 확장 라이브러리 사용 예

黄舟
풀어 주다: 2023-03-07 12:56:01
원래의
4259명이 탐색했습니다.

PHP 암호화 확장 라이브러리—Mcrypt 확장 라이브러리

이 기사의 본문을 시작하기 전에 먼저 PHP 암호화 확장 라이브러리가 무엇인지 이해해 보겠습니다. 여러 암호화 기능(md5, crypt, sha1) 외에도 PHP에는 포괄적인 암호화 확장 라이브러리도 있습니다! PHP가 원래 특정 기능의 동작을 지원하지 않는 것처럼, 새 버전에서 지원하고 싶다면 확장해서 제공하면 됩니다. 이런 식으로 PHP를 구성할 때 이 기능을 사용하지 않으면, PHP가 로드되는 것을 방지할 수 있으므로 서버 리소스가 절약되고 성능이 향상됩니다.

이전 세 편의 글에서 "PHP 암호화 기능 - crypt() 기능 암호화", "PHP 암호화 기능 - md5() 기능 암호화" 그리고 "PHP 암호화 기능—sha1() 함수 암호화"에서 PHP 암호화 기능을 소개했으니 다음에는 PHP 암호화 확장 라이브러리를 소개하겠습니다!

PHP 암호화 확장 라이브러리는 Mcrypt와 Mhash 두 가지가 있습니다. 이번 글에서는 먼저 Mcrypt를 소개하겠습니다!

1. Mcrypt 라이브러리 설치

mcypt는 매우 강력한 암호화 알고리즘 확장 라이브러리입니다. Mcrypt는 표준 PHP 설치 프로세스 중에 설치되지 않지만 libmcrypt.dll 파일은 PHP 홈 디렉터리에 포함되어 있으므로 PHP 구성 파일에서 "Remove it" 줄 앞에 있는 세미콜론만 사용합니다. 을 클릭한 다음 서버를 다시 시작하여 이 확장 라이브러리를 사용하세요.

2.Mcrypt 라이브러리 상수

mcrypt 라이브러리는 20개 이상의 암호화 알고리즘과 8개 이상의 암호화 모드를 지원하며 mcrypt_list_algorithms() 및 mcrypt_list_modes( ) 함수를 직접 사용할 수 있습니다. 보려면 구체적인 코드는 다음과 같습니다.

<?php
$atr = mcrypt_list_algorithms();  //函数返回 Mcrypt支持的加密算法数组
echo "支持算法有:";
foreach ($atr as $atr_value){
    echo "<br>".$atr_value;
}
$arr = mcrypt_list_modes();     //函数返回 Mcrypt支持的加密模式数组
echo "<p>支持加密模式有:";
foreach ($arr as $arr_value){
    echo "<br>".$arr_value;
}
?>
로그인 후 복사

출력 결과는 다음과 같습니다.

PHP 암호화 확장 라이브러리 - Mcrypt 확장 라이브러리 사용 예

참고: 이러한 알고리즘은 실제 응용에서는 이를 표현하기 위해 상수를 사용해야 합니다. 작성 시 MCRYPT_ 및 MCRYPT_MODE_라는 접두어를 추가하여 표현해야 합니다. 예:

TWOFISH 알고리즘은 MCRYPT_TWOFISH로 표현됩니다.

CBC 암호화 모드는 MCRYPT_MODE_CBC로 표현됩니다.

3. Mcrypt 애플리케이션

md5(), sha1() 및 기타 기능을 사용하지 않으려면 Mcrypt를 사용하세요. 직접적으로. Mcrypt의 작업 흐름을 모두가 명확하게 이해할 수 있도록 코드로 직접 소개하겠습니다. 구체적인 코드는 다음과 같습니다.

<?php
header("Content-Type:text/html; charset=utf-8");
$str = "被加密的内容:PHH中文网www.php.cn";  //加密文本
$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."<p>";
?>
로그인 후 복사

출력 결과는

PHP 암호화 확장 라이브러리 - Mcrypt 확장 라이브러리 사용 예

아래에서는 위의 예에 나타나는 여러 기능을 소개합니다.

1.mcrypt_create_iv:

The 구문 형식은 다음과 같습니다.

string mcrypt_create_iv ( int $size [, int $source = MCRYPT_DEV_URANDOM ] )
로그인 후 복사

데이터 암호화에는 Mcrypt를 사용하세요. 복호화 전에 초기화 벡터(iv라고 함)를 먼저 생성해야 합니다. 초기화 벡터를 생성하려면 두 개의 매개변수가 필요합니다. size는 iv의 크기를 지정하고 source는 iv의 소스입니다. 소스는 다음 값을 취할 수 있습니다:

  • MCRYPT_RAND: 시스템 난수.

  • MCRYPT_DEV_RANDOM: /dev/random 디렉터리의 데이터를 읽습니다(UNIX 시스템).

  • MCRYPT_DEV_URANDOM: /dev/urandom 디렉터리의 데이터를 읽습니다(UNIX 시스템).

2.mcrypt_get_iv_size:

구문 형식:

int mcrypt_get_iv_size ( string $cipher , string $mode )
로그인 후 복사

이 반환된 초기화 벡터(iv)의 크기 기능. 함수의 두 매개변수는 앞서 소개한 암호화 알고리즘(cipher)과 암호화 모드(mode)입니다.

3.mcrypt_encrypt:

구문 형식은 다음과 같습니다.

string mcrypt_encrypt ( string $cipher , string $key , string $data , string $mode [, string $iv ] )
로그인 후 복사

벡터를 초기화한 후 mcrypt_encrypt() 암호화 기능을 사용할 수 있습니다. 이 함수의 5개 매개변수의 의미는 다음과 같습니다.

(1)암호화: 암호화 알고리즘. 위의 예에서는 $cipher 변수입니다. 여기의 암호화 알고리즘은 초기화 벡터의 암호화 알고리즘과 다를 수 있습니다.

(2)키: 열쇠. 위 예의 변수 $key입니다.

(3)모드: 암호화 모드.

(4)iv: 초기화 벡터.

4.mcrypt_decrypt

구문 형식은 다음과 같습니다.

string mcrypt_decrypt ( string $cipher , string $key , string $data , string $mode [, string $iv ] )
로그인 후 복사

복호화 함수 mcrypt_decrypt() 및 암호화 함수 mcrypt_encrypt( ) 거의 똑같습니다. 유일한 차이점은 매개변수 데이터입니다. 여기서 데이터는 원본 데이터가 아니라 해독해야 하는 데이터입니다.

참고: 암호화 기능과 복호화 기능의 암호, 키 및 모드 매개변수는 일관되어야 합니다. 그렇지 않으면 데이터가 복원되지 않습니다.

다음 기사에서는 계속해서 PHP 암호화 확장 라이브러리인 Mhash 확장 라이브러리를 소개하겠습니다. 자세한 내용은 "PHP 암호화 확장 라이브러리 - Mhash 확장 라이브러리 "를 참조하세요. !

【관련 추천】

1. 관련 주제 추천 : "PHP 암호화 기능"

2.PHP 암호화 확장 라이브러리-Mhash 확장 라이브러리 상세 사용 예



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

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