手机
当前位置:查字典教程网 >编程开发 >Java >使用java自带des加密算法实现文件加密和字符串加密
使用java自带des加密算法实现文件加密和字符串加密
摘要:复制代码代码如下:importjava.io.ByteArrayInputStream;importjava.io.ByteArrayOut...

复制代码 代码如下:

import java.io.ByteArrayInputStream;

import java.io.ByteArrayOutputStream;

import java.io.File;

import java.io.FileInputStream;

import java.io.FileOutputStream;

import java.io.InputStream;

import java.io.OutputStream;

import java.security.SecureRandom;

import javax.crypto.Cipher;

import javax.crypto.CipherInputStream;

import javax.crypto.SecretKey;

import javax.crypto.SecretKeyFactory;

import javax.crypto.spec.DESKeySpec;

import javax.crypto.spec.IvParameterSpec;

public class DesTool {

private static final String PASSKEY = "afasdf";

private static final String DESKEY = "asfsdfsdf";

/**

* @Comments :对文件进行加密

* @param filePath 要加密的文件路径

* @param fileName 文件

* @param mode 加密模式 加密:Cipher.ENCRYPT_MODE 解密:Cipher.DECRYPT_MODE

* @return

*/

public static String encoderOrdecoder(String filePath, String fileName, int mode) {

InputStream is = null;

OutputStream out = null;

CipherInputStream cis = null;

try {

SecureRandom sr = new SecureRandom();

DESKeySpec dks = new DESKeySpec(DESKEY.getBytes());

SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");

SecretKey securekey = keyFactory.generateSecret(dks);

IvParameterSpec iv = new IvParameterSpec(PASSKEY.getBytes());

Cipher cipher = Cipher.getInstance("DES/CBC/PKCS5Padding");

cipher.init(mode, securekey, iv, sr);

File encoderFile = new File(filePath + File.separator + "encoder");

if (!encoderFile.exists()) {

encoderFile.mkdir();

}

is = new FileInputStream(filePath + File.separator + fileName);

out = new FileOutputStream(filePath + File.separator + "encoder"

+ File.separator + fileName);

cis = new CipherInputStream(is, cipher);

byte[] buffer = new byte[1024];

int r;

while ((r = cis.read(buffer)) > 0) {

out.write(buffer, 0, r);

}

} catch (Exception e) {

e.printStackTrace();

} finally {

try {

if (is != null) {

is.close();

}

if (cis != null) {

cis.close();

}

if (out != null) {

out.close();

}

} catch (Exception e1){

}

}

return filePath + File.separator + "encoder" + File.separator

+ fileName;

}

/**@Comments :对字符串进行加密

* @param src 源字符串

* @param mode 加密模式 加密:Cipher.ENCRYPT_MODE 解密:Cipher.DECRYPT_MODE

* @return

*/

public static String encoderOrdecoder( String src, int mode) {

String tag="";

InputStream is = null;

OutputStream out = null;

CipherInputStream cis = null;

try {

SecureRandom sr = new SecureRandom();

DESKeySpec dks = new DESKeySpec(DESKEY.getBytes());

SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");

SecretKey securekey = keyFactory.generateSecret(dks);

IvParameterSpec iv = new IvParameterSpec(PASSKEY.getBytes());

Cipher cipher = Cipher.getInstance("DES/CBC/PKCS5Padding");

cipher.init(mode, securekey, iv, sr);

cis = new CipherInputStream(new ByteArrayInputStream(src.getBytes()) , cipher);

out=new ByteArrayOutputStream();

byte[] buffer = new byte[1024];

int r;

while ((r = cis.read(buffer)) > 0) {

out.write(buffer, 0, r);

}

tag=out.toString();

} catch (Exception e) {

e.printStackTrace();

} finally {

try {

if (is != null) {

is.close();

}

if (cis != null) {

cis.close();

}

if (out != null) {

out.close();

}

} catch (Exception e1){

}

}

return tag;

}

public static void main(String[] args) {

System.out.println("aaa");

String t=encoderOrdecoder("aaa", Cipher.ENCRYPT_MODE );

System.out.println(t);

System.out.println(encoderOrdecoder(t, Cipher.DECRYPT_MODE ));

}

}

【使用java自带des加密算法实现文件加密和字符串加密】相关文章:

Java 随机取字符串的工具类

java开发之MD5加密算法的实现

java异或加密算法

通过java备份恢复mysql数据库的实现代码

Java读取Excel文件内容的简单实例

java自定义日志输出文件(log4j日志文件输出多个自定义日志文件)

使用Java获取html中Select,radio多选的值方法

使用jdk7的nio2操作文件拷贝和剪切示例

java中的hashCode方法小例子

java不可逆加密算法之md5加密算法使用示例

精品推荐
分类导航