先看java代码

  1. public static String encrypt(String message, String key) throws Exception {
  2. Cipher cipher = Cipher.getInstance("DES/CBC/PKCS5Padding");
  3. DESKeySpec desKeySpec = new DESKeySpec(key.getBytes("UTF-8"));
  4. SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");
  5. SecretKey secretKey = keyFactory.generateSecret(desKeySpec);
  6. IvParameterSpec iv = new IvParameterSpec(key.getBytes("UTF-8"));
  7. cipher.init(Cipher.ENCRYPT_MODE, secretKey, iv);
  8. return toHexString(cipher.doFinal(message.getBytes("UTF-8")));
  9. }
  10. public static String decrypt(String message, String key) throws Exception {
  11. byte[] bytesrc = convertHexString(message);
  12. Cipher cipher = Cipher.getInstance("DES/CBC/PKCS5Padding");
  13. DESKeySpec desKeySpec = new DESKeySpec(key.getBytes("UTF-8"));
  14. SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");
  15. SecretKey secretKey = keyFactory.generateSecret(desKeySpec);
  16. IvParameterSpec iv = new IvParameterSpec(key.getBytes("UTF-8"));
  17. cipher.init(Cipher.DECRYPT_MODE, secretKey, iv);
  18. byte[] retByte = cipher.doFinal(bytesrc);
  19. return new String(retByte);
  20. }
  21. public static byte[] convertHexString(String ss) {
  22. byte digest[] = new byte[ss.length() / 2];
  23. for (int i = 0; i < digest.length; i++) {
  24. String byteString = ss.substring(2 * i, 2 * i + 2);
  25. int byteValue = Integer.parseInt(byteString, 16);
  26. digest[i] = (byte) byteValue;
  27. }
  28. return digest;
  29. }
  30. public static String toHexString(byte b[]) {
  31. StringBuffer hexString = new StringBuffer();
  32. for (int i = 0; i < b.length; i++) {
  33. String plainText = Integer.toHexString(0xff & b[i]);
  34. if (plainText.length() < 2)
  35. plainText = "0" + plainText;
  36. hexString.append(plainText);
  37. }
  38. return hexString.toString();
  39. }

java写的已经很明显使用的是CBC/PKCS补码方式

在看PHP

  1. function encrypt($str) {
  2. //加密,返回大写十六进制字符串
  3. $size = mcrypt_get_block_size (MCRYPT_DES, MCRYPT_MODE_[color=red]CBC[/color] );
  4. $str = $this->pkcs5Pad ( $str, $size );
  5. return strtoupper( bin2hex( mcrypt_cbc(MCRYPT_DES, $this->key, $str, MCRYPT_ENCRYPT, $this->iv ) ) );
  6. }
  7. function decrypt($str) {
  8. //解密
  9. $strBin = $this->hex2bin( strtolower( $str ) );
  10. $str = mcrypt_cbc( MCRYPT_DES, $this->key, $strBin, MCRYPT_DECRYPT, $this->iv );
  11. $str = $this->pkcs5Unpad( $str );
  12. return $str;
  13. }
  14. function hex2bin($hexData) {
  15. $binData = "";
  16. for($i = 0; $i  < strlen ( $hexData ); $i += 2) {
  17. $binData .= chr ( hexdec ( substr ( $hexData, $i, 2 ) ) );
  18. }
  19. return $binData;
  20. }
  21. function pkcs5Pad($text, $blocksize) {
  22. $pad = $blocksize - (strlen ( $text ) % $blocksize);
  23. return $text . str_repeat ( chr ( $pad ), $pad );
  24. }
  25. function pkcs5Unpad($text) {
  26. $pad = ord ( $text {strlen ( $text ) - 1} );
  27. if ($pad > strlen ( $text )) return false;
  28. if (strspn ( $text, chr ( $pad ), strlen ( $text ) - $pad ) != $pad)   return false;
  29. return substr ( $text, 0, - 1 * $pad );
  30. }

java/php DES/CBC/PKCS5Padding加密解密算法实现过程的更多相关文章

  1. .NET和JAVA中BYTE的区别以及JAVA中“DES/CBC/PKCS5PADDING” 加密解密在.NET中的实现

    场景:java 作为客户端调用已有的一个.net写的server的webservice,输入string,返回字节数组. 问题:返回的值不是自己想要的,跟.net客户端直接调用总是有差距 分析:平台不 ...

  2. php实现AES/CBC/PKCS5Padding加密解密(又叫:对称加密)

    今天在做一个和java程序接口的架接,java那边需要我这边(PHP)对传过去的值进行AES对称加密,接口返回的结果也是加密过的(就要用到解密),然后试了很多办法,也一一对应了AES的key密钥值,偏 ...

  3. OC的DES加密,使与java的Cipher类用DES/CBC/PKCS5Padding方式的加密结果同样

    问题说明: 近期用到DES加密,而且要与java的Cipher类加密的结果保持一致.没研究过java的Cliper,但工作中Cipher依据DES/CBC/PKCS5Padding加密方式生成了一个字 ...

  4. Android DES加密的CBC模式加密解密和ECB模式加密解密

    DES加密共有四种模式:电子密码本模式(ECB).加密分组链接模式(CBC).加密反馈模式(CFB)和输出反馈模式(OFB). CBC模式加密: import java.security.Key; i ...

  5. Des加密解密算法java实现

    package tech.fullink.eaglehorn.utils; import javax.crypto.Cipher; import javax.crypto.SecretKey; imp ...

  6. java 实现 DES加密 解密算法

    DES算法的入口参数有三个:Key.Data.Mode.其中Key为8个字节共64位,是DES算法的工作密钥:Data也为8个字节64位,是要被加密或被解密的数据:Mode为DES的工作方式,有两种: ...

  7. Java DES 加解密("DES/CBC/PKCS5Padding")

    /** * DES加密 * * @param data 加密数据 * @param key 密钥 * @return 返回加密后的数据 */ public static byte[] desEncry ...

  8. DES对 json 、http参数加密解密算法

    网上众多大神们的众多方式实现加解密操作及保障数据安全性.今天无意中发现一篇以 DES加密解密算法.摘抄如下 工具类: import java.security.SecureRandom; import ...

  9. DES加密 java与.net可以相互加密解密的方法

    我.net程序员.今天和java的童鞋交互,单点登录的操作.采用了如下的加密和解密的方式.经过验证,完美结合.通过这个方法可以实现java和C#相互加密与解密 并能保持解密出来一致. 废话少说,上代码 ...

随机推荐

  1. Java中的IO与NIO

    前文开了高并发学习的头,文末说了将会选择NIO.RPC相关资料做进一步学习,所以本文开始学习NIO知识. IO知识回顾 在学习NIO前,有必要先回顾一下IO的一些知识. IO中的流 Java程序通过流 ...

  2. 创建Sphinx + GitHub + ReadtheDocs托管文档

    最新博客链接 "Tsanfer's Blog" 创建Sphinx + GitHub + ReadtheDocs托管文档 Readthedocs在线电子书链接

  3. Socket编程简介

    目录 背景 基础 流程 参考 本文系读书笔记,非深入研究,也无代码,如非所需,请见谅. 哦,这里有份不错的:Linux的SOCKET编程详解 背景 花了好久的时间(大约一周,我太垃圾)看完了一篇英文文 ...

  4. Natas10 Writeup(正则表达式、grep命令)

    Natas10: 页面与上一关类似,只是增加了提示“出于安全原因,我们现在过滤某些字符”. 查看源码,发现关键代码如下: $key = ""; if(array_key_exist ...

  5. sqlmap详解

    sqlmap是一个自动化的sql注入工具,其主要功能是扫描.发现并利用给定URL的SQL注入漏洞,内置了很多绕过插件,支持的数据库有MySQL, Oracle,PostgreSQL, Microsof ...

  6. linux redis安装 5.0.2

    参看:https://www.cnblogs.com/limit1/p/9045183.html 1.获取redis资源 wget http://download.redis.io/releases/ ...

  7. ABP实践(4)-abp前端vue框架之简单商品增删改查(帮助刚入门的新手快速了解怎么才能加入自己的功能并运行起来)

    提示:如有不明白的地方请先查看前3篇ABP实践系列的文章 1,下载及启动abp项目前后端分离(netcore+vue) 2,修改abp数据库为mysql 3,商品系列api接口(本文主要依赖在这个商品 ...

  8. MySQL----DDL(操作数据库,表)

    1. 操作数据库:CRUD 1. C(Create):创建 * 创建数据库: * create database 数据库名称; * 创建数据库,判断不存在,再创建: * create database ...

  9. 一起学习vue源码 - Vue2.x的生命周期(初始化阶段)

    作者:小土豆biubiubiu 博客园:https://www.cnblogs.com/HouJiao/ 掘金:https://juejin.im/user/58c61b4361ff4b005d9e8 ...

  10. 强化学习之二:Q-Learning原理及表与神经网络的实现(Q-Learning with Tables and Neural Networks)

    本文是对Arthur Juliani在Medium平台发布的强化学习系列教程的个人中文翻译.(This article is my personal translation for the tutor ...