`
bask
  • 浏览: 147205 次
  • 性别: Icon_minigender_1
  • 来自: 宇宙
社区版块
存档分类
最新评论

java php DES 加密解密

    博客分类:
  • php
阅读更多
import java.io.IOException;
import java.security.SecureRandom;
import javax.crypto.Cipher;
import javax.crypto.SecretKey;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.DESKeySpec;
import sun.misc.BASE64Decoder;
import sun.misc.BASE64Encoder;
public class DES {

	private byte[] desKey;

	public DES(String desKey) {
		this.desKey = desKey.getBytes();
	}

	public byte[] desEncrypt(byte[] plainText) throws Exception {
		SecureRandom sr = new SecureRandom();
		byte rawKeyData[] = desKey;
		DESKeySpec dks = new DESKeySpec(rawKeyData);
		SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");
		SecretKey key = keyFactory.generateSecret(dks);
		Cipher cipher = Cipher.getInstance("DES");
		cipher.init(Cipher.ENCRYPT_MODE, key, sr);
		byte data[] = plainText;
		byte encryptedData[] = cipher.doFinal(data);
		return encryptedData;
	}

	public byte[] desDecrypt(byte[] encryptText) throws Exception {
		SecureRandom sr = new SecureRandom();
		byte rawKeyData[] = desKey;
		DESKeySpec dks = new DESKeySpec(rawKeyData);
		SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");
		SecretKey key = keyFactory.generateSecret(dks);
		Cipher cipher = Cipher.getInstance("DES");
		cipher.init(Cipher.DECRYPT_MODE, key, sr);
		byte encryptedData[] = encryptText;
		byte decryptedData[] = cipher.doFinal(encryptedData);
		return decryptedData;
	}

	public String encrypt(String input) throws Exception {
		return base64Encode(desEncrypt(input.getBytes()));
	}

	public String decrypt(String input) throws Exception {
		byte[] result = base64Decode(input);
		return new String(desDecrypt(result));
	}

	public static String base64Encode(byte[] s) {
		if (s == null)
			return null;
		BASE64Encoder b = new sun.misc.BASE64Encoder();
		return b.encode(s);
	}

	public static byte[] base64Decode(String s) throws IOException {
		if (s == null)
			return null;
		BASE64Decoder decoder = new BASE64Decoder();
		byte[] b = decoder.decodeBuffer(s);
		return b;
	}

	public static void main(String[] args) throws Exception {
		String key = "abcdefgh";
		String input = "a";
		DES crypt = new DES(key);
		System.out.println("Encode:" + crypt.encrypt(input));
		System.out.println("Decode:" + crypt.decrypt(crypt.encrypt(input)));
	}
}




php 方法一
<?php
class DES1 {	
	var $key;		
	function 	DES1($key) {		
		$this->key = $key;		
	}		
	function encrypt($input) {		
		$size = mcrypt_get_block_size('des', 'ecb');    	
		$input = $this->pkcs5_pad($input, $size);   		
		$key = $this->key;    	
		$td = mcrypt_module_open('des', '', '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;	
	}		
	function decrypt($encrypted) {		
		$encrypted = base64_decode($encrypted);    	
		$key =$this->key;    	
		$td = mcrypt_module_open('des','','ecb',''); 
		//使用MCRYPT_DES算法,cbc模式          	
		$iv = @mcrypt_create_iv(mcrypt_enc_get_iv_size($td), MCRYPT_RAND);       	
		$ks = mcrypt_enc_get_key_size($td);         	
		@mcrypt_generic_init($td, $key, $iv);       
		//初始处理           	
		$decrypted = mdecrypt_generic($td, $encrypted);       
		//解密           	
		mcrypt_generic_deinit($td);       
		//结束          
		mcrypt_module_close($td);               
		$y=$this->pkcs5_unpad($decrypted);        
		return $y;	
	}		
	function pkcs5_pad ($text, $blocksize) {    	
		$pad = $blocksize - (strlen($text) % $blocksize);    	
		return $text . str_repeat(chr($pad), $pad);	
	} 	
	function pkcs5_unpad($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);	
	}
} 
		$key = "abcdefgh";
		$input = "a";
		$crypt = new DES1($key);
		echo "Encode:".$crypt->encrypt($input)."<br/>";
		echo "Decode:".$crypt->decrypt($crypt->encrypt($input));
?> 

php 方法2
使用phpseclib中的DES
<?php
	include('DES.php');

	$des = new Crypt_DES();

	$des->setKey('abcdefgh');
	$plaintext = 'a';
	$jiami = base64_encode($des->encrypt($plaintext));
	echo "Encode:".$jiami."<br/>";
	echo "Decode:".$des->decrypt(base64_decode($jiami));
?>
  • DES.rar (9.4 KB)
  • 下载次数: 459
分享到:
评论
2 楼 zohog 2013-12-24  
谢谢,可能要用到了,我弄php端
1 楼 tss0823 2012-06-16  
非常感谢楼主,帮我解决了一个大问题。。

相关推荐

    PHP、JAVA、C#、Object-C、Android 通用的DES加密解密

    在这个主题中,我们将探讨PHP、JAVA、C#、Object-C和Android这五种编程语言中如何实现DES加密解密。 1. PHP DES加密解密: 在PHP中,可以使用mcrypt扩展来实现DES加密解密。首先,你需要创建一个密钥和初始化向量...

    兼容PHP和Java的des加密解密代码分享

    在PHP和Java之间进行DES加密解密时,关键在于保持相同的密钥和初始化向量。在PHP代码中,如果没有指定初始化向量,它会使用密钥作为IV。而在Java代码中,IV是随机生成的,因此为了跨平台兼容,必须在两个环境中使用...

    php实现DES 加密 匹配java的des加密 验证

    本话题聚焦于如何使用PHP实现DES加密,并确保其与Java环境下的DES加密结果相匹配,以实现跨平台的数据安全交换。 首先,我们来了解一下DES加密的基本原理。DES使用56位的密钥对64位的数据块进行操作,通过一系列...

    Qt DES_ECB加密解密类

    **Qt DES_ECB 加密解密类** 在IT领域,数据安全是至关重要的,而加密技术就是保护数据安全的一种常用手段。DES(Data Encryption Standard)是一种古老的对称加密算法,虽然现在已被更强大的AES(Advanced ...

    Des加密,PHP和java互通

    DES加密,DES解密,可以输入密钥后进行加密和解密,支持可逆加密解密。内含PHP加密、解密 和 JAVA加密解密,双方可以互通,亲测有效

    PHP、Java des加密解密实例

    des加密是对称加密中在互联网应用的比较多的一种加密方式,php 通过mcrypt扩展库来支持des加密,要在Php中使用des加密,需要先安装mcrypt扩展库 下面是加密解密的实例 复制代码 代码如下: $iv_size = mcrypt_get_iv_...

    PHP 3des 对称加密解密,与 java c#兼容

    PHP 3des 对称加密解密,与 java c#兼容

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

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

    php,java,ios 统一的des 加密

    文件`des.php`可能包含了PHP的实现代码,`des-ios.zip`可能包含了一个iOS项目,其中包含了Objective-C或Swift的加密解密逻辑,而`des-java.zip`则可能包含了一个Java项目的源码。 总的来说,这个解决方案旨在提供一...

    java的des加密用到的base64包

    在描述中提到的“附带 java和php对接的des加密算法”,这意味着这个压缩包可能包含了一个示例,展示如何在Java和PHP之间使用相同的DES密钥进行加密和解密。DES加密算法在两个平台上的实现原理相同,但是关键在于确保...

    android iOS php des 互通加密解密算法

    在`Android`平台上,你可以使用Java的`javax.crypto`库来实现`DES`加密解密。首先,需要创建一个`SecretKeySpec`对象,使用它和`DesKeySpec`对象初始化`KeyGenerator`,然后生成`SecretKey`。接着,使用`Cipher`对象...

    PHP、Java des加密解密实例_.docx

    DES(Data Encryption Standard)是一种对称加密算法,广泛应用于数据...在PHP中,通常使用`mcrypt`扩展库来实现DES加密,而在Java中,我们可以利用`javax.crypto`包中的类来完成相同的功能。 在PHP中,以下是一个DE

    标准3DES和DES加密解密软件

    标准的3des和des加密解密软件 附带JAVA和PHP的实现方式

    JS前台加密,java后台解密实现

    1. **Java解密**:接收到加密数据后,服务器端使用对应的解密算法和密钥进行解密。如果是AES,可以使用`javax.crypto.Cipher`类来解密;如果是RSA,需要使用`java.security.PrivateKey`来解密用公钥加密的数据。 2....

    java,php,GOLang,JavaScript,AES加密解密代码互通

    本主题聚焦于四种常用编程语言——Java、PHP、GOLang(Go语言)和JavaScript——之间的AES(Advanced Encryption Standard)ECB(Electronic Codebook)模式128位加密解密的互操作性。下面我们将详细探讨这些语言...

    delphi与java 加密解密 DES/CBC/PKCS5Padding

    最近做一个接口,与JAVA的关于DES/CBC/PKCS5Padding 互相解密。在网上找了很多资料,摸索了3天才摸索出来。同样的明文,用JAVA加密的密文死活都跟用DELPHI加密的不相等,有时候少于8个字符的就正常,多了8个字符的就...

    DESPlus 加密解密 PHP版

    本PHP实现是针对网上常见的JAVA版本进行的对应,确保在两个平台上能够互换使用加密解密的结果。 在PHP中实现DESPlus加密解密,主要涉及以下几个关键知识点: 1. **DES算法**:DES是一种块加密算法,由IBM在1970...

Global site tag (gtag.js) - Google Analytics