2015-06-06 08:44 511人阅读 评论(0) 收藏 举报
 分类:
JAVA(57) 

公钥加密也称为非对称加密、速度慢、加密和解密的钥匙不相同,某一个人持有私钥,任何人都可以知道公钥

  1. package com.stone.security;
  2. import java.security.KeyPair;
  3. import java.security.KeyPairGenerator;
  4. import java.security.PrivateKey;
  5. import java.security.PublicKey;
  6. import java.util.Arrays;
  7. import javax.crypto.Cipher;
  8. /**
  9. * RSA算法 公钥加密 非对称加密
  10. * @author stone
  11. * @date 2014-03-11 00:28:38
  12. */
  13. public class RSA {
  14. public static final String KEY_ALGORITHM = "RSA";
  15. public static final String CIPHER_ALGORITHM_ECB1 = "RSA/ECB/PKCS1Padding";
  16. public static final String CIPHER_ALGORITHM_ECB2 = "RSA/ECB/OAEPWithSHA-1AndMGF1Padding"; //不能用
  17. public static final String CIPHER_ALGORITHM_ECB3 = "OAEPWithSHA-256AndMGF1Padding"; //不能用
  18. static PublicKey publicKey;
  19. static PrivateKey privateKey;
  20. static Cipher cipher;
  21. static KeyPair keyPair;
  22. public static void main(String[] args) throws Exception {
  23. method1("斯柯达U*(Sfsad7f()*^%%$");
  24. method2("斯柯达U*(Sfsad7f()*^%%$");
  25. method3("斯柯达U*(Sfsad7f()*^%%$");
  26. }
  27. /**
  28. * 公钥加密,私钥解密    使用默认CIPHER_ALGORITHM_ECB1
  29. * @param str
  30. * @throws Exception
  31. */
  32. static void method1(String str) throws Exception {
  33. KeyPairGenerator keyGenerator = KeyPairGenerator.getInstance(KEY_ALGORITHM);
  34. KeyPair keyPair = keyGenerator.generateKeyPair();
  35. publicKey = keyPair.getPublic();
  36. privateKey = keyPair.getPrivate();
  37. cipher = Cipher.getInstance(KEY_ALGORITHM);
  38. cipher.init(Cipher.ENCRYPT_MODE, publicKey); //公钥加密
  39. byte[] encrypt = cipher.doFinal(str.getBytes());
  40. System.out.println("公钥加密后1:" + Arrays.toString(encrypt));
  41. cipher.init(Cipher.DECRYPT_MODE, privateKey);//私钥解密
  42. byte[] decrypt = cipher.doFinal(encrypt);
  43. System.out.println("私钥解密后1:" + new String(decrypt));
  44. }
  45. /**
  46. * 私钥加密,公钥解密    使用默认CIPHER_ALGORITHM_ECB1
  47. * @param str
  48. * @throws Exception
  49. */
  50. static void method2(String str) throws Exception {
  51. KeyPairGenerator keyGenerator = KeyPairGenerator.getInstance(KEY_ALGORITHM);
  52. KeyPair keyPair = keyGenerator.generateKeyPair();
  53. publicKey = keyPair.getPublic();
  54. privateKey = keyPair.getPrivate();
  55. cipher = Cipher.getInstance(KEY_ALGORITHM);
  56. cipher.init(Cipher.ENCRYPT_MODE, privateKey); //私钥加密
  57. byte[] encrypt = cipher.doFinal(str.getBytes());
  58. System.out.println("私钥加密后2:" + Arrays.toString(encrypt));
  59. cipher.init(Cipher.DECRYPT_MODE, publicKey);//公钥解密
  60. byte[] decrypt = cipher.doFinal(encrypt);
  61. System.out.println("公钥解密后2:" + new String(decrypt));
  62. }
  63. /**
  64. * 私钥加密,公钥解密    使用CIPHER_ALGORITHM_ECB1 = RSA/ECB/PKCS1Padding
  65. * @param str
  66. * @throws Exception
  67. */
  68. static void method3(String str) throws Exception {
  69. KeyPairGenerator keyGenerator = KeyPairGenerator.getInstance(KEY_ALGORITHM);
  70. KeyPair keyPair = keyGenerator.generateKeyPair();
  71. publicKey = keyPair.getPublic();
  72. privateKey = keyPair.getPrivate();
  73. cipher = Cipher.getInstance(CIPHER_ALGORITHM_ECB1);
  74. cipher.init(Cipher.ENCRYPT_MODE, privateKey); //私钥加密
  75. byte[] encrypt = cipher.doFinal(str.getBytes());
  76. System.out.println("私钥加密后3:" + Arrays.toString(encrypt));
  77. cipher.init(Cipher.DECRYPT_MODE, publicKey);//公钥解密
  78. byte[] decrypt = cipher.doFinal(encrypt);
  79. System.out.println("公钥解密后3:" + new String(decrypt));
  80. }
  81. }
 
 

Java加密算法 RSA的更多相关文章

  1. Java使用RSA加密算法对内容进行加密

    什么是RSA加密算法 RSA是一种典型的非对称性加密算法,具体介绍可参考阮一峰的日志 RSA算法原理 下面是使用RSA算法对传输内容进行加密的一个简要Java案例,主要用到了三个类,大体实现如下: 对 ...

  2. Java进阶(七)Java加密技术之非对称加密算法RSA

    Java加密技术(四)--非对称加密算法RSA 非对称加密算法--RSA 基本概念 非对称加密算法是一种密钥的保密方法. 非对称加密算法需要两个密钥:公开密钥(publickey)和私有密钥(priv ...

  3. JAVA 非对称加密算法RSA

    非对称加密算法 RSA过程 : 以甲乙双方为例 1.初始化密钥 构建密钥对,生成公钥.私钥保存到keymap中 KeyPairGenerator ---> KeyPair --> RSAP ...

  4. Java加密技术(四)非对称加密算法RSA

    RSA      这样的算法1978年就出现了.它是第一个既能用于数据加密也能用于数字签名的算法.它易于理解和操作.也非常流行.算法的名字以发明者的名字命名:Ron Rivest, AdiShamir ...

  5. JAVA实现RSA加密,非对称加密算法

    RSA.java package org.icesnow.jeasywx.util.security; import java.security.Key; import java.security.K ...

  6. Java使用RSA加密解密及签名校验

    该工具类中用到了BASE64,需要借助第三方类库:javabase64-1.3.1.jar注意:RSA加密明文最大长度117字节,解密要求密文最大长度为128字节,所以在加密和解密的过程中需要分块进行 ...

  7. .NET和java的RSA互通,仅此而已

    .NET和java的RSA互通,仅此而已 在开始这篇文章之前,先请读者朋友阅读老唐的这两篇文章: 1.Java与.Net环境下RSA加密解密交互不成功的问题解决 2.Java与.Net环境下RSA加密 ...

  8. Java前端Rsa公钥加密,后端Rsa私钥解密(目前还不支持中文加密解密,其他都行)

    Base64工具类,可以让rsa编码的乱码变成一串字符序列 package com.utils; import java.io.ByteArrayInputStream; import java.io ...

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

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

随机推荐

  1. oracle连接本地数据库

    连接方式: 通过SQL Developer进行连接: 通过sql plus 进行连接: SQL Developer进行连接1.安装Oracle 11g会自带一个叫做SQL Developer的工具,它 ...

  2. 渲染引擎之Camera

    Camera, 在游戏渲染引擎里面, 如果摄影师的眼睛, 它决定了观众可以看到的游戏内容.从3D技术角度讲,Camera就是如何计算视图矩阵view matrix的模块(这里不讨论透视的方法),无论是 ...

  3. linux笔记:文件系统管理-分区、文件系统以及文件系统常用命令

    linux分区类型: linux文件系统: df(查看文件系统容量和占用): du(统计文件或目录大小): 查询和自动挂载: 挂载命令格式: 挂载光盘: 卸载光盘: 挂载U盘:

  4. vs2012中VC连接mysql

    在MySQL的安装目录下你会找到include和lib文件夹(完全安装模式下),里面分别是C接口的头文件和库文件,库文件只用libmysql.lib就好了,即把libmysql.lib拷贝到了VC++ ...

  5. 三种JS方法确定元素在数组中的索引值

    第一种:数组遍历 function search(arr,dst){ var i = arr.length; while(i-=1){ if (arr[i] == dst){ return i; } ...

  6. JavaScipt 源码解析 Sizzle选择器

    jQuery的定位就是一个DOM的操作库,那么可想而知选择器是一个至关重要的模块.Sizzle,作为一个独立全新的选择器引擎,出现在jQuery 1.3版本之后,并被John Resig作为一个开源的 ...

  7. Android开发--FrameLayout的应用

    1.简介 frameLayout为框架布局,该布局的特点为层层覆盖,即最先放置的部件位于最下层,最后放置的部件位于最上层. 2.构建 如图所示,该视图中有五个TextView.其中,tv1放置在最底层 ...

  8. HDU 1240 Asteroids! 解题报告

    //这道题做完我只有 三个感受  第一:坑: 第二 : 坑! 第三:还是坑! 咳咳  言归正传  WA了无数次之后才发现是输入进去时坐标时z, y, x的顺序输入的 题解   :  类似胜利大逃亡 只 ...

  9. cppcheck 下载与安装(Liunx)

    下载网址:https://sourceforge.net/projects/cppcheck/files/cppcheck/ 选择安装包:cppcheck-1.75.tar.gz 解压安装包:tar ...

  10. hdu 4639 Hehe

    http://acm.hdu.edu.cn/showproblem.php?pid=4639 每一段 "hehe..... " 相互独立  将每一段 "hehe..... ...