cooking java ——加密解密
java安全与密码概述
主要分为三部分:
- 密码学基础,包括:相关术语;分类;常用安全体系。
- java的安全组成;jdk以及第三方扩展。
- 相关实现代码,包括:base64、MD5········
密码学基础
相关术语
- 明文:待加密的信息
- 密文:加密后的明文
- 加密:明文转密文
- 加密算法:明文转密文的算法
- 加密密钥:加密算法进行加密操作的密钥
- 解密:密文转为明文
- 解密算法:密文转成明文的算法
- 解密密钥:解密算法进行解密操作的密钥
- 密码分析:截取密文,通过分析推出明文或密钥
- 密码体系:明文空间、密文空间、密钥空间、加密算法、解密算法
- 密码协议:安全协议,以密码学为基础的信息交换通信协议
- 密码系统:加密,解密的系统
- 柯克霍夫原则:数据的安全集与密钥而不是算法,对密钥保密,对算法公开,现代密码学设计的基本原则
分类
按时间分类:
- 古典密码:以字符为基本加密单元
- 现代密码:以信息块为基本加密单元
按保密内容分类:
- 受限制算法:保密性基于算法的保密
- 集与密钥算法:保密性基于对密钥的保密
明文处理方法分类:
- 分组密码:用同一密钥和算法加密固定长度的组
- 流密码:也称序列密码,每次加密一位或者一个字节
密码体系
- 对称密码:加密解密密钥相同
- 非对称密码:密钥分公钥和私钥,加密解密密钥不相同
- 对称密码算法:应用于对称密码的加密,解密算法
- 非对称密码算法:应用于非对称密码的加密,解密算法
散列函数
用于验证数据的完整性,特点是:
- 长度不受限制
- 哈希值容易计算
- 散列原酸过程不可逆
有这些特性,发展处很多有关散列函数相关的算法,如:
- 消息摘要算法MD5
- SHA:安全散列算法
- MAC:消息认证码算法
安全体系
常用的安全体系有两种:OSI安全体系和TCP/IP安全体系,这儿就不过多讲解,放两张安全体系图大致了解下即可。


java安全体系
组成
- JCA(Java Cryptography Architecture)
- JCE(Java Cryptography Extension)
- JSSE(Java Secure Socket Extension)
- JAAS(Java Authentication and Authentication Service)
相关包和类
- java.security:消息摘要
- java.crypto:安全消息摘要,消息认证鉴别码
- java.net.ssl:安全套接字
第三方扩展
- Bouncy Castle:支持两种方式使用,一是在jdk中配置,再者就是调用addprovider
- Commons Codec:是apache开源项目,支持BASE64,URL编码解码
cooking java ——加密解密的更多相关文章
- java加密解密的学习
注:此文章只是对如何学习java加密解密技术做一个讲解.并不涉及具体的知识介绍,如果有需要请留言,有时间我补冲长.个人觉着学习一个学习方法比学习一个知识点更有价值的多. 首先,对于加密解密知识体系没有 ...
- Java加密解密字符串
http://www.cnblogs.com/vwpolo/archive/2012/07/18/2597232.html Java加密解密字符串 旧文重发:http://www.blogjava ...
- java加密解密
java加密解密 public class MD5Util { /** * @param args */ public static void main(String[] args) { System ...
- password学4——Java 加密解密之消息摘要算法(MD5 SHA MAC)
Java 加密解密之消息摘要算法(MD5 SHA MAC) 消息摘要 消息摘要(Message Digest)又称为数字摘要(Digital Digest). 它是一个唯一相应一个消息或文本的固定长度 ...
- Java加密解密大全
ChinaSEI系列讲义(By 郭克华) Java加密解密方法大全 如果有文字等小错,请多包涵.在不盈利的情况下,欢迎免费传播. 版权所有.郭克华 本讲义经 ...
- java加密解密算法位运算
一.实例说明 本实例通过位运算的异或运算符 “ ^ ” 把字符串与一个指定的值进行异或运算,从而改变每个字符串中字符的值,这样就可以得到一个加密后的字符串.当把加密后的字符串作为程序输入内容,异或运算 ...
- ◆JAVA加密解密-3DES
从数据安全谈起 当你使用网银时,是否担心你的银行卡会被盗用? 当你和朋友用QQ进行聊天时,是否担心你的隐私会被泄露? 作为开发者,编写安全的代码比编写优雅的代码更重要,因为 ...
- java加密-解密小结
加密算法可以分为 双向加密(对称加密.不对称加密) 单向加密(不可逆加密)—— MD5.sha.hmac... 在对称加密算法中,使用的密钥只有一个,发收信双方都使用这个密钥对数据进行加密和解密 有: ...
- Java加密解密相关
关于解释加密解密中的填充方案: http://laokaddk.blog.51cto.com/368606/461279/ 关于对称加密中的反馈模式: http://blog.csdn.net/aaa ...
随机推荐
- Aggregation(1):Blending、Bagging、Random Forest
假设我们有很多机器学习算法(可以是前面学过的任何一个),我们能不能同时使用它们来提高算法的性能?也即:三个臭皮匠赛过诸葛亮. 有这么几种aggregation的方式: 一些性能不太好的机器学习算法(弱 ...
- Tkinter教程之Radiobutton篇
本文转载自:http://blog.csdn.net/jcodeer/article/details/1811308 #Tkinter教程之Radiobutton篇#Radiobutton为单选按钮, ...
- 新購電腦筆記 - G1.Sniper B7 內建網路晶片在 Mint 17.2(Cinnamon)上無法使用(已解決)
又好久沒寫文章了,這次因新購電腦,有一些狀況,故做一下記錄,也分享給遇到同樣問題的格友 以前在公司裝 Ubuntu 從沒遇過這麼多問題,這次自己第一次組電腦,也第一次裝 Mint,問題倒是不少 第一個 ...
- redis的string类型
string : string类型是二进制安全的, 可以包含任何数据,比如jpg图片或者序列化的对象 . 方法 : set : 设置key对应的值为string类型的value set name ...
- Entity Framework Power Tools
http://visualstudiogallery.msdn.microsoft.com/72a60b14-1581-4b9b-89f2-846072eff19d
- Tengine – Nginx衍生版
Tengine是淘宝在Nginx基础上开发的一个衍生版.官方的简介说针对大访问量网站的需求,添加了很多高级功能和特性.Tengine的性能和稳定性已经在大型的网站如淘宝网,天猫商城等得到了很好的检验. ...
- Nginx和Tengine的详细安装图文教程(Linux下)
简洁安装 安装依赖 yum -y install gcc openssl-devel pcre-devel zlib-devel 编译三步走./configure \ --prefix=/opt/sx ...
- google proto buffer安装和简单示例
1.安装 下载google proto buff. 解压下载的包,并且阅读README.txt,根据里面的指引进行安装. $ ./configure $ make $ make check $ mak ...
- 基于 Red5 的流媒体服务器的搭建和应用
http://www.ibm.com/developerworks/cn/opensource/os-cn-Red5/ Red5 是一个采用 Java 开发的开源免费 Flash 流媒体服务器.Red ...
- [iOS微博项目 - 1.1] - 设置导航栏主题(统一样式)
A.导航栏两侧文字按钮 1.需求: 所有导航栏两侧的文字式按钮统一样式 普通样式:橙色 高亮样式:红色 不可用样式:亮灰 阴影:不使用 字体大小:15 github: https://github ...