文档章节

关于加密算法怎么写

徐干稳
 徐干稳
发布于 2015/10/23 11:07
字数 364
阅读 21
收藏 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
武汉
私信 提问
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
关于加密和解密,非对称算法我怎么感觉最不安全

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

太黑_thj
2016/10/28
379
5
PHP开发大发彩票源码搭建接口安全验证

php的大发彩票源码搭建接口 企 娥:217 1793 408 在实际工作中,使用PHP写api接口是经常做的,PHP写好接口后,前台就可以通过链接获取接口提供的数据,而返回的数据一般分为两种情况,xml和j...

我的女王
07/02
0
0
pxe网络装机kickstart的密码生成

关于ks文件MD5加密方式 linux kickstart之中root的密码可以使用明文,也可以使用加密过的值 rootpw –iscrypted $1$BYSimLw0$I515yLiKzudlwkIskBqQE1 就是读取加密后的值,但是这个值是怎么生...

qbs1989
06/26
0
0

没有更多内容

加载失败,请刷新页面

加载更多

ViewPager+Fragment+FragmentPagerAdapter实现软件主界面

ViewPager之前的页面是由View构成的,现在由Fragment构成,之前的PagerAdapter这里也换成了FragmentPagerAdapter.因为PagerAdapter有 public Object instantiateItem(ViewGroup container, i......

鱼想吃肉
10分钟前
0
0
feign文件上传遇到的坑

明天写

王俊博客
15分钟前
0
0
scala的sorted,sortBy,sortWith

val lst = List(1,3,2,4,5) //scala中对于集合的排序有三种方法:sorted,sortBy,sortWith //sorted方法对一个集合进行自然排序,传递一个Ordering隐式参数 def sorted[B >: A](imp...

whoisliang
30分钟前
0
0
区块链扩容最佳途径?十分钟讲清楚侧链技术

今天我们来讲区块链扩容的另一个主流方案——侧链,侧链可作为解决区块链扩容难题的一种有效解决方案。有些人认为,从理论上说,这种解决方案可让所有人都满意。 基础概念 侧链协议本质上是一...

HiBlock
32分钟前
0
0
3年经验Java程序员面阿里P6 差距在哪里

虽然这位小伙伴觉得自己工作三年了,结果阿里连面都不面就把自己挂了,这让自己感到很伤心。但是还是有网友觉得,三年不到p6,很正常啊,明年再面就没有问题啦! Java程序员3年经验面阿里P6,...

架构师springboot
34分钟前
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部