永发信息网

如何利用JAVA对文档进行加密和解密处理,完整的java类

答案:4  悬赏:20  手机版
解决时间 2021-11-27 22:15
如何利用JAVA对文档进行加密和解密处理,完整的java类
最佳答案
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.io.OutputStream;
import java.security.KeyPair;
import java.security.KeyPairGenerator;
import java.security.NoSuchAlgorithmException;
import java.security.interfaces.RSAPrivateKey;
import java.security.interfaces.RSAPublicKey;
import javax.crypto.Cipher;

public class RSAEncrypt {

static KeyPairGenerator keyPairGen;

static KeyPair keyPair;

static RSAPrivateKey privateKey;

static RSAPublicKey publicKey;

static{
try {
keyPairGen = KeyPairGenerator.getInstance("RSA");
keyPairGen.initialize(512);
keyPair = keyPairGen.generateKeyPair();
// Generate keys
privateKey = (RSAPrivateKey) keyPair.getPrivate();
publicKey = (RSAPublicKey) keyPair.getPublic();
} catch (NoSuchAlgorithmException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}

public static void main(String[] args) {
RSAEncrypt encrypt = new RSAEncrypt();
File file = new File(
"C:\\Documents and Settings\\Administrator.DCB5E0D91E0D436\\桌面\\sdf.txt");
File newFile = new File(
"C:\\Documents and Settings\\Administrator.DCB5E0D91E0D436\\桌面\\sdf1.txt");
encrypt.encryptFile(encrypt, file, newFile);
File file1 = new File(
"C:\\Documents and Settings\\Administrator.DCB5E0D91E0D436\\桌面\\sdf1.txt");
File newFile1 = new File(
"C:\\Documents and Settings\\Administrator.DCB5E0D91E0D436\\桌面\\sdf2.txt");
encrypt.decryptFile(encrypt, file1, newFile1);
}

public void encryptFile(RSAEncrypt encrypt, File file, File newFile) {
try {
InputStream is = new FileInputStream(file);
OutputStream os = new FileOutputStream(newFile);

byte[] bytes = new byte[53];
while (is.read(bytes) > 0) {
byte[] e = encrypt.encrypt(RSAEncrypt.publicKey, bytes);
bytes = new byte[53];
os.write(e, 0, e.length);
}
os.close();
is.close();
System.out.println("write success");
} catch (Exception e) {
e.printStackTrace();
}
}

public void decryptFile(RSAEncrypt encrypt, File file, File newFile) {
try {
InputStream is = new FileInputStream(file);
OutputStream os = new FileOutputStream(newFile);
byte[] bytes1 = new byte[64];
while (is.read(bytes1) > 0) {
byte[] de = encrypt.decrypt(RSAEncrypt.privateKey, bytes1);
bytes1 = new byte[64];
os.write(de, 0, de.length);
}
os.close();
is.close();
System.out.println("write success");

} catch (Exception e) {
e.printStackTrace();
}
}



protected byte[] encrypt(RSAPublicKey publicKey, byte[] obj) {
if (publicKey != null) {
try {
Cipher cipher = Cipher.getInstance("RSA");
cipher.init(Cipher.ENCRYPT_MODE, publicKey);
return cipher.doFinal(obj);
} catch (Exception e) {
e.printStackTrace();
}
}
return null;
}



protected byte[] decrypt(RSAPrivateKey privateKey, byte[] obj) {
if (privateKey != null) {
try {
Cipher cipher = Cipher.getInstance("RSA");
cipher.init(Cipher.DECRYPT_MODE, privateKey);
return cipher.doFinal(obj);
} catch (Exception e) {
e.printStackTrace();
}
}
return null;
}
}

加解密需要依靠以下四个属性,你可以把它存文件,存数据库都无所谓:
static KeyPairGenerator keyPairGen;

static KeyPair keyPair;

static RSAPrivateKey privateKey;

static RSAPublicKey publicKey;

以上只是示例,怎么存放根据自己情况追问你能具体的注释下么
,追答每一句话都注释?追问不用每一句,每个方法注释下,还有就是怎么使用哇,哪个文件时本来存在的,哪个是加密之后的,这个类 我运行了之后,还出现了文档打不开的问题追答哦,好的

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.io.OutputStream;
import java.security.KeyPair;
import java.security.KeyPairGenerator;
import java.security.NoSuchAlgorithmException;
import java.security.interfaces.RSAPrivateKey;
import java.security.interfaces.RSAPublicKey;
import javax.crypto.Cipher;

public class RSAEncrypt {

static KeyPairGenerator keyPairGen;

static KeyPair keyPair;

static RSAPrivateKey privateKey;

static RSAPublicKey publicKey;

static{
try {
//实例类型
keyPairGen = KeyPairGenerator.getInstance("RSA");
//初始化长度
keyPairGen.initialize(512);
//生成KeyPair
keyPair = keyPairGen.generateKeyPair();
// Generate keys
privateKey = (RSAPrivateKey) keyPair.getPrivate();
publicKey = (RSAPublicKey) keyPair.getPublic();
} catch (NoSuchAlgorithmException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}


public void encryptFile(RSAEncrypt encrypt, File file, File newFile) ;


public void decryptFile(RSAEncrypt encrypt, File file, File newFile) ;


protected byte[] encrypt(RSAPublicKey publicKey, byte[] obj) ;


protected byte[] decrypt(RSAPrivateKey privateKey, byte[] obj)

我测试了下,.doc .txt均可以加密

因为加密解密均是根据那四个属性来的,所以你需要写个每次运行先读取属性,你可以写入文件
若文件不存在则新生成一组,当加密完成后把四个属性写入文件。
我以上写的只是测试,加解密未分开的追问朋友你能帮忙把里面的加密,解密分离开下么,谢谢哇!
全部回答
使用Virbox Protector对Java项目加密有两种方式,一种是对War包加密,一种是对Jar包加密。Virbox Protector支持这两种文件格式加密,并且加密用于解析class文件的java.exe,并且可以实现项目源码绑定制定设备,防止部署到客户服务器的项目被整体拷贝。
两种加密方式
War 包加密
当你的项目在没有完成竣工的时候,不适合使用war 文件,因为你的类会由于调试之类的经常改,这样来回删除、创建 war 文件很不爽,最好是你的项目已经完成了,不改了,那么就打个 war 包吧,这个时候一个 war 文件就相当于一个web应用程序;而 jar 文件就是把类和一些相关的资源封装到一个包中,便于程序中引用。
Jar 包加密
在编写java代码时,为方便编程,常常会引用别人已经实现的方法,通常会封装成jar包,我们在编写时,只需引入到Eclipse中即可。Jar包有已知的jar包及自己导出的jar包。
加密流程
我们如何对已知的jar 或者自己导出jar包做加密并给别人使用呢?下面是对简单的加密流程介绍。
War包加密流程
1、打包War包
2、解压War包
3、对java.exe加壳
4、对class文件加密
Jar包加密流程
1、对java.exe加壳
2、对Jar文件进行加密
我是1楼,代码太长发不上来
留联系方式
我以前上密码学课写过一个DES加解密的程序,是自己实现的,不是通过调用java库函数,代码有点长,带有用户界面。需要的话联系我
我要举报
如以上问答信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
黄陂区民政局地址好找么,我有些事要过去,
excel中怎么每隔3个取出一组数据并求平均值
弯沉值0.416是什么意思
7/8-3/4×1/27等与多少分数
你好请问,我有一辆非运营皮卡车想拉活鲜走高
我家出进门朝西餐桌那一方是延年方请大师给觧
跨度是什么意思?
额济纳旗气象局地址在什么地方,想过去办事,
宇宙飞船在宇宙中怎么加速
邻居大哥趁我丈夫出差敲响我家门,这事我该不
什么是断点调试?C语言怎么用断点调试?
怎么对付室友打呼噜?
m乐客产融平台是传销吗
唐嫣和李心艾嫁衣照美艳动人,但是和她比还是
屏幕解锁。
推荐资讯
摄影小白需要全画幅么
嘉陵江上阅读答案
鞋子的利润一般在多少?
无线网卡隔几分钟就断线要重连,怎么回事
小皇帝詹姆斯至今一共打出过多少次三双?以及
我头发如果软化能像王俊凯的 一样吗
铁矿开采能影响多少公里
单选题第一次世界大战前的美国和德国都是后起
GB/T 2872是合格面膜吗?我看到好多都是Q
这才叫五对一别说斑卑鄙,问你们个问题宇智波
我要是去我男朋友店里给他帮忙,然后让他给我
薪火相传这个成语是什么意思?
正方形一边上任一点到这个正方形两条对角线的
阴历怎么看 ?