You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

72 lines
1.8 KiB

7 years ago
  1. <?php
  2. /**
  3. * 加密工具类
  4. *
  5. * User: jiehua
  6. * Date: 16/3/30
  7. * Time: 下午3:25
  8. */
  9. /**
  10. * 加密方法
  11. * 方法名本来是encrypt,与laravel冲突改成encrypt_laravel,by FLi
  12. * @param string $str
  13. * @return string
  14. */
  15. function encrypt_laravel($str,$screct_key){
  16. //AES, 128 模式加密数据 CBC
  17. $screct_key = base64_decode($screct_key);
  18. $str = trim($str);
  19. $str = addPKCS7Padding($str);
  20. $iv = mcrypt_create_iv(mcrypt_get_iv_size(MCRYPT_RIJNDAEL_128,MCRYPT_MODE_CBC),1);
  21. $encrypt_str = mcrypt_encrypt(MCRYPT_RIJNDAEL_128, $screct_key, $str, MCRYPT_MODE_CBC);
  22. return base64_encode($encrypt_str);
  23. }
  24. /**
  25. * 解密方法
  26. * 方法名本来是decrypt,与laravel冲突改成decrypt_laravel,by FLi
  27. * @param string $str
  28. * @return string
  29. */
  30. function decrypt_laravel($str,$screct_key){
  31. //AES, 128 模式加密数据 CBC
  32. $str = base64_decode($str);
  33. $screct_key = base64_decode($screct_key);
  34. $iv = mcrypt_create_iv(mcrypt_get_iv_size(MCRYPT_RIJNDAEL_128,MCRYPT_MODE_CBC),1);
  35. $encrypt_str = mcrypt_decrypt(MCRYPT_RIJNDAEL_128, $screct_key, $str, MCRYPT_MODE_CBC);
  36. $encrypt_str = trim($encrypt_str);
  37. $encrypt_str = stripPKSC7Padding($encrypt_str);
  38. return $encrypt_str;
  39. }
  40. /**
  41. * 填充算法
  42. * @param string $source
  43. * @return string
  44. */
  45. function addPKCS7Padding($source){
  46. $source = trim($source);
  47. $block = mcrypt_get_block_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_CBC);
  48. $pad = $block - (strlen($source) % $block);
  49. if ($pad <= $block) {
  50. $char = chr($pad);
  51. $source .= str_repeat($char, $pad);
  52. }
  53. return $source;
  54. }
  55. /**
  56. * 移去填充算法
  57. * @param string $source
  58. * @return string
  59. */
  60. function stripPKSC7Padding($source){
  61. $source = trim($source);
  62. $char = substr($source, -1);
  63. $num = ord($char);
  64. if($num==62)return $source;
  65. $source = substr($source,0,-$num);
  66. return $source;
  67. }