本文实例讲述了php7实现和cryptojs的aes加密方式互通。分享给大家供大家参考,具体如下:

php类:

class aes
{
  /**
   *
   * @param string $string 需要加密的字符串
   * @param string $key 密钥
   * @return string
   */
  public static function encrypt($string, $key)
  {
    // openssl_encrypt 加密不同mcrypt,对秘钥长度要求,超出16加密结果不变
    $data = openssl_encrypt($string, 'aes-128-ecb', $key, openssl_raw_data);
    return base64_encode($data);
  }
  /**
   * @param string $string 需要解密的字符串
   * @param string $key 密钥
   * @return string
   */
  public static function decrypt($string, $key)
  {
    return openssl_decrypt(base64_decode($string), 'aes-128-ecb', $key, openssl_raw_data);
  }
  /**
   * 获取秘钥
   * @return string
   */
  public static function getsecretkey()
  {
    $str='xxx';//生成16位的字符窜
    return $str;
  }
}

js的写法:

<script type="text/javascript" src="./bower_components/crypto-js/crypto-js.js"></script>
<script type="text/javascript">
  aeskey = 'xxxxx';//加密时用的key,跟php一样
  message='xxxxxxx';//加密后的字符窜
  var ecboptions = {
    mode: cryptojs.mode.ecb,
    padding: cryptojs.pad.pkcs7
  };
  var key = cryptojs.enc.utf8.parse(aeskey);
  var bytes = cryptojs.aes.decrypt(message, key,ecboptions);
  var originaltext = bytes.tostring(cryptojs.enc.utf8);
  console.log(originaltext)
</script>

ps:关于加密解密感兴趣的朋友还可以参考本站在线工具:

文字在线加密解密工具(包含aes、des、rc4等):

md5在线加密工具:
http://tools.jb51.net/password/createmd5password

在线散列/哈希算法加密工具:

在线md5/hash/sha-1/sha-2/sha-256/sha-512/sha-3/ripemd-160加密工具:

在线sha1/sha224/sha256/sha384/sha512加密工具:

更多关于php相关内容感兴趣的读者可查看本站专题:《php加密方法总结》、《php编码与转码操作技巧汇总》、《php数学运算技巧总结》、《php数组(array)操作技巧大全》、《php字符串(string)用法总结》、《php数据结构与算法教程》、《php程序设计算法总结》及《php正则表达式用法总结》

希望本文所述对大家php程序设计有所帮助。