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. D - Cyclic Nacklace

    CC always becomes very depressed at the end of this month, he has checked his credit card yesterday, ...

  2. Linux排查java程序占用cpu过高的线程代码

    分几步骤: 1.通过top,查出占用CPU过高的java进程 ,比如: pid :6666 2.通过ps -mp 6666 -o THREAD,tid,time| sort -n -k1 -r 查看此 ...

  3. [Angular] Why should we using Protal

    Origianl article Protal from Angular CDK, is a way to create dynammic component. Consider an example ...

  4. 游戏人生(一),我的lua之旅:那些坑爹的CCBReaderLoad

    首先,我们说说这个CCBReaderLoad. 这个脚本是cocos2dx自带的一个lua+cocosbuilder 的工具,详细功能呐,往下看. 先来看下我遇到的一个问题: ----美工给了我一个. ...

  5. ios调用dismissViewController的一个小陷阱

    我们的APP从启动到进入主页面.是通过presentViewController构造了一个ViewController序列,类似于首页 -> 登陆页 -> 启动载入页 -> 主页面 ...

  6. java wait 与 notify sleep

    来自:http://blog.csdn.net/zyplus/article/details/6672775 有适当的代码修改. 在JAVA中,是没有类似于PV操作.进程互斥等相关的方法的.JAVA的 ...

  7. ZOJ 3814 Sawtooth Puzzle (2014年牡丹江赛区网络赛F题)

    1.题目描写叙述:点击打开链接 2.解题思路:本题是一道隐式图的搜索题目.一般来说,这类题目首先要定义状态,接下来是弄清楚状态怎样转移,以及状态怎样判重,怎样推断当前状态是否和目标状态同样.至于求解最 ...

  8. Mac关闭Iphone更新系统iTunes强制自动备份文件

    在任何时候iOS设备一连结苹果Mac电脑,电脑中的iTunes软件将自动对iOS设备进行同步和备份.虽然备份非常有用,当我们的iPhone/iPad出现问题的时候,可以直接恢复iPhone/iPad的 ...

  9. NS3网络仿真(5): 数据包分析

    快乐虾 http://blog.csdn.net/lights_joy/ 欢迎转载,但请保留作者信息 在我们生成的xml文件里.是不包括生成的数据包的数据的,在我们的脚本中加入以下的语句: point ...

  10. WPF学习笔记——DataContext 与 ItemSource

    作为一个WPF新手,在ListBox控件里,我分不清 DataContext 与 ItemSource的区别. 在实践中,似乎: <ListBox x:Name="Lst" ...