加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

Java加密算法 RSA

发布时间:2020-12-14 23:26:19 所属栏目:Java 来源:网络整理
导读:今天PHP站长网 52php.cn把收集自互联网的代码分享给大家,仅供参考。 import java.security.KeyPair; import java.security.KeyPairGenerator; import java.security.PrivateKey; import java.security.PublicKey; import

以下代码由PHP站长网 52php.cn收集自互联网

现在PHP站长网小编把它分享给大家,仅供参考

import java.security.KeyPair;  
import java.security.KeyPairGenerator;  
import java.security.PrivateKey;  
import java.security.PublicKey;  
import java.util.Arrays;  
  
import javax.crypto.Cipher;  
  
/** 
 * RSA算法 公钥加密 非对称加密 
 * @author stone 
 * @date 2014-03-11 00:28:38 
 */  
public class RSA {  
    public static final String KEY_ALGORITHM = "RSA";  
    public static final String CIPHER_ALGORITHM_ECB1 = "RSA/ECB/PKCS1Padding";  
    public static final String CIPHER_ALGORITHM_ECB2 = "RSA/ECB/OAEPWithSHA-1AndMGF1Padding"; //不能用  
    public static final String CIPHER_ALGORITHM_ECB3 = "OAEPWithSHA-256AndMGF1Padding"; //不能用  
      
    static PublicKey publicKey;  
    static PrivateKey privateKey;  
    static Cipher cipher;  
    static KeyPair keyPair;  
      
    public static void main(String[] args) throws Exception {  
        method1("斯柯达U*(Sfsad7f()*^%%$");  
        method2("斯柯达U*(Sfsad7f()*^%%$");  
        method3("斯柯达U*(Sfsad7f()*^%%$");  
          
    }  
      
    /** 
     * 公钥加密,私钥解密    使用默认CIPHER_ALGORITHM_ECB1 
     * @param str 
     * @throws Exception 
     */  
    static void method1(String str) throws Exception {  
        KeyPairGenerator keyGenerator = KeyPairGenerator.getInstance(KEY_ALGORITHM);  
        KeyPair keyPair = keyGenerator.generateKeyPair();  
        publicKey = keyPair.getPublic();  
        privateKey = keyPair.getPrivate();  
        cipher = Cipher.getInstance(KEY_ALGORITHM);  
        cipher.init(Cipher.ENCRYPT_MODE,publicKey); //公钥加密  
        byte[] encrypt = cipher.doFinal(str.getBytes());  
        System.out.println("公钥加密后1:" + Arrays.toString(encrypt));  
          
        cipher.init(Cipher.DECRYPT_MODE,privateKey);//私钥解密  
        byte[] decrypt = cipher.doFinal(encrypt);  
        System.out.println("私钥解密后1:" + new String(decrypt));  
    }  
      
    /** 
     * 私钥加密,公钥解密    使用默认CIPHER_ALGORITHM_ECB1 
     * @param str 
     * @throws Exception 
     */  
    static void method2(String str) throws Exception {  
        KeyPairGenerator keyGenerator = KeyPairGenerator.getInstance(KEY_ALGORITHM);  
        KeyPair keyPair = keyGenerator.generateKeyPair();  
        publicKey = keyPair.getPublic();  
        privateKey = keyPair.getPrivate();  
        cipher = Cipher.getInstance(KEY_ALGORITHM);  
        cipher.init(Cipher.ENCRYPT_MODE,privateKey); //私钥加密  
        byte[] encrypt = cipher.doFinal(str.getBytes());  
        System.out.println("私钥加密后2:" + Arrays.toString(encrypt));  
          
        cipher.init(Cipher.DECRYPT_MODE,publicKey);//公钥解密  
        byte[] decrypt = cipher.doFinal(encrypt);  
        System.out.println("公钥解密后2:" + new String(decrypt));  
    }  
      
    /** 
     * 私钥加密,公钥解密    使用CIPHER_ALGORITHM_ECB1 = RSA/ECB/PKCS1Padding 
     * @param str 
     * @throws Exception 
     */  
    static void method3(String str) throws Exception {  
        KeyPairGenerator keyGenerator = KeyPairGenerator.getInstance(KEY_ALGORITHM);  
        KeyPair keyPair = keyGenerator.generateKeyPair();  
        publicKey = keyPair.getPublic();  
        privateKey = keyPair.getPrivate();  
        cipher = Cipher.getInstance(CIPHER_ALGORITHM_ECB1);  
        cipher.init(Cipher.ENCRYPT_MODE,privateKey); //私钥加密  
        byte[] encrypt = cipher.doFinal(str.getBytes());  
        System.out.println("私钥加密后3:" + Arrays.toString(encrypt));  
          
        cipher.init(Cipher.DECRYPT_MODE,publicKey);//公钥解密  
        byte[] decrypt = cipher.doFinal(encrypt);  
        System.out.println("公钥解密后3:" + new String(decrypt));  
    }  
}  

以上内容由PHP站长网【52php.cn】收集整理供大家参考研究

如果以上内容对您有帮助,欢迎收藏、点赞、推荐、分享。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读