设为首页 收藏本站
查看: 685|回复: 0

[经验分享] AES 加密 PHP 和 JAVA 互通

[复制链接]

尚未签到

发表于 2017-4-2 14:39:27 | 显示全部楼层 |阅读模式
  见代码:
  PHP代码:
  <?php
  class Security {
  public static function encrypt($input, $key) {
  $size = mcrypt_get_block_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_ECB);
  $input = Security::pkcs5_pad($input, $size);
  $td = mcrypt_module_open(MCRYPT_RIJNDAEL_128, '', MCRYPT_MODE_ECB, '');
  $iv = mcrypt_create_iv (mcrypt_enc_get_iv_size($td), MCRYPT_RAND);
  mcrypt_generic_init($td, $key, $iv);
  $data = mcrypt_generic($td, $input);
  mcrypt_generic_deinit($td);
  mcrypt_module_close($td);
  $data = base64_encode($data);
  return $data;
  }
  private static function pkcs5_pad ($text, $blocksize) {
  $pad = $blocksize - (strlen($text) % $blocksize);
  return $text . str_repeat(chr($pad), $pad);
  }
  public static function decrypt($sStr, $sKey) {
  $decrypted= mcrypt_decrypt(
  MCRYPT_RIJNDAEL_128,
  $sKey,
  base64_decode($sStr),
  MCRYPT_MODE_ECB
  );
  $dec_s = strlen($decrypted);
  $padding = ord($decrypted[$dec_s-1]);
  $decrypted = substr($decrypted, 0, -$padding);
  return $decrypted;
  }
  }
  $key = "1234567891234567";
  $data = "example";
  $value = Security::encrypt($data , $key );
  echo $value.'<br/>';
  echo Security::decrypt($value, $key );
  ---------------
  java 代码
  import javax.crypto.Cipher;
  import javax.crypto.spec.SecretKeySpec;
  import org.apache.commons.codec.binary.Base64;
  public class Security {
  public static String encrypt(String input, String key){
  byte[] crypted = null;
  try{
  SecretKeySpec skey = new SecretKeySpec(key.getBytes(), "AES");
  Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");
  cipher.init(Cipher.ENCRYPT_MODE, skey);
  crypted = cipher.doFinal(input.getBytes());
  }catch(Exception e){
  System.out.println(e.toString());
  }
  return new String(Base64.encodeBase64(crypted));
  }
  public static String decrypt(String input, String key){
  byte[] output = null;
  try{
  SecretKeySpec skey = new SecretKeySpec(key.getBytes(), "AES");
  Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");
  cipher.init(Cipher.DECRYPT_MODE, skey);
  output = cipher.doFinal(Base64.decodeBase64(input));
  }catch(Exception e){
  System.out.println(e.toString());
  }
  return new String(output);
  }
  public static void main(String[] args) {
  String key = "1234567891234567";
  String data = "example";
  
  System.out.println(Security.encrypt(data, key));
  
  System.out.println(Security.decrypt(Security.encrypt(data, key), key));
  
  
  }
  }

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-359256-1-1.html 上篇帖子: PHP无限分类(树形类) 下篇帖子: PHP面向对象之旅:类和对象
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表