ホームページ > バックエンド開発 > PHPチュートリアル > PHP は AES 暗号化クラスの定義と使用法を実装します

PHP は AES 暗号化クラスの定義と使用法を実装します

小云云
リリース: 2023-03-19 19:24:01
オリジナル
3673 人が閲覧しました

この記事では、PHP で実装された AES 暗号化クラスの定義と使用法を主に紹介し、完全な例の形式で AES 暗号化クラスの実装と使用法を分析します。それはすべての人を助けることができます。

CryptAES.class.php ファイル:


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

<?php

class CryptAES

{

 protected $cipher = MCRYPT_RIJNDAEL_128;

 protected $mode = MCRYPT_MODE_ECB;

 protected $pad_method = NULL;

 protected $secret_key = &#39;&#39;;

 protected $iv = &#39;&#39;;

 public function set_cipher($cipher)

 {

 $this->cipher = $cipher;

 }

 public function set_mode($mode)

 {

 $this->mode = $mode;

 }

 public function set_iv($iv)

 {

 $this->iv = $iv;

 }

 public function set_key($key)

 {

 $this->secret_key = $key;

 }

 public function require_pkcs5()

 {

 $this->pad_method = &#39;pkcs5&#39;;

 }

 protected function pad_or_unpad($str, $ext)

 {

 if ( is_null($this->pad_method) )

 {

  return $str;

 }

 else

 {

  $func_name = __CLASS__ . &#39;::&#39; . $this->pad_method . &#39;_&#39; . $ext . &#39;pad&#39;;

  if ( is_callable($func_name) )

  {

  $size = mcrypt_get_block_size($this->cipher, $this->mode);

  return call_user_func($func_name, $str, $size);

  }

 }

 return $str;

 }

 protected function pad($str)

 {

 return $this->pad_or_unpad($str, &#39;&#39;);

 }

 protected function unpad($str)

 {

 return $this->pad_or_unpad($str, &#39;un&#39;);

 }

 public function encrypt($str)

 {

 $str = $this->pad($str);

 $td = mcrypt_module_open($this->cipher, &#39;&#39;, $this->mode, &#39;&#39;);

 if ( empty($this->iv) )

 {

  $iv = @mcrypt_create_iv(mcrypt_enc_get_iv_size($td), MCRYPT_RAND);

 }

 else

 {

  $iv = $this->iv;

 }

 mcrypt_generic_init($td, $this->secret_key, $iv);

 $cyper_text = mcrypt_generic($td, $str);

 //$rt=base64_encode($cyper_text);

 $rt = bin2hex($cyper_text);

 mcrypt_generic_deinit($td);

 mcrypt_module_close($td);

 return $rt;

 }

 public function decrypt($str){

 $td = mcrypt_module_open($this->cipher, &#39;&#39;, $this->mode, &#39;&#39;);

 if ( empty($this->iv) )

 {

  $iv = @mcrypt_create_iv(mcrypt_enc_get_iv_size($td), MCRYPT_RAND);

 }

 else

 {

  $iv = $this->iv;

 }

 mcrypt_generic_init($td, $this->secret_key, $iv);

 $decrypted_text = mdecrypt_generic($td, self::hex2bin($str));

 //$decrypted_text = mdecrypt_generic($td, base64_decode($str));

 $rt = $decrypted_text;

 mcrypt_generic_deinit($td);

 mcrypt_module_close($td);

 return $this->unpad($rt);

 }

 public static function hex2bin($hexdata) {

 $bindata = &#39;&#39;;

 $length = strlen($hexdata);

 for ($i=0; $i < $length; $i += 2)

 {

  $bindata .= chr(hexdec(substr($hexdata, $i, 2)));

 }

 return $bindata;

 }

 public static function pkcs5_pad($text, $blocksize)

 {

 $pad = $blocksize - (strlen($text) % $blocksize);

 return $text . str_repeat(chr($pad), $pad);

 }

 public static function pkcs5_unpad($text)

 {

 $pad = ord($text{strlen($text) - 1});

 if ($pad > strlen($text)) return false;

 if (strspn($text, chr($pad), strlen($text) - $pad) != $pad) return false;

 return substr($text, 0, -1 * $pad);

 }

}

?>

ログイン後にコピー

使用法:


1

2

3

4

5

6

7

require_once("CryptAES.class.php");

$keyStr = &#39;ss4fs4skfhksk&#39;;

$aes = new CryptAES();

$keyStr = $aes->hex2bin($keyStr);

$aes->set_key($keyStr);

$aes->require_pkcs5();

$d = $aes->encrypt($data);

ログイン後にコピー

注: これは php.ini で開く必要があります: extension=php_mcrypt.dll

関連する推奨事項:

方法MySQL について AES_ENCRYPT() と AES_DECRYPT() を正しく使って暗号化と復号化を行う

Java の SHA1PRNG 方式の暗号化に対応する AES 暗号化の詳細説明

php で実装される AES 暗号化クラス

以上がPHP は AES 暗号化クラスの定義と使用法を実装しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート