Java 加解密技术系列之 总结

  • 背景
  • 分类
  • 常用算法
  • 原理
  • 关于代码
  • 结束语

上一篇文章中简单的介绍了第二种非对称加密算法 — — DH,这种算法也经常被叫做密钥交换协议,它主要是针对密钥的保护。同时,由于水平的限制,打算这个系列就到此为止了,这篇文章就算是一个总结吧,回顾一下这几个月来都写了些什么。

背景


实,在开始写这个系列之前,我对于 Java
的加解密也并不是那么了解。之所以要写这些文章,还主要是由于工作的原因。记得几个月以前,当时项目要做一个数字证书,证书的生成、存储、传输等过程都是
需要加密的,那时,我对于加解密这块还不是那么了解,就索性恶补了一段时间,简单的研究了一下。后来,工作上的任务都完成之后,就考虑反正加解密这一块在
工作中使用挺频繁的,还不如分享出来,一块学习呢。

分类

      常用算法
      原理
写了这么多的加解密算法,其实,本质上他们的原理是一样的。刚开始写前几篇的时候,还没有发现,可越到后边,这种感觉也就特别明显,仔细一想还真是,看来我的反应有点迟钝啊。

谓的加密,说通俗一点,就是把原来的数据,改变输出的形式,让人眼不能一眼就分辨出来,从而保护数据的真实性。那么对于计算机来说,计算机只认识 0 和
1 。不管什么形式的数据,对于计算机来说都是一样的,都是很多的 0 和 1 的组合。0 和 1
虽然一样,但不同的组合(或者说排列)就会产生不同的结果,而加密的目的,就是让它产生不同的结果,以便其他的人或计算机不能正确的识别,这样才能保证数
据不被泄漏或篡改。
不同的加密算法,其原理是共通的,只不过,对于加密的复杂程度是不同的。而且,很多加密算法都是基于另一种加密算法的基础之上实现的。说到底,就是用一定的方法,按照一定的规律,使用其他的字符(包括一些特殊字符)替换正常的字符,使之改变正常的表现形式。

关于代码

在分享每一个算法的时候,一般都会贴上 Java 的实现代码,这些代码中,有的是我自己写的,有的是参考了一些大牛的,自己实现了之后,才贴到博文中,主要是方便其他童鞋学习和理解。当然,这些代码中,我这里都有工程,如果有哪位小伙伴需要的话,可以私信我。当然,代码写的并不怎么好,还有很多需要改善的地方,希望路过的大神多多批评指正。

结束语

这个加解密系列维持了这么长的时间,实非我愿,不过,话说回来,通过这段时间的研究,对于加密这一块,我学到了很多,同时,也解决了很多问题。之前觉得很枯燥的,看不懂的东东,现在已经很清楚明了了。希望这些东东能够对小伙伴们有一些帮助。
最后说一句,再见了,Encrypt And Decrypt!

11.Java 加解密技术系列之 总结的更多相关文章

  1. 3.Java 加解密技术系列之 SHA

    Java 加解密技术系列之 SHA 序 背景 正文 SHA-1 与 MD5 的比较 代码实现 结束语 序 上一篇文章中介绍了基本的单向加密算法 — — MD5,也大致的说了说它实现的原理.这篇文章继续 ...

  2. 2.Java 加解密技术系列之 MD5

    Java 加解密技术系列之 MD5 序 背景 正文 结束语 序 上一篇文章中,介绍了最基础的编码方式 — — BASE64,也简单的提了一下编码的原理.这篇文章继续加解密的系列,当然也是介绍比较基础的 ...

  3. Java 加解密技术系列文章

    Java 加解密技术系列之 总结 Java 加解密技术系列之 DH Java 加解密技术系列之 RSA Java 加解密技术系列之 PBE Java 加解密技术系列之 AES Java 加解密技术系列 ...

  4. 10.Java 加解密技术系列之 DH

    Java 加解密技术系列之 DH 序 概念 原理 代码实现 结果 结束语 序 上一篇文章中简单的介绍了一种非对称加密算法 — — RSA,今天这篇文章,继续介绍另一种非对称加密算法 — — DH.当然 ...

  5. 9.Java 加解密技术系列之 RSA

    Java 加解密技术系列之 RSA 序 概念 工作流程 RSA 代码实现 加解密结果 结束语 序 距 离上一次写博客感觉已经很长时间了,先吐槽一下,这个月以来,公司一直在加班,又是发版.上线,又是新项 ...

  6. 8.Java 加解密技术系列之 PBE

    Java 加解密技术系列之 PBE 序 概念 原理 代码实现 结束语 序 前 边的几篇文章,已经讲了几个对称加密的算法了,今天这篇文章再介绍最后一种对称加密算法 — — PBE,这种加密算法,对我的认 ...

  7. 7.java 加解密技术系列之 AES

    java 加解密技术系列之 AES 序 概念 原理 应用 代码实现 结束语 序 这篇文章继续介绍对称加密算法,至于今天的主角,不用说,也是个厉害的角色 — — AES.AES 的出现,就是为了来替代原 ...

  8. 6. Java 加解密技术系列之 3DES

    Java 加解密技术系列之 3DES 序 背景 概念 原理 代码实现 结束语 序 上一篇文章讲的是对称加密算法 — — DES,这篇文章打算在 DES 的基础上,继续多讲一点,也就是 3 重 DES ...

  9. 5.Java 加解密技术系列之 DES

    Java 加解密技术系列之 DES 序 背景 概念 基本原理 主要流程 分组模式 代码实现 结束语 序 前 几篇文章讲的都是单向加密算法,其中涉及到了 BASE64.MD5.SHA.HMAC 等几个比 ...

随机推荐

  1. sublime Text3+emmet(快速开发)

    sublime软件使用Emmet插件快速编写CSS样式                    基本的CSS样式编写时,很多样式只需输入首字母即可得到不带属性值的CSS样式,像上面说到的margin.而 ...

  2. spring+mybatis事务不起作用的原因

    一.场景再现 @Override @Transactional public void updateById(String userId,String username) throws Excepti ...

  3. Ackerman 函数 (双递归函数)

    public static int ackerman(int n,int m){  if(n==1&&m==0){return 2;}  else if(n==0&&m ...

  4. js和android及ios交互

    Android中Java和JavaScript交互 这种交互,Hybrid App 会用的比较多一点, 本文将介绍如何实现Java代码和Javascript代码的相互调用. Android提供了一个很 ...

  5. Java中线程的yield(),sleep()以及wait()的区别

    从操作系统的角度讲,os会维护一个ready queue(就绪的线程队列).并且在某一时刻cpu只为ready queue中位于队列头部的线程服务. 但是当前正在被服务的线程可能觉得cpu的服务质量不 ...

  6. java多线程基本概述(三)——同步方法

    非线程安全其实是在多个线程对同一个对象实例的变量进行并发访问的时候发生,产生的后果就是脏读,也就是取到的数据是修改过的.而线程安全就是获得的实例变量的值是经过同步处理的,从而不会出现脏读现象. 1.1 ...

  7. C#数据结构之串

    串(string)是n(n>=0)个字符组成的有限序列. 由于串中的字符都是连续存储的,在C#中有恒定不变的特性.一经创建就保持不变. 为了区别C#中的string,因此以stringDS类模拟 ...

  8. mvc中DotNetOpenAuth实现了第三方应用访问自己的网站

    以yahoo为例吧,即从yahoo取得用户信息,存到自己的站点,实现了用户信息在一次录入多处共享的功能.以下是在点击了使用yahoo登录本站的链接后执行action:OpenId. ProviderU ...

  9. Unity Debug类

    静态变量 developerConsoleVisible 报告是否开发控制台是可见的.开发控制台不能出现使用: isDebugBuild 在构建设置对话框中有一个叫做"发展构建"复 ...

  10. 《HelloGitHub》第 13 期

    公告 本期推荐的项目到达了 30 个,里面少不了对本项目支持的小伙伴们,再次感谢大家. 本次排版尝试:根据分类项目名排序,为了让大家方便查阅.如果有任何建议和意见欢迎留言讨论 临近 5.1 假期,所以 ...