前一段接到一个任务,为了安全起见,从银行传输的过来的文件要进行加密。而我需要把这些加密的文件解密后再进行处理。处理后返回的文件不需要进行加密。
一顿搜索,知道了加密用公钥,解密用私钥。公钥提供给银行,私钥保存即可。
了解到服务器是windows系统,就去网上下载安装了一下gpg4win。安装完成后分别用工具(Kleopatra)和cmd命令操作了下加解密。官方网站下载:http://www.gpg4win.org/
原本想写一个CMD命令,每天去进行解密文件。银行周末不传文件过来,周一的时候不止一个文件过来。想着能不能搞一个批处理定时去读取当天文件夹下的所有加密文件进行解密,防止过多的人为干预。进行解密时遇到文件夹下文件为空等其他异常现象时,进行发送邮件通知相关负责人及时进行处理。这样才是良好的运转模式。
解密的时候需要用到要解密的文件名和目标文件名,那我首先要获取当天文件夹下的所有文件名;获取到的文件名和目标文件路径以及名称写到bat文件(cmd命令)中;然后执行bat文件实现自己的解密操作。
windows系统下的gpg的cmd命令如下:https://blog.csdn.net/x728999452/article/details/50759249
而我主要用到只是一个解密命令即可;gpg --output 新文件名 --decrypt 加密文件名。
代码如下:
public class ReadWrite {
static public void main(String[] str) {
//1、读取文件夹中文件名称
String timerandom = DateUtil.getCurrentDate("yyyy-MM-dd").replace("-", "");//获取当天的日期
String encpath ="";//加密文件存放的路径
String decpath ="";//解密文件要存放的路径
String batpath ="";//cmd命令存放的路径
encpath ="D:" +"/" + timerandom +"/encrypt/";
decpath ="D:" +"/" + timerandom +"/decrypt/";
batpath ="D:" +"/" + timerandom +"/bat/";
String qianString ="gpg -d ";//gpg的命令
String writeString ="set path=%path%;\n" +"D:\\software\\gnupg2\\gnupg\\anzhuang\\GnuPG\n";//gpg的安装地址(这句可以不要)写入到bat的详细内容
List fileNameList =new ArrayList();
try {
fileNameList = ReadFileName();
if (null != fileNameList && fileNameList.size() >0) {
for (int i =0; i < fileNameList.size(); i++) {
fileNameList.get(i).replace("gpg", "");
writeString = writeString + qianString + encpath + fileNameList.get(i) +" > " + decpath + fileNameList.get(i).replace(".gpg", "") +"\n";
}
}
//2、编写bat脚本命令 写入命令
System.out.println("写入到bat文件中的内容为" + writeString);
writeBat(writeString);
//3、生成解密后的文件
System.out.println("执行解密文件开始:" + callCmd(batpath +"text.bat"));
}catch (IOException e) {
e.printStackTrace();
}
}
//遍历读取文件名,存到数组中
static public List ReadFileName() {
File f =null;
DateUtil.getCurrentDate("yyyy-MM-dd");
String timerandom = DateUtil.getCurrentDate("yyyy-MM-dd").replace("-", "");
String path ="";
path ="D:" +"/" + timerandom +"/encrypt";
f =new File(path); //新建文件实例
File[] list = f.listFiles(); /* 此处获取文件夹下的所有文件 */
List fileNameList =new ArrayList();
if (null != list && list.length >0) {
for (int i =0; i < list.length; i++) {
fileNameList.add(list[i].getName());
System.out.println(list[i].getName());//打印全路径,可以更改为你自己需要的方法}
System.out.println("遍历后的文件名:" + fileNameList.get(i));
}
}else {
System.out.println("文件夹没有相应的文件,请检查");
}
return fileNameList;
}
//把cmd的内容写到bat文件中
public static void writeBat(String writeString) {
try {
String timerandom = DateUtil.getCurrentDate("yyyy-MM-dd").replace("-", "");
String filePath ="D:" +"/" + timerandom +"/bat" +"/";
File fatherFile =new File(filePath);
if (!fatherFile.exists()) {
fatherFile.mkdirs();
}
String file = filePath +"text.bat";
File indexFile =new File(file);
PrintWriter indexPrintWriter =new PrintWriter(new OutputStreamWriter(new FileOutputStream(indexFile), "GBK"));
indexPrintWriter.println(writeString);
indexPrintWriter.close();
}catch (Exception e) {
e.printStackTrace();
}
}
//运行cmd命令
public static String callCmd(String command)throws IOException {
try {
Runtime r = Runtime.getRuntime();
Process p = r.exec(command);
BufferedReader br =new BufferedReader(new InputStreamReader(p.getInputStream()));
p.getOutputStream().flush();
p.getOutputStream().close();
String message ="";
StringBuffer result =new StringBuffer();
while ((message = br.readLine()) !=null) {
result.append(message).append("\n");
}
return result.toString();
}catch (IOException e) {
return e.getMessage();
}
}
}
运行一下,解密后的文件都进入解密的文件夹下了,可以直接进行处理了。
刚想放松一下下,又发现了一个小问题拦住自己的去路。运行该程序时会时不时跳出一个页面,要我手动输入我这边的私钥保护密码,才给进行解密,但是有很多时候又是不要的。发布到服务器上之后不会有人专门输入这个密码的,怎样能记住密码不需要人为的进行输入,就是我要接下来研究的问题了。
然后又扒拉到一个命令,就是把私钥的保护密码,写进命令就可以解密文件了。
命令如下 :gpg --passphrase=密钥密码 -q --no-tty -d XXX.gpg > sss(保存的文件)
我在写命令文件的时候把秘钥密码写进去就可以正常解密文件了,再也不用手动输入保护私钥的密码了。
把代码中的变量qianString 设置成这个命令即可,我的设置是:String qianString ="gpg --passphrase=1234568988 -q --no-tty -d ";//1234568988保护私钥的密码
这样我的基本功能都已经实现了,这个主要的内容封装个接口,就可以批处理进行调用了。异常情况发邮件进行及时的人工干预,任何程序都有完善的空间。或许我该考虑下保护私钥密码的安全性了。
网友评论