前言

在以前的一个项目中,觉得登录注册的加密方式不安全,需要改造一下,就用到了RSA加密。网上都说它是最安全的,现有的技术是无法破解的。我知道的京东的登录和国寿的登录都是用的这个加密。我想整理一下,肯定会有人用的到的。

RSA加密的介绍
RSA加密的好处
RSA加密和解密的讲解
RSA签名和验签的讲解
RSA测试
RSA加密的应用

一、RSA加密的介绍

RSA加密算法是一种非对称加密算法。在公开密钥加密和电子商业中RSA被广泛使用。RSA是1977年由罗纳德·李维斯特(Ron Rivest)、阿迪·萨莫尔(Adi Shamir)和伦纳德·阿德曼(Leonard Adleman)一起提出的。当时他们三人都在麻省理工学院工作。RSA就是他们三人姓氏开头字母拼在一起组成的。

对极大整数做因数分解的难度决定了RSA算法的可靠性。换言之,对一极大整数做因数分解愈困难,RSA算法愈可靠。假如有人找到一种快速因数分解的算法的话,那么用RSA加密的信息的可靠性就肯定会极度下降。但找到这样的算法的可能性是非常小的。今天只有短的RSA钥匙才可能被强力方式解破。到目前为止,世界上还没有任何可靠的攻击RSA算法的方式。只要其钥匙的长度足够长,用RSA加密的信息实际上是不能被解破的。

二、RSA加密的好处

要说它的好处,觉得有必要先说一下常用的几种加密的方式的劣势。

MD5加密在开发中用的比较多,一般应用在登录密码的加密或者接口的验签。同样的参数,它的加密结果是一样的,如果密码相对简单,被盗取的话,通过大数据是可以查询的你的铭文密码的。因为它是不可解密的,所以在接口也只能作为验签使用,而不能对数据进行加密传输。

base64加密因为是可以反解密的,所以它就谈不上安全了。

AES加密是我们接口对接一直在用的,它是对称加密,要求key是一样的,容易造成key的泄露。没有RES加密显的安全。

RSA加密,它是非对称的加密算法,也就是加密的秘钥(公钥)和解密的秘钥(私钥)是不一样的。并且相同的参数每次加密的结果都不一样,这样可以保证你的数据即使被盗取了,也没有办法通过大数据的方法到你的明文数据。在对接的过程中,暴露的永远是你的公钥,所以数据是绝对安全的。

三、RSA加密的讲解

加密是为了防止信息泄露。

RSA加密的公钥和私钥的长度是可以定义的,目前是没有上限。主流密钥长度至少都是1024bits以上,也就是最少128个字节(Bytes),少于这个长度会有安全问题。

RSA加密明文的长度不能大于秘钥的长度,但是由于明文长度小于秘钥长度的时候,需要进行填充(padding)占用11字节,所以0<加密明文的长度<秘钥长度-1

这里我们定义秘钥的长度为1024bits

//RSA最大加密明文大小
private static final int MAX_ENCRYPT_BLOCK = 117;
// RSA最大解密密文大小
private static final int MAX_DECRYPT_BLOCK = 128;
// 获取密钥对
public static KeyPair getKeyPair() throws Exception {KeyPairGenerator generator = KeyPairGenerator.getInstance("RSA");generator.initialize(1024);//定义秘钥长度为1024return generator.generateKeyPair();
}// 获取私钥
public static PrivateKey getPrivateKey(String privateKey) throws Exception {KeyFactory keyFactory = KeyFactory.getInstance("RSA");byte[] decodedKey = Base64.decodeBase64(privateKey.getBytes());PKCS8EncodedKeySpec keySpec = new PKCS8EncodedKeySpec(decodedKey);return keyFactory.generatePrivate(keySpec);}//获取公钥
public static PublicKey getPublicKey(String publicKey) throws Exception {KeyFactory keyFactory = KeyFactory.getInstance("RSA");byte[] decodedKey = Base64.decodeBase64(publicKey.getBytes());X509EncodedKeySpec keySpec = new X509EncodedKeySpec(decodedKey);return keyFactory.generatePublic(keySpec);}

因为加密的明文长度不能大于117,所以长度大于117的明文,可以分段加密和解密。

//RSA加密public static String encrypt(String data, PublicKey publicKey) throws Exception {Cipher cipher = Cipher.getInstance("RSA");cipher.init(Cipher.ENCRYPT_MODE, publicKey);int inputLen = data.getBytes().length;ByteArrayOutputStream out = new ByteArrayOutputStream();int offset = 0;byte[] cache;int i = 0;// 对数据分段加密while (inputLen - offset > 0) {if (inputLen - offset > MAX_ENCRYPT_BLOCK) {cache = cipher.doFinal(data.getBytes(), offset, MAX_ENCRYPT_BLOCK);} else {cache = cipher.doFinal(data.getBytes(), offset, inputLen - offset);}out.write(cache, 0, cache.length);i++;offset = i * MAX_ENCRYPT_BLOCK;}byte[] encryptedData = out.toByteArray();out.close();// 获取加密内容使用base64进行编码,并以UTF-8为标准转化成字符串// 加密后的字符串return new String(Base64.encodeBase64String(encryptedData));
}//RSA解密public static String decrypt(String data, PrivateKey privateKey) throws Exception {Cipher cipher = Cipher.getInstance("RSA");cipher.init(Cipher.DECRYPT_MODE, privateKey);byte[] dataBytes = Base64.decodeBase64(data);int inputLen = dataBytes.length;ByteArrayOutputStream out = new ByteArrayOutputStream();int offset = 0;byte[] cache;int i = 0;// 对数据分段解密while (inputLen - offset > 0) {if (inputLen - offset > MAX_DECRYPT_BLOCK) {cache = cipher.doFinal(dataBytes, offset, MAX_DECRYPT_BLOCK);} else {cache = cipher.doFinal(dataBytes, offset, inputLen - offset);}out.write(cache, 0, cache.length);i++;offset = i * MAX_DECRYPT_BLOCK;}byte[] decryptedData = out.toByteArray();out.close();// 解密后的内容 return new String(decryptedData, "UTF-8");}

四、RSA签名的讲解

签名是为了防止信息被串改。签名的的公钥的公开的。

A给B传递消息,A通过私钥把对数据加签,形成签名,把签名和数据给B。

B获取签名和数据,通过公钥验签,如果为true,表示是A发送的消息,否则不是。

//签名public static String sign(String data, PrivateKey privateKey) throws Exception {byte[] keyBytes = privateKey.getEncoded();PKCS8EncodedKeySpec keySpec = new PKCS8EncodedKeySpec(keyBytes);KeyFactory keyFactory = KeyFactory.getInstance("RSA");PrivateKey key = keyFactory.generatePrivate(keySpec);Signature signature = Signature.getInstance("MD5withRSA");signature.initSign(key);signature.update(data.getBytes());return new String(Base64.encodeBase64(signature.sign()));}//验签public static boolean verify(String srcData, PublicKey publicKey, String sign) throws Exception {byte[] keyBytes = publicKey.getEncoded();X509EncodedKeySpec keySpec = new X509EncodedKeySpec(keyBytes);KeyFactory keyFactory = KeyFactory.getInstance("RSA");PublicKey key = keyFactory.generatePublic(keySpec);Signature signature = Signature.getInstance("MD5withRSA");signature.initVerify(key);signature.update(srcData.getBytes());return signature.verify(Base64.decodeBase64(sign.getBytes()));}

注意:修改秘钥长度,需要同步修改最大解密密文大小

五、RSA测试

public static void main(String[] args) {try {// 生成密钥对KeyPair keyPair = getKeyPair();String privateKey = new String(Base64.encodeBase64(keyPair.getPrivate().getEncoded()));System.out.println("私钥:" + privateKey);String publicKey = new String(Base64.encodeBase64(keyPair.getPublic().getEncoded()));System.out.println("公钥:" + publicKey);// RSA加密String data = "小名登录密码";String encryptData = encrypt(data, getPublicKey(publicKey));System.out.println("加密后内容:" + encryptData);// RSA解密String decryptData = decrypt(encryptData, getPrivateKey(privateKey));System.out.println("解密后内容:" + decryptData);// RSA签名String sign = sign(data, getPrivateKey(privateKey));// RSA验签boolean result = verify(data, getPublicKey(publicKey), sign);System.out.print("验签结果:" + result);} catch (Exception e) {e.printStackTrace();System.out.print("加解密异常");}}

结果

六、RSA加密的应用

因为jsencrypt.min.js对RSA作了很好的封装,我们可以在前端页面直接引用使用。

前端js加密

**<script src="/Resource/js/jsencrypt.min.js"></script>
<script type="text/javascript">
function to_login(){var userAccount = $('#userAccount').val();var password = $('#password').val();if(userAccount==""||password==""){alert("用户名或者密码不能为空!");return;}$.ajax({type : 'POST',dataType : 'json',url : ' ${contextPath}/customer/to/loginTest',data : {userAccount :userAccount,password :getEntryptPwd(password)},success: function(data){if(data.result == -1){ alert(data.msg);}else if(data.result == 2){alert("验证成功");return;}}});
}
function getEntryptPwd(pwd){var pubKey = 'MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQC50/mvgdowH3nC5XOYQya'+'G78kYmws4b/1KJCb9zG85IJf2cmZ+9sJS80jYLRjuqFQfwwixhibLjshp4bZirvR8jIkf9yti9'+'HSGF1pHqNVag2HNyEbFFJ13c7lI+3LN5/0dByoIB3g/80R6kVMhAShzYRE6EfhBCoap6fzZfJu3QIDAQAB';var encrypt = new JSEncrypt();encrypt.setPublicKey(pubKey);return encrypt.encrypt(pwd);
}
</script>**

解密参考上面的解密就可以了

京东的登录页面

搞定!!!
喜欢的可以关注公众号,海量学习资料免费送~

原创|RSA加密详解,京东登录页面都在用加密有什么好?相关推荐

  1. IOS之RSA加密解密与后台之间的双向加密详解

    IOS之RSA加密解密与后台之间的双向加密详解 序言 因为项目中需要用到RSA加密,刚开始也是有点乱,这两天也整理的差不多了,希望能帮到大家. 这次先上代码,我想大部分人肯定是着急解决问题,所以不要废 ...

  2. 微信公众号登录密码参数加密详解

    微信公众号登录密码pwd参数加密详解 前言 此参数的加密没有任何难度,适合小白练手学习. 网址:https://mp.weixin.qq.com/ 一.打开浏览器开始抓包 输入错误的账号密码,登录.然 ...

  3. RSA加密 — 详解

    转载请标明出处:http://blog.csdn.net/zhaoyanjun6/article/details/120316606 本文出自[赵彦军的博客] 文章目录 推荐 RSA 简介 RSA 常 ...

  4. AES加密 — 详解

    转载请标明出处:http://blog.csdn.net/zhaoyanjun6/article/details/120285594 本文出自[赵彦军的博客] 文章目录 推荐 AES 简介 对称加密 ...

  5. python实现非对称加密算法_Python3非对称加密算法RSA实例详解

    本文实例讲述了Python3非对称加密算法RSA.分享给大家供大家参考,具体如下: python3 可以使用 Crypto.PublicKey.RSA 和 rsa 生成公钥.私钥. 其中 python ...

  6. java加密算法入门(三)-非对称加密详解

    1.简单介绍 这几天一直在看非对称的加密,相比之前的两篇内容,这次看了两倍多的时间还云里雾里的,所以这篇文章相对之前的两篇,概念性的东西多了些,另外是代码的每一步我都做了介绍,方便自己以后翻阅,也方便 ...

  7. Android传输数据时加密详解

    Android传输数据时加密详解 ONE Goal , ONE Passion ! ------–MD5加密------- MD5即Message-Digest Algorithm 5(信息-摘要算法 ...

  8. 案例:京东登录页面css创建

    京东登录页面 效果图 一.整体html代码 <!DOCTYPE html> <html><head><meta charset="utf-8&quo ...

  9. mysql数据库表添加加密密码_数据库账号密码加密详解及实例

    数据库账号密码加密详解及实例 数据库中经常有对数据库账号密码的加密,但是碰到一个问题,在使用UserService对密码进行加密的时候,spring security 也是需要进行同步配置的,因为sp ...

最新文章

  1. typedef VS #define —— C语言中的 关键字 与 C指令
  2. 文艺青年的两门必修课——绘画与音乐
  3. Spring 中经典的 9 种设计模式,打死也要记住啊!
  4. JDK各版本新特性总结
  5. python正则判断列表是否有元素,python – 从列表中删除正则表达式元素
  6. feign直接走熔断_四、Spring Cloud之熔断处理 Hystrix
  7. 迭代器 生成器 面向过程编程
  8. python爬取京东手机配置信息(正则)
  9. libreoffice word转pdf时中文乱码问题解决
  10. title属性,显示出提示文字;alt属性,在浏览器无法显示图片的时候,用alt中的文字替代。不要把title和alt的作用混乱了~
  11. pixhawk通信机制
  12. 水星路由器设置显示服务器,水星路由器设置的方法
  13. RobotStudio 自动路径
  14. AI实战:深度学习必须使用大量数据?数据量对深度学习的重要性可能超乎你的想象!
  15. Python-Django毕业设计交通违章举报平台(程序+Lw)
  16. 3D美术人员Technical Artist(TA技术美术)的学习之旅(2)
  17. 计算机数值仿真及虚拟现实论文,计算机仿真论文- 计算机仿真技术及其发展.doc...
  18. 2021年12月中国A股生物制品行业上市企业市值排行榜:百济神州-U位居第二,康希诺-U股价最高(附月榜TOP43详单)
  19. html5炫酷作品源代码,8个超炫酷的HTML5动画演示及源码
  20. 第二届“中科实数杯”全国电子数据取证 wp

热门文章

  1. Revit Lookup相关问题解答
  2. 基于ROS机器人的3D物体识别与三维重建(一) 介绍篇
  3. HTML头部(head)
  4. 4.23 详细讲解混合工具的使用 [Illustrator CC教程]
  5. NLP大火的Prompt能用到其他领域吗?清华孙茂松组的CPT了解一下
  6. 服务器被DDoS攻击了怎么办?
  7. 野牛物联网-新版华为OC云平台配置教程
  8. iPhoneXR会在中国热销?可能过于乐观了
  9. 【91xcz】Windows 8应用分组及组命名
  10. 开挂的程序员,都有这项底层竞争力!