文档章节

关于加密算法怎么写

徐干稳
 徐干稳
发布于 2015/10/23 11:07
字数 364
阅读 22
收藏 0

 import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.io.OutputStream;
import java.security.Key;
import java.security.SecureRandom;

import javax.crypto.Cipher;
import javax.crypto.CipherInputStream;
import javax.crypto.CipherOutputStream;
import javax.crypto.KeyGenerator;

 public class TestDES {
   Key key;
   public TestDES(String str) {
     getKey(str);//生成密匙
   }
   /**
   * 根据参数生成KEY
   */
   public void getKey(String strKey) {
     try {
         KeyGenerator _generator = KeyGenerator.getInstance("DES");
         _generator.init(new SecureRandom(strKey.getBytes()));
         this.key = _generator.generateKey();
         _generator = null;
     } catch (Exception e) {
         throw new RuntimeException("Error initializing SqlMap class. Cause: " + e);
     }
   }

   /**
   * 文件file进行加密并保存目标文件destFile中
   *
   * @param file   要加密的文件 如c:/test/srcFile.txt
   * @param destFile 加密后存放的文件名 如c:/加密后文件.txt
   */
   public void encrypt(String file, String destFile) throws Exception {
     Cipher cipher = Cipher.getInstance("DES");
     // cipher.init(Cipher.ENCRYPT_MODE, getKey());
     cipher.init(Cipher.ENCRYPT_MODE, this.key);
     InputStream is = new FileInputStream(file);
     OutputStream out = new FileOutputStream(destFile);
     CipherInputStream cis = new CipherInputStream(is, cipher);
     byte[] buffer = new byte[1024];
     int r;
     while ((r = cis.read(buffer)) > 0) {
         out.write(buffer, 0, r);
     }
     cis.close();
     is.close();
     out.close();
   }
   /**
   * 文件采用DES算法解密文件
   *
   * @param file 已加密的文件 如c:/加密后文件.txt
   *         * @param destFile
   *         解密后存放的文件名 如c:/ test/解密后文件.txt
   */
   public void decrypt(String file, String dest) throws Exception {
     Cipher cipher = Cipher.getInstance("DES");
     cipher.init(Cipher.DECRYPT_MODE, this.key);
     InputStream is = new FileInputStream(file);
     OutputStream out = new FileOutputStream(dest);
     CipherOutputStream cos = new CipherOutputStream(out, cipher);
     byte[] buffer = new byte[1024];
     int r;
     while ((r = is.read(buffer)) >= 0) {
      System.out.println();
         cos.write(buffer, 0, r);
     }
     cos.close();
     out.close();
     is.close();
   }
   public static void main(String[] args) throws Exception {
     TestDES td = new TestDES("aaa");
     td.encrypt("C:/Users/Administrator/Desktop/hehe.txt", "C:/Users/Administrator/Desktop/1hehe.txt"); //加密
     File file=new File("C:/Users/Administrator/Desktop/hehe.txt");
     file.delete();
     td.decrypt("C:/Users/Administrator/Desktop/1hehe.txt", "C:/Users/Administrator/Desktop/hehe.txt"); //解密
    
   }
 }

© 著作权归作者所有

共有 人打赏支持
徐干稳
粉丝 1
博文 25
码字总数 7783
作品 0
武汉
私信 提问
来自计时攻击的一课(或者,不要使用 MessageDigest.isEquals )

对于某些打算写一个安全的密码系统的人的角度来说,计时攻击相当可怕。它工作原理是依赖于程序员的最佳本能—不要做多余的工作,而这给攻击者得到一个统计101教科书(而这能很好的得到您应用程...

mvj3
2013/12/24
2.3K
13
RSA加密解密算法,哈希摘要

因项目需求,由C#转到C编写关于RSA加密解密,Sha256哈希运算。而且我还是一个学生,因此可见我的水准有多菜了。折腾了半个月,看过openssl、polarssl-1.1.1-gpl、cryptlib 3.4.1等一系列开源...

hshs
2012/03/11
1K
4
Java非对称加密RSA工具类v1.1

依旧是练习的产物,java的加密算法有很多,可惜用起来很痛苦(个人感受),有时间的话打算做个简化过程的所有加密算法工具类,之前已经写过一个包含MD5、SHA1、DES、AES、异或的简单工具类 ...

linin630
2016/09/13
95
0
关于数据库连接密码的保存

普通的建站开发,Java语言,Spring框架。 在配置链接池信息时会配置登录账号和密码。可以直接写在xml文件中,也可以另写.properties的配置文件引入进来。为了安全,大家通常会在.properties...

烛✟孩
07/25
502
3
关于加密和解密,非对称算法我怎么感觉最不安全

最近在看一些关于网络安全的内容,突然想到一个问题,都说用非对称加密解密最安全,就是把公钥暴露出去让别人使用,然后用私钥解密, 这里我就有个疑问了,你给人家提供了公钥,那你得把加密...

太黑_thj
2016/10/28
438
5

没有更多内容

加载失败,请刷新页面

加载更多

【58沈剑 架构师之路】1分钟了解MyISAM与InnoDB的索引差异

《数据库索引,到底是什么做的?》介绍了B+树,它是一种非常适合用来做数据库索引的数据结构: (1)很适合磁盘存储,能够充分利用局部性原理,磁盘预读; (2)很低的树高度,能够存储大量数据;...

张锦飞
6分钟前
1
0
代码优化----使用builder模式构造对象

看《effective java》的时候,创建对象章节提到使用builder模式来创建对象。觉得非常好用,做一个记录。以后应该就会这么写啦~~~~~~ 对于一个有很多属性的类,在为属性赋值时,通常会用到两种...

wuyiyi
7分钟前
2
0
一文带你看懂cookie,面试前端不用愁

本文由云+社区发表 在前端面试中,有一个必问的问题:请你谈谈cookie和localStorage有什么区别啊? localStorage是H5中的一种浏览器本地存储方式,而实际上,cookie本身并不是用来做服务器存...

腾讯云加社区
8分钟前
0
0
随行付微服务测试之接口测试和契约测试

背景 日常开发过程中,项目的接口通常由服务提供方约定和提供,微服务模式下接口被多个消费者调用更是常态,那么提供方接口的变更如何快速、高效、无遗漏的通知给消费者呢?另外,当一个ser...

马力-随行付
9分钟前
1
0
为什么Python是2019最值得学的编程语言?

对于那些从来没有学习编程小伙伴,Python 是最好的选择之一, Python 是一种清晰的语言,用缩进来表示程序的嵌套关系可谓是一种创举,把过去软性的编程风格升级为硬性的语法规定。再不需要在...

糖宝lsh
9分钟前
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部