密码学综述 密码学基本功能
机密性、鉴别、报文完整性、不可否认性
基本模型sender-->加密算法 --> 密文 --> 解密算法 --> receiver
密钥源
密码学算法分类:密码学五元组</>复制代码
消息编码:Base64
消息摘要:MD类,SHA类,MAC
对称加密:DES,3DES,AES
非对称加密:RSA,DH密钥交换
数字签名:RSA signature,DSA signature
明文、密文、加密算法、解密算法、密钥
Java编程中的常用类</>复制代码
加密解密算法都要使用公开算法(经过验证)
(1)消息编码
</>复制代码
BASE64Encoder,BASE64Decoder
(2)消息摘要
</>复制代码
MessageDigest
(3)对称密码
</>复制代码
KeyGenerator、SecretKey、Cipher
(4)非对称密码
</>复制代码
KeyPairGenerator、KeyFactory、KeyPair、PublicKey、PrivateKey、Cipher
(5)数字签名
JDK提供的Base64编码操作</>复制代码
Signature
</>复制代码
import java.io.IOException;
import sun.misc.BASE64Decoder;
import sun.misc.BASE64Encoder;
public class Base64Util {
public static String encrypt(byte[] data) {
return new BASE64Encoder().encode(data);
}
public static String decrypt(String data) throws IOException {
return new String(new BASE64Decoder().decodeBuffer(data));
}
public static void main(String[] args) throws IOException {
String data = "1234567890";
String result = Base64Util.encrypt(data.getBytes());
System.out.println(data +" 使用Base64编码的结果: "+result);
String result2 = Base64Util.decrypt(result);
System.out.println(result + "使用Base64解码的结果:" +result2);
}
}
运行结果:
</>复制代码
1234567890 使用Base64编码的结果: MTIzNDU2Nzg5MA==
MTIzNDU2Nzg5MA==使用Base64解码的结果:1234567890
</>复制代码
PS1:
Eclipse中找不到sun.misc.BASE64Encoder包的解决方法:
在工程的build path中先移除JRE System Library,再添加库JRE System Library,重新编译后就一切正常了。
</>复制代码
PS2:
其他提供Base64操作的jar包,
Apache Commons Codec(简称CC),
Bouncy Castle(BC)
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/65201.html
摘要:时间年月日星期一说明本文部分内容均来自慕课网。多用于网络加密。散列函数函数或消息摘要函数主要作用散列函数用来验证数据的完整性。 时间:2017年4月10日星期一说明:本文部分内容均来自慕课网。@慕课网:http://www.imooc.com教学示例源码:https://github.com/zccodere/s...个人学习源码:https://github.com/zccodere...
摘要:时间年月日星期三说明本文部分内容均来自慕课网。秘密密钥,生成一个分组的秘密密钥。 时间:2017年4月12日星期三说明:本文部分内容均来自慕课网。@慕课网:http://www.imooc.com教学示例源码:https://github.com/zccodere/s...个人学习源码:https://github.com/zccodere/s... 第一章:概述 1-1 概述 非对称...
摘要:还有很多开发者没有意识到的加密算法的问题。不要使用哈希函数做为对称加密算法的签名。开发者建议使用基于口令的加密算法时,生成密钥时要加盐,盐的取值最好来自,并指定迭代次数。不要使用没有消息认证的加密算法加密消息,无法防重放。 本文作者:阿里移动安全@伊樵,@舟海 Android开发中,难免会遇到需要加解密一些数据内容存到本地文件、或者通过网络传输到其他服务器和设备的问题,但并不是使用了加...
摘要:系列密码学二传送门密码学一基础密码学算法分类消息编码消息摘要类,类,对称密码非对称密码数字签名五元组明文原始信息。非对称密码包提供给,,等非对称加密算法。对称加密算法在分布式网络系统上使用较为困难,主要是因为密钥管理困难,使用成本较高。 前言 最近一场面试,面试官问了我 对称加密与非对称加密的问题,虽然曾经看过一些内容,但是没有系统的整理,所以当被问的时候,脑子里一片空白,没有回答上...
阅读 1049·2022-06-21 15:13
阅读 1889·2021-10-20 13:48
阅读 1075·2021-09-22 15:47
阅读 1403·2019-08-30 15:55
阅读 3160·2019-08-30 15:53
阅读 556·2019-08-29 12:33
阅读 758·2019-08-28 18:15
阅读 3496·2019-08-26 13:58
极致性价比!云服务器续费无忧!
Tesla A100/A800、Tesla V100S等多种GPU云主机特惠2折起,不限台数,续费同价。
NVIDIA RTX 40系,高性价比推理显卡,满足AI应用场景需要。
乌兰察布+上海青浦,满足东推西训AI场景需要