zoukankan      html  css  js  c++  java
  • Android之RAS加密算法测试

    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.interfaces.RSAPrivateKey;   
    import java.security.interfaces.RSAPublicKey;   
    import java.security.spec.PKCS8EncodedKeySpec;   
    import java.security.spec.X509EncodedKeySpec;   
        
    import javax.crypto.Cipher;   
        
    import sun.misc.BASE64Decoder;   
    import sun.misc.BASE64Encoder;   
        
        
    public class RSAHelper {   
        
            
          public static PublicKey getPublicKey(String key) throws Exception {   
                byte[] keyBytes;   
                keyBytes = (new BASE64Decoder()).decodeBuffer(key);   
        
                X509EncodedKeySpec keySpec = new X509EncodedKeySpec(keyBytes);   
                KeyFactory keyFactory = KeyFactory.getInstance("RSA");   
                PublicKey publicKey = keyFactory.generatePublic(keySpec);   
                return publicKey;   
          }   
            
          public static PrivateKey getPrivateKey(String key) throws Exception {   
                byte[] keyBytes;   
                keyBytes = (new BASE64Decoder()).decodeBuffer(key);   
        
                PKCS8EncodedKeySpec keySpec = new PKCS8EncodedKeySpec(keyBytes);   
                KeyFactory keyFactory = KeyFactory.getInstance("RSA");   
                PrivateKey privateKey = keyFactory.generatePrivate(keySpec);   
                return privateKey;   
          }   
        
            
          public static String getKeyString(Key key) throws Exception {   
                byte[] keyBytes = key.getEncoded();   
                String s = (new BASE64Encoder()).encode(keyBytes);   
                return s;   
          }   
        
        
          public static void main(String[] args) throws Exception {   
        
                KeyPairGenerator keyPairGen = KeyPairGenerator.getInstance("RSA");   
                //密钥位数   
                keyPairGen.initialize(1024);   
                //密钥对   
                KeyPair keyPair = keyPairGen.generateKeyPair();   
        
                // 公钥   
                PublicKey publicKey = (RSAPublicKey) keyPair.getPublic();   
        
                // 私钥   
                PrivateKey privateKey = (RSAPrivateKey) keyPair.getPrivate();   
        
                String publicKeyString = getKeyString(publicKey);   
                System.out.println("public:
    " + publicKeyString);   
        
                String privateKeyString = getKeyString(privateKey);   
                System.out.println("private:
    " + privateKeyString);   
        
                //加解密类   
                Cipher cipher = Cipher.getInstance("RSA");//Cipher.getInstance("RSA/ECB/PKCS1Padding");   
        
                //明文   
                byte[] plainText = "我们都很好!邮件:@sina.com".getBytes();   
        
                //加密   
                cipher.init(Cipher.ENCRYPT_MODE, publicKey);   
                byte[] enBytes = cipher.doFinal(plainText);   
        
               //通过密钥字符串得到密钥   
                publicKey = getPublicKey(publicKeyString);   
                privateKey = getPrivateKey(privateKeyString);   
        
                //解密   
                cipher.init(Cipher.DECRYPT_MODE, privateKey);   
                byte[]deBytes = cipher.doFinal(enBytes);   
        
                publicKeyString = getKeyString(publicKey);   
                System.out.println("public:
    " +publicKeyString);   
        
                privateKeyString = getKeyString(privateKey);   
                System.out.println("private:
    " + privateKeyString);   
        
                String s = new String(deBytes);   
                System.out.println(s);   
        
        
          }   
        
    }   
  • 相关阅读:
    jquery及相关兼容插件的版本搭配
    jquery IE7 下报错:SCRIPT257: 由于出现错误 80020101 而导致此项操作无法完成
    兼顾php和jquery新版本的checkbox的写法
    jquery.validate动态更改校验规则 【转】
    Google的10大座右铭
    用jQuery屏蔽掉按回车键时提交表单
    sizeof()和strlen()在求字符串长度时的差别
    Matlab使用心得
    C++ 数据类型及相关问题 及输出精度控制
    原生javascript满屏上下滚动
  • 原文地址:https://www.cnblogs.com/lee0oo0/p/3314599.html
Copyright © 2011-2022 走看看