Coder.java

package com.sign.utils.rsa;

import java.security.MessageDigest;
import sun.misc.BASE64Decoder;
import sun.misc.BASE64Encoder;

public class Coder {

    public static final String KEY_SHA="SHA";
    public static final String KEY_MD5="MD5";

         /**
          * BASE64解密
          * @param key
          * @return
          * @throws Exception
          */
         public static byte[] decryptBASE64(String key) throws Exception{
             return (new BASE64Decoder()).decodeBuffer(key);
        }
         /**
          * BASE64加密
          * @param key
          * @return
          * @throws Exception
          */
         public static String encryptBASE64(byte[] key)throws Exception{
             return (new BASE64Encoder()).encodeBuffer(key);
                     }

         /**
          * MD5加密
          * @param data
          * @return
         * @throws Exception
          */
         public static byte[] encryptMD5(byte[] data)throws Exception{
             MessageDigest md5 = MessageDigest.getInstance(KEY_MD5);
             md5.update(data);
             return md5.digest();
         }

         /**
          * SHA加密
          * @param data
          * @return
          * @throws Exception
          */
         public static byte[] encryptSHA(byte[] data)throws Exception{
             MessageDigest sha = MessageDigest.getInstance(KEY_SHA);
             sha.update(data);
             return sha.digest();
         }

}

Rsa.java

package com.sign.utils.rsa;

import java.security.Key;
import java.security.KeyFactory;
import java.security.KeyPair;
import java.security.KeyPairGenerator;
import java.security.PrivateKey;
import java.security.PublicKey;
import java.security.Signature;
import java.security.interfaces.RSAPrivateKey;
import java.security.interfaces.RSAPublicKey;
import java.security.spec.PKCS8EncodedKeySpec;
import java.security.spec.X509EncodedKeySpec;
import java.util.HashMap;
import java.util.Map;

import javax.crypto.Cipher;

import org.junit.Test;

public class Rsa extends Coder {

    public static final String KEY_ALGORTHM="RSA";//秘钥算法
    public static final String SIGNATURE_ALGORITHM="MD5withRSA";//签名算法

    public static final String PUBLIC_KEY = "RSAPublicKey";//公钥
    public static final String PRIVATE_KEY = "RSAPrivateKey";//私钥

    /*
     * 初始化密钥
     * @return
     * @throws Exception
     *  RSA加密解密的实现,需要有一对公私密钥,公私密钥的初始化如下:
     */
    public static Map<String,Object> initKey()throws Exception{
        KeyPairGenerator keyPairGenerator = KeyPairGenerator.getInstance(KEY_ALGORTHM);
        keyPairGenerator.initialize(1024);
        KeyPair keyPair = keyPairGenerator.generateKeyPair();
        //公钥
        RSAPublicKey publicKey = (RSAPublicKey) keyPair.getPublic();
        //私钥
        RSAPrivateKey privateKey =  (RSAPrivateKey) keyPair.getPrivate();

        Map<String,Object> keyMap = new HashMap<String, Object>(2);
        keyMap.put(PUBLIC_KEY, publicKey);
        keyMap.put(PRIVATE_KEY, privateKey);

        return keyMap;
        }

         /**
          * 取得公钥,并转化为String类型
          * @param keyMap
          * @return
          * @throws Exception
          */
    public static String getPublicKey(Map<String, Object> keyMap)throws Exception{
             Key key = (Key) keyMap.get(PUBLIC_KEY);
             return encryptBASE64(key.getEncoded());
         }

         /**
          * 取得私钥,并转化为String类型
          * @param keyMap
          * @return
          * @throws Exception
          */
    public static String getPrivateKey(Map<String, Object> keyMap) throws Exception{
             Key key = (Key) keyMap.get(PRIVATE_KEY);
             return encryptBASE64(key.getEncoded());
         }

         //两种加密形式
         //方法一
         /*
         * 用私钥加密
          * @param data  加密数据
          * @param key   密钥
          * @return
          * @throws Exception
          */
      public static byte[] encryptByPrivateKey(byte[] data,String key)throws Exception{
             //解密密钥
             byte[] keyBytes = decryptBASE64(key);
             //取私钥
             PKCS8EncodedKeySpec pkcs8EncodedKeySpec = new PKCS8EncodedKeySpec(keyBytes);
             KeyFactory keyFactory = KeyFactory.getInstance(KEY_ALGORTHM);
             Key privateKey = keyFactory.generatePrivate(pkcs8EncodedKeySpec);

             //对数据加密
             Cipher cipher = Cipher.getInstance(keyFactory.getAlgorithm());
             cipher.init(Cipher.ENCRYPT_MODE, privateKey);
             return cipher.doFinal(data);
         }

         /**
          * 私钥解密
          * @param data  加密数据
          * @param key   密钥
          * @return
          * @throws Exception
          */
         public static byte[] decryptByPrivateKey(byte[] data,String key)throws Exception{
             //对私钥解密
             byte[] keyBytes = decryptBASE64(key);

             PKCS8EncodedKeySpec pkcs8EncodedKeySpec = new PKCS8EncodedKeySpec(keyBytes);
             KeyFactory keyFactory = KeyFactory.getInstance(KEY_ALGORTHM);
             Key privateKey = keyFactory.generatePrivate(pkcs8EncodedKeySpec);
             //对数据解密
             Cipher cipher = Cipher.getInstance(keyFactory.getAlgorithm());
             cipher.init(Cipher.DECRYPT_MODE, privateKey);
             return cipher.doFinal(data);
         }

         //方式二

          /**
          * 用公钥加密
          * @param data  加密数据
          * @param key   密钥
          * @return
          * @throws Exception
          */
         public static byte[] encryptByPublicKey(byte[] data,String key)throws Exception{
             //对公钥解密
             byte[] keyBytes = decryptBASE64(key);
             //取公钥
             X509EncodedKeySpec x509EncodedKeySpec = new X509EncodedKeySpec(keyBytes);
             KeyFactory keyFactory = KeyFactory.getInstance(KEY_ALGORTHM);
             Key publicKey = keyFactory.generatePublic(x509EncodedKeySpec);

             //对数据解密
             Cipher cipher = Cipher.getInstance(keyFactory.getAlgorithm());
             cipher.init(Cipher.ENCRYPT_MODE, publicKey);

             return cipher.doFinal(data);
         }

          /**
          * 私钥加密
          * 用公钥解密
          * @param data  加密数据
          * @param key   密钥
          * @return
          * @throws Exception
          */
         public static byte[] decryptByPublicKey(byte[] data,String key)throws Exception{
             //对私钥解密
             byte[] keyBytes = decryptBASE64(key);
             X509EncodedKeySpec x509EncodedKeySpec = new X509EncodedKeySpec(keyBytes);
             KeyFactory keyFactory = KeyFactory.getInstance(KEY_ALGORTHM);
             Key publicKey = keyFactory.generatePublic(x509EncodedKeySpec);

             //对数据解密
             Cipher cipher = Cipher.getInstance(keyFactory.getAlgorithm());
             cipher.init(Cipher.DECRYPT_MODE, publicKey);

             return cipher.doFinal(data);
         }

          /**
           * 私钥签名
          *  用私钥对信息生成数字签名
          * @param data  //加密数据
          * @param privateKey    //私钥
          * @return
          * @throws Exception
          */
         public static String sign(byte[] data,String privateKey)throws Exception{
             //解密私钥
             byte[] keyBytes = decryptBASE64(privateKey);
             //构造PKCS8EncodedKeySpec对象
             PKCS8EncodedKeySpec pkcs8EncodedKeySpec = new PKCS8EncodedKeySpec(keyBytes);
             //指定加密算法
             KeyFactory keyFactory = KeyFactory.getInstance(KEY_ALGORTHM);
             //取私钥匙对象
             PrivateKey privateKey2 = keyFactory.generatePrivate(pkcs8EncodedKeySpec);
              //用私钥对信息生成数字签名
             Signature signature = Signature.getInstance(SIGNATURE_ALGORITHM);
             signature.initSign(privateKey2);
             signature.update(data);

             return encryptBASE64(signature.sign());
         }

          /**
           * 公钥校验
          * 校验数字签名
          * @param data  加密数据
          * @param publicKey 公钥
          * @param sign  数字签名
          * @return
          * @throws Exception
          */
         public static boolean verify(byte[] data,String publicKey,String sign)throws Exception{
             //解密公钥
             byte[] keyBytes = decryptBASE64(publicKey);
             //构造X509EncodedKeySpec对象
             X509EncodedKeySpec x509EncodedKeySpec = new X509EncodedKeySpec(keyBytes);
             //指定加密算法
             KeyFactory keyFactory = KeyFactory.getInstance(KEY_ALGORTHM);
             //取公钥匙对象
             PublicKey publicKey2 = keyFactory.generatePublic(x509EncodedKeySpec);

             Signature signature = Signature.getInstance(SIGNATURE_ALGORITHM);
             signature.initVerify(publicKey2);
             signature.update(data);
             //验证签名是否正常
             return signature.verify(decryptBASE64(sign));

         }

         @Test
         public void testRsa(){
              try {
                //test();
                testSign();
            } catch (Exception e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }

         }

        public  void test() throws Exception {
             Map<String, Object> keyMap = initKey();
             String publicKey =getPublicKey(keyMap);
            String privateKey = getPrivateKey(keyMap);
             System.err.println("公钥加密——私钥解密");
             String source = "这是一行没有任何意义的文字,你看完了等于没看,不是吗?";
             System.out.println("\r加密前文字:\r\n" + source);
             byte[] data = source.getBytes();
             byte[] encodedData = encryptByPublicKey(data, publicKey);
             System.out.println("加密后文字:\r\n" + new String(encodedData));
             byte[] decodedData =decryptByPrivateKey(encodedData, privateKey);
             String target = new String(decodedData);
             System.out.println("解密后文字: \r\n" + target);
         }

        public void testSign() throws Exception {
             Map<String, Object> keyMap = initKey();
             String publicKey =getPublicKey(keyMap);
             System.out.println(publicKey+"===================================");
            String privateKey = getPrivateKey(keyMap);
             System.err.println("私钥加密——公钥解密");
             String source = "这是一行测试RSA数字签名的无意义文字";
             System.out.println("原文字:\r\n" + source);
             byte[] data = source.getBytes();
             byte[] encodedData = encryptByPrivateKey(data, privateKey);
             System.out.println("加密后:\r\n" + new String(encodedData));
             byte[] decodedData = decryptByPublicKey(encodedData, publicKey);
             String target = new String(decodedData);
             System.out.println("解密后: \r\n" + target);
             System.err.println("私钥签名——公钥验证签名");
             String sign = sign(encodedData, privateKey);
             System.err.println("签名:\r" + sign);
             boolean status = verify(encodedData, publicKey, sign);
             System.err.println("验证结果:\r" + status);
         }

}

上面生成秘钥对的时候每次都生成的不一样,一般后台和app或其他设备交互只需要两对,写在配置文件中。

java rsa加密解密的更多相关文章

  1. 【转】 java RSA加密解密实现

    [转] java RSA加密解密实现 该工具类中用到了BASE64,需要借助第三方类库:javabase64-1.3.1.jar 下载地址:http://download.csdn.net/detai ...

  2. C#-java RSA加密解密

    using Org.BouncyCastle.Math; using Org.BouncyCastle.Crypto.Parameters; using Org.BouncyCastle.Securi ...

  3. java RSA加密解密--转载

    原文地址:http://www.blogjava.net/icewee/archive/2012/05/19/378570.html 该工具类中用到了BASE64,需要借助第三方类库:javabase ...

  4. java RSA加密解密实现(含分段加密)

    该工具类中用到了BASE64,需要借助第三方类库:javabase64-1.3.1.jar 下载地址:http://download.csdn.net/detail/centralperk/50255 ...

  5. Java RSA 加密 解密 签名 验签

    原文:http://gaofulai1988.iteye.com/blog/2262802 import java.io.FileInputStream; import java.io.FileOut ...

  6. java RSA 加密解密

    package com.rsa; import java.security.KeyFactory; import java.security.KeyPair; import java.security ...

  7. C# Java间进行RSA加密解密交互

    原文:C# Java间进行RSA加密解密交互 这里,讲一下RSA算法加解密在C#和Java之间交互的问题,这两天纠结了很久,也看了很多其他人写的文章,颇受裨益,但没能解决我的实际问题,终于,还是被我捣 ...

  8. C# 与JAVA 的RSA 加密解密交互,互通,C#使用BouncyCastle来实现私钥加密,公钥解密的方法

    因为C#的RSA加密解密只有公钥加密,私钥解密,没有私钥加密,公钥解密.在网上查了很久也没有很好的实现.BouncyCastle的文档少之又少.很多人可能会说,C#也是可以的,通过Biginteger ...

  9. C# Java间进行RSA加密解密交互(二)

    原文:C# Java间进行RSA加密解密交互(二) 接着前面一篇文章C# Java间进行RSA加密解密交互,继续探讨这个问题. 在前面,虽然已经实现了C# Java间进行RSA加密解密交互,但是还是与 ...

随机推荐

  1. [TS-A1487][2013中国国家集训队第二次作业]分配游戏[二分]

    根据题意,设$3n$次比较中胜了$w$次,负了$l$次,平了$d$次,所有场次中胜了$W$次,负了$L$次,平了$D$次.如果一场赢了,那么$w-l$就会$+1$,相同地,$W-L$也会$+1$:如果 ...

  2. 递归算法详细分析->C

    C通过运行时堆栈支持递归函数的实现.递归函数就是直接或间接调用自身的函数.     许多教科书都把计算机阶乘和菲波那契数列用来说明递归,非常不幸我们可爱的著名的老潭老师的<C语言程序设计> ...

  3. ZooKeeper的应用场景(转)

    应用场景1 :统一命名服务 分布式应用中,通常需要一套完备的命令机制,既能产生唯一的标识,又方便人识别和记忆. 我们知道,每个ZNode都可以由其路径唯一标识,路径本身也比较简洁直观,另外ZNode上 ...

  4. gcc动态链接库so的制作和使用

    http://blog.csdn.net/CSqingchen/article/details/51546784 参考: http://blog.sina.com.cn/s/blog_69e96b37 ...

  5. Cookie &amp;&amp; Session &amp;&amp; Token

    Cookies Cookie的由来: HTTP 本身是一个无状态的 request/response 协议. server接收一个来自client的request, 处理完以后返回一个response ...

  6. Codeforces 510 A.Fox and Snake

    题目链接:http://codeforces.com/contest/510/problem/A A. Fox And Snake time limit per test2 seconds memor ...

  7. C语言编程入门——程序练习(上)

    大家能够敲写一下以下的练习代码.看下执行结果,都非常easy.关键要理解. if: # include <stdio.h> int main(void) { int i = 1; i = ...

  8. 2015 年度新增开源软件排名TOP100

    本榜单包括 2015 年开源中国新收录的 5977 款开源软件中,依据软件本身的关注度.活跃程度进行排名前 100 名的软件.从这份榜单中也许能够了解到最新业界的趋势. 1.SwitchyOmega ...

  9. Oracle学习(12):存储过程,函数和触发器

    存储过程和存储函数 l存储在数据库中供全部用户程序调用的子程序叫存储过程.存储函数. 注意:存储过程与存储函数声明变量时,用的是as   而不是declare 存储过程与存储函数差别 存储过程不带有返 ...

  10. 01背包模板、全然背包 and 多重背包(模板)

    转载请注明出处:http://blog.csdn.net/u012860063 贴一个自觉得解说不错的链接:http://www.cppblog.com/tanky-woo/archive/2010/ ...