`
kisseveryone
  • 浏览: 197826 次
  • 性别: Icon_minigender_1
  • 来自: 武汉
社区版块
存档分类
最新评论

PHP JAVA C#互通的DES加密解密算法

des 
阅读更多
注意:
des中的key必须是8位

先看java代码

public static String encrypt(String message, String key) throws Exception {
		Cipher cipher = Cipher.getInstance("DES/CBC/PKCS5Padding");

		DESKeySpec desKeySpec = new DESKeySpec(key.getBytes("UTF-8"));

		SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");
		SecretKey secretKey = keyFactory.generateSecret(desKeySpec);
		IvParameterSpec iv = new IvParameterSpec(key.getBytes("UTF-8"));
		cipher.init(Cipher.ENCRYPT_MODE, secretKey, iv);

		return toHexString(cipher.doFinal(message.getBytes("UTF-8")));
	}

public static String decrypt(String message, String key) throws Exception {

		byte[] bytesrc = convertHexString(message);
		Cipher cipher = Cipher.getInstance("DES/CBC/PKCS5Padding");
		DESKeySpec desKeySpec = new DESKeySpec(key.getBytes("UTF-8"));
		SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");
		SecretKey secretKey = keyFactory.generateSecret(desKeySpec);
		IvParameterSpec iv = new IvParameterSpec(key.getBytes("UTF-8"));

		cipher.init(Cipher.DECRYPT_MODE, secretKey, iv);

		byte[] retByte = cipher.doFinal(bytesrc);
		return new String(retByte);
	}

public static byte[] convertHexString(String ss) {
		byte digest[] = new byte[ss.length() / 2];
		for (int i = 0; i < digest.length; i++) {
			String byteString = ss.substring(2 * i, 2 * i + 2);
			int byteValue = Integer.parseInt(byteString, 16);
			digest[i] = (byte) byteValue;
		}

		return digest;
	}
	public static String toHexString(byte b[]) {
		StringBuffer hexString = new StringBuffer();
		for (int i = 0; i < b.length; i++) {
			String plainText = Integer.toHexString(0xff & b[i]);
			if (plainText.length() < 2)
				plainText = "0" + plainText;
			hexString.append(plainText);
		}

		return hexString.toString();
	}


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

在看PHP
function encrypt($str) {
        //加密,返回大写十六进制字符串
        $size = mcrypt_get_block_size (MCRYPT_DES, MCRYPT_MODE_[color=red]CBC[/color] );
        $str = $this->pkcs5Pad ( $str, $size );
        return strtoupper( bin2hex( mcrypt_cbc(MCRYPT_DES, $this->key, $str, MCRYPT_ENCRYPT, $this->iv ) ) );
    }

    function decrypt($str) {
        //解密  
        $strBin = $this->hex2bin( strtolower( $str ) );  
        $str = mcrypt_cbc( MCRYPT_DES, $this->key, $strBin, MCRYPT_DECRYPT, $this->iv );
        $str = $this->pkcs5Unpad( $str );
        $str = explode('_',$str);
        array_pop($str);
        $str = implode("_",$str);
        return $str;
    }
function hex2bin($hexData) {  
        $binData = "";  
        for($i = 0; $i  < strlen ( $hexData ); $i += 2) {  
            $binData .= chr ( hexdec ( substr ( $hexData, $i, 2 ) ) );  
        }
        return $binData;
    }

    function pkcs5Pad($text, $blocksize) {
        $pad = $blocksize - (strlen ( $text ) % $blocksize);
        return $text . str_repeat ( chr ( $pad ), $pad );
    }

    function pkcs5Unpad($text) {
        $pad = ord ( $text {strlen ( $text ) - 1} );  
        if ($pad > strlen ( $text )) return false;

        if (strspn ( $text, chr ( $pad ), strlen ( $text ) - $pad ) != $pad)   return false;  

        return substr ( $text, 0, - 1 * $pad );
    }



最后看c#实现
/// <summary>
	/// DES加密方法
	/// </summary>
	/// <param name="strPlain">明文</param>
	/// <param name="strDESKey">密钥</param>
	/// <param name="strDESIV">向量</param>
	/// <returns>密文</returns>
	public string Encrypt(string source,string _DESKey)
	{
		StringBuilder sb = new StringBuilder();
		using (DESCryptoServiceProvider des = new DESCryptoServiceProvider())
		{
			byte[] key = ASCIIEncoding.ASCII.GetBytes(_DESKey);
			byte[] iv = ASCIIEncoding.ASCII.GetBytes(_DESKey);
			byte[] dataByteArray = Encoding.UTF8.GetBytes(source);
			des.Mode = System.Security.Cryptography.CipherMode.CBC;
			des.Key = key;
			des.IV = iv;
			string encrypt = "";
			using (MemoryStream ms = new MemoryStream())
			using (CryptoStream cs = new CryptoStream(ms, des.CreateEncryptor(), CryptoStreamMode.Write))
			{
				cs.Write(dataByteArray, 0, dataByteArray.Length);
				cs.FlushFinalBlock();
				//輸出資料
				foreach (byte b in ms.ToArray())
				{
					sb.AppendFormat("{0:X2}", b);
				}
				encrypt = sb.ToString();
			}
			return encrypt;
		}
		
  	}

/// <summary>
        /// 进行DES解密。
        /// </summary>
        /// <param name="pToDecrypt">要解密的串</param>
        /// <param name="sKey">密钥,且必须为8位。</param>
        /// <returns>已解密的字符串。</returns>
        public string Decrypt(string source, string sKey)
        {
            byte[] inputByteArray = Encoding.UTF8.GetBytes(source);
            using (DESCryptoServiceProvider des = new DESCryptoServiceProvider())
            {
                des.Key = ASCIIEncoding.ASCII.GetBytes(sKey);
                des.IV = ASCIIEncoding.ASCII.GetBytes(sKey);
                System.IO.MemoryStream ms = new System.IO.MemoryStream();
                using (CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(), CryptoStreamMode.Write))
                {
                    cs.Write(inputByteArray, 0, inputByteArray.Length);
                    cs.FlushFinalBlock();
                    cs.Close();
                }
                string str = Encoding.UTF8.GetString(ms.ToArray());
                ms.Close();
                return str;
            }

分享到:
评论
5 楼 lianyoujun168 2015-10-08  
c#的解密方法走不通,能把调试通过的代码贴出来吗
4 楼 龙心之火 2014-05-24  
C#代码里那个解密算法有问题,拜托亲调试好了再上传代码好不?
3 楼 weishiym 2014-03-28  
<?php

class CryptDesDemo{
public $key ="";
public $iv = "";


public function init_crypt($key) {
$this->key = $key;
$this->iv= $key;
}

    public function encrypt($str) {
//加密,返回大写十六进制字符串
$size = mcrypt_get_block_size (MCRYPT_DES, MCRYPT_MODE_CBC );
$str = $this->pkcs5Pad ( $str, $size );
$hexString = bin2hex( mcrypt_cbc(MCRYPT_DES, $this->key, $str, MCRYPT_ENCRYPT, $this->iv ) );
return strtoupper( $hexString );
}

public function decrypt($str) {
//解密 
$strBin = $this->hex2bin( strtolower( $str ) ); 
$str = mcrypt_cbc( MCRYPT_DES, $this->key, $strBin, MCRYPT_DECRYPT, $this->iv );
$str = $this->pkcs5Unpad( $str );
return $str;
}
function hex2bin($hexData) { 
$binData = ""; 
for($i = 0; $i  < strlen ( $hexData ); $i += 2) { 
$binData .= chr ( hexdec ( substr ( $hexData, $i, 2 ) ) ); 
}
return $binData;
}

function pkcs5Pad($text, $blocksize) {
$pad = $blocksize - (strlen ( $text ) % $blocksize);
return $text . str_repeat ( chr ( $pad ), $pad );
}

function pkcs5Unpad($text) {
$pad = ord ( $text {strlen ( $text ) - 1} ); 
if ($pad > strlen ( $text )) return false;

if (strspn ( $text, chr ( $pad ), strlen ( $text ) - $pad ) != $pad)   return false; 

return substr ( $text, 0, - 1 * $pad );
}
}
?>
2 楼 weishiym 2014-03-28  
还有iv向量,没说明初始值
1 楼 weishiym 2014-03-28  
php这段写得有问题啊
  function decrypt($str) { 
        //解密   
        $strBin = $this->hex2bin( strtolower( $str ) );   
        $str = mcrypt_cbc( MCRYPT_DES, $this->key, $strBin, MCRYPT_DECRYPT, $this->iv ); 
        $str = $this->pkcs5Unpad( $str ); 
        $str = explode('_',$str); 
        array_pop($str); 
        $str = implode("_",$str); 
        return $str; 
    } 

应该改为

  function decrypt($str) { 
        //解密   
        $strBin = $this->hex2bin( strtolower( $str ) );   
        $str = mcrypt_cbc( MCRYPT_DES, $this->key, $strBin, MCRYPT_DECRYPT, $this->iv ); 
        $str = $this->pkcs5Unpad( $str ); 
        return $str; 
    } 

相关推荐

    C++C#互通DES加密算法

    标题 "C++C#互通DES加密算法" 涉及的是在C++和C#编程语言之间使用DES(Data Encryption Standard)加密算法进行数据安全通信的技术。DES是一种经典的对称加密算法,它基于一个56位的密钥来对64位的数据块进行加密和...

    C#和Java实现互通的RSA&DES加解密算法

    本话题主要关注如何在C#和Java之间通过RSA和DES加密算法实现数据的安全互通。RSA是一种非对称加密算法,适用于小量数据加密,如密钥交换;而DES是对称加密算法,适合大量数据的快速加密,但安全性相对较低。 首先,...

    c++,c#互通DES加密算法(支持中文)

    总之,实现C++和C#之间的DES加密互通涉及密钥管理、数据预处理、编码转换等多个环节。理解和掌握这些知识点,有助于在实际项目中确保数据安全和跨平台的兼容性。在进行此类开发时,注意测试不同情况,尤其是中文字符...

    Delphi7与C#实现Des加解密互通Demo,全网找遍只次一份

    标题中的“Delphi7与C#实现Des加解密互通Demo”指的是一个示例项目,该项目旨在演示如何在Delphi 7和C#之间进行DES加密和解密操作,确保两个环境下的数据一致性。全网找遍只此一份,表明这个示例可能比较罕见且具有...

    c++和c#同时实现DES加密解密算法

    在本文中,我们将深入探讨DES加密解密算法,并展示如何在C++和C#这两种编程语言中实现这一算法。 首先,理解DES的工作原理至关重要。DES算法主要由以下四个步骤组成:初始置换(IP)、密钥扩展、16轮Feistel网络和...

    java和C#通用des3加解密

    标题中的“java和C#通用des3加解密”指的是在Java和C#这两种不同的编程语言中实现DES(Data Encryption Standard)的加强版——3DES(Triple DES)加解密算法。3DES是一种广泛使用的对称加密算法,通过三次应用DES的...

    C#中DES加密解密(兼容前端网页在线DES加密解密).zip

    在IT行业中,数据安全是至关重要的,特别是在网络通信和存储敏感信息时。DES(Data Encryption Standard,数据加密标准...本压缩包“C#中DES加密解密(兼容前端网页在线DES加密解密)”包含的资源可能是一个C#实现的DE

    DES加密解密算法(C#)

    c#实现des加密解密算法,winform程序,基于.net framework 2.0开发

    C# DES加密解密

    综上所述,C#中的DES加密解密涉及到理解DES算法原理、使用`System.Security.Cryptography.DES`类、设置密钥和初始化向量、执行加密和解密操作等步骤。在实际项目中,需要根据需求选择合适的加密算法并注意安全问题。

    C#的3DES加密解密算法实例代码

    这篇文章主要介绍了C#的3DES加密解密算法实例代码,有需要的朋友可以参考一下

    C#3DES加密解密

    本篇文章将深入探讨C#中实现3DES加密解密的方法。 3DES的工作原理是通过三次应用DES算法来提高安全性。它将明文分成64位的数据块,然后用三个不同的密钥进行三次独立的DES加密过程:一次加密、一次解密、再一次加密...

    c#3DES双倍长加密解密

    c#的3DES加密解密强制要求不能使用简单的密钥,这里按照3DES双倍长的算法原理,实现双倍长的加密解密

    JavaScript与C 互通的DES加解密算法实现.docx

    本文提供了一个使 JavaScript 与 C# 互通的 DES 加解密算法的实现,旨在实现前台页面中使用 JavaScript 版本的 DES 算法将数据加密,传到服务器端,然后使用 C# 版本的 DES 解密算法将其解密,得到原始数据,以起到...

    java c# des加密解密

    ### Java与C#中的DES加密解密技术 #### 一、概述 在现代软件开发中,数据的安全性至关重要。为了确保数据在传输过程中的安全,加密技术被广泛应用。其中,数据加密标准(Data Encryption Standard,简称DES)是一...

    c# 可逆 加密 解密算法

    ### C# 可逆加密解密算法解析 #### 一、引言 在现代软件开发中,数据安全显得尤为重要。为了保护敏感数据不被非法访问或窃取,开发者需要使用各种加密技术对数据进行处理。C#作为一种广泛使用的编程语言,在.NET...

    Java、C#与PHP的DES加密互通代码(测试通过)

    本篇文章将详细讲解如何在Java、C#和PHP这三个不同的编程语言环境中实现DES加密,并确保它们之间的互通性。在实际项目中,这种跨平台的加密互通能力对于多语言系统的集成至关重要。 首先,DES是一种块加密算法,它...

    DES加密DEMO(C#与JAVA)

    - **javax.crypto命名包**:JAVA中使用`javax.crypto.Cipher`类配合`DESKeySpec`和`SecretKeyFactory`实现DES加密解密。首先需要创建`DESKeySpec`对象,然后通过`SecretKeyFactory`生成`SecretKey`,再用`Cipher`...

    C#des对文件进行加密解密

    在C#中,可以使用.NET框架提供的`System.Security.Cryptography`命名空间内的类来实现DES加密解密。具体步骤如下: 1. **创建DES对象**:使用` DESCryptoServiceProvider`类创建一个DES加密服务提供者实例。你可以...

    C#版 DES+AES+IDEA+3DES加密解密程序及完整源代码

    本文将深入探讨C#中实现的四种经典加密算法:DES(Data Encryption Standard)、AES(Advanced Encryption Standard)、3DES(Triple DES)和IDEA(International Data Encryption Algorithm),并基于提供的资源,...

    c#编写关于AES与DES加密算法

    本资源提供了C#语言实现AES与DES加密算法的示例代码,包括加密和解密函数的实现。AES(Advanced Encryption Standard,高级加密标准)和DES(Data Encryption Standard,数据加密标准)都是常用的对称加密算法,广泛...

Global site tag (gtag.js) - Google Analytics