When the client and server communicate, there is a very common scenario where an id is passed back and forth as a url parameter. Assuming that the current business only has this ID identifier, then slightly more secure communication is needed to encrypt and transmit this ID, and then decrypt it to the server. A server-side secret key is needed here, and this key is used for encryption and decryption. This article mainly introduces how PHP uses custom keys to encrypt and decrypt data. It involves PHP's techniques for implementing encryption and decryption functions for string conversion, interception and other operations. Friends who need it can refer to it. I hope it can help everyone.
The encryption and decryption methods are as follows: $str is the string that needs to be encrypted and decrypted, $key is a key defined by yourself
// 加密 function encryptStr($str, $key){ $block = mcrypt_get_block_size('des', 'ecb'); $pad = $block - (strlen($str) % $block); $str .= str_repeat(chr($pad), $pad); $enc_str = mcrypt_encrypt(MCRYPT_DES, $key, $str, MCRYPT_MODE_ECB); return base64_encode($enc_str); } // 解密 function decryptStr($str, $key){ $str = base64_decode($str); $str = mcrypt_decrypt(MCRYPT_DES, $key, $str, MCRYPT_MODE_ECB); $block = mcrypt_get_block_size('des', 'ecb'); $pad = ord($str[($len = strlen($str)) - 1]); return substr($str, 0, strlen($str) - $pad); }
Worth it One thing to mention is:
If it is applied to the scenario of id in the URL, then after encryption, it is base64 encoding. It is recommended tourlencode()
to remove the influence of the + sign.
Related recommendations:
php string encryption and decryption implementation process sharing
mysql functions about encryption and decryption
Tutorial on the use of several methods of php encryption and decryption
The above is the detailed content of How does PHP use a custom key to encrypt and decrypt data?. For more information, please follow other related articles on the PHP Chinese website!