AopEncrypt.php 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. <?php
  2. namespace aop;
  3. /**
  4. * 加密工具类
  5. *
  6. * User: jiehua
  7. * Date: 16/3/30
  8. * Time: 下午3:25
  9. */
  10. /**
  11. * 加密方法
  12. * @param string $str
  13. * @return string
  14. */
  15. function encrypt($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. * @param string $str
  27. * @return string
  28. */
  29. function decrypt($str,$screct_key){
  30. //AES, 128 模式加密数据 CBC
  31. $str = base64_decode($str);
  32. $screct_key = base64_decode($screct_key);
  33. $iv = mcrypt_create_iv(mcrypt_get_iv_size(MCRYPT_RIJNDAEL_128,MCRYPT_MODE_CBC),1);
  34. $encrypt_str = mcrypt_decrypt(MCRYPT_RIJNDAEL_128, $screct_key, $str, MCRYPT_MODE_CBC);
  35. $encrypt_str = trim($encrypt_str);
  36. $encrypt_str = stripPKSC7Padding($encrypt_str);
  37. return $encrypt_str;
  38. }
  39. /**
  40. * 填充算法
  41. * @param string $source
  42. * @return string
  43. */
  44. function addPKCS7Padding($source){
  45. $source = trim($source);
  46. $block = mcrypt_get_block_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_CBC);
  47. $pad = $block - (strlen($source) % $block);
  48. if ($pad <= $block) {
  49. $char = chr($pad);
  50. $source .= str_repeat($char, $pad);
  51. }
  52. return $source;
  53. }
  54. /**
  55. * 移去填充算法
  56. * @param string $source
  57. * @return string
  58. */
  59. function stripPKSC7Padding($source){
  60. $source = trim($source);
  61. $char = substr($source, -1);
  62. $num = ord($char);
  63. if($num==62)return $source;
  64. $source = substr($source,0,-$num);
  65. return $source;
  66. }