国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - Java實現RSA算法的方法詳解

Java實現RSA算法的方法詳解

2021-04-18 15:44chengqiuming Java教程

這篇文章主要介紹了Java實現RSA算法的方法,結合實例形式分析了RSA算法的原理、實現與使用方法,需要的朋友可以參考下

本文實例講述了java實現rsa算法的方法。分享給大家供大家參考,具體如下:

一 介紹

唯一廣泛接受并實現
用于數據加密和數字簽名
公鑰加密、私鑰解密
私鑰加密、公鑰解密

二 rsa參數說明

Java實現RSA算法的方法詳解

三 實現

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
package com.imooc.security.rsa;
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 org.apache.commons.codec.binary.base64;
public class imoocrsa {
  private static string src = "cakin24 security rsa";
  public static void main(string[] args) {
    jdkrsa();
  }
  public static void jdkrsa() {
    try {
      //1.初始化密鑰
      keypairgenerator keypairgenerator = keypairgenerator.getinstance("rsa");
      keypairgenerator.initialize(512);
      keypair keypair = keypairgenerator.generatekeypair();
      rsapublickey rsapublickey = (rsapublickey)keypair.getpublic();
      rsaprivatekey rsaprivatekey = (rsaprivatekey)keypair.getprivate();
      system.out.println("public key : " + base64.encodebase64string(rsapublickey.getencoded()));
      system.out.println("private key : " + base64.encodebase64string(rsaprivatekey.getencoded()));
      //2.私鑰加密、公鑰解密——加密
      pkcs8encodedkeyspec pkcs8encodedkeyspec = new pkcs8encodedkeyspec(rsaprivatekey.getencoded());
      keyfactory keyfactory = keyfactory.getinstance("rsa");
      privatekey privatekey = keyfactory.generateprivate(pkcs8encodedkeyspec);
      cipher cipher = cipher.getinstance("rsa");
      cipher.init(cipher.encrypt_mode, privatekey);
      byte[] result = cipher.dofinal(src.getbytes());
      system.out.println("私鑰加密、公鑰解密——加密 : " + base64.encodebase64string(result));
      //3.私鑰加密、公鑰解密——解密
      x509encodedkeyspec x509encodedkeyspec = new x509encodedkeyspec(rsapublickey.getencoded());
      keyfactory = keyfactory.getinstance("rsa");
      publickey publickey = keyfactory.generatepublic(x509encodedkeyspec);
      cipher = cipher.getinstance("rsa");
      cipher.init(cipher.decrypt_mode, publickey);
      result = cipher.dofinal(result);
      system.out.println("私鑰加密、公鑰解密——解密:" + new string(result));
      //4.公鑰加密、私鑰解密——加密
      x509encodedkeyspec = new x509encodedkeyspec(rsapublickey.getencoded());
      keyfactory = keyfactory.getinstance("rsa");
      publickey = keyfactory.generatepublic(x509encodedkeyspec);
      cipher = cipher.getinstance("rsa");
      cipher.init(cipher.encrypt_mode, publickey);
      result = cipher.dofinal(src.getbytes());
      system.out.println("公鑰加密、私鑰解密——加密 : " + base64.encodebase64string(result));
      //5.公鑰加密、私鑰解密——解密
      pkcs8encodedkeyspec = new pkcs8encodedkeyspec(rsaprivatekey.getencoded());
      keyfactory = keyfactory.getinstance("rsa");
      privatekey = keyfactory.generateprivate(pkcs8encodedkeyspec);
      cipher = cipher.getinstance("rsa");
      cipher.init(cipher.decrypt_mode, privatekey);
      result = cipher.dofinal(result);
      system.out.println("公鑰加密、私鑰解密——解密:" + new string(result));
    } catch (exception e) {
      e.printstacktrace();
    }
  }
}

四 實現效果

public key : mfwwdqyjkozihvcnaqebbqadswawsajbajcbeob97idkkirbmx3moy5e4erwh0uvc2bcnly1rdo0lz8ibr1bl1rjxwkhv7u0aso/5dblnnngbqrtsjlscpmcaweaaq==
private key : miibvaibadanbgkqhkig9w0baqefaascat4wgge6ageaakealwf45v3sh2ssksgbhcw5jl7h5hchs68lyfw2vjwsojsvnyjthvuxveldaqe/ttqbi7/kmgweecztbg2wmwwi8widaqabakadskprsl+ew3s2n+cemizxfyyb0xhs1d84qapafpixkunvwl0a4ovrwsnwt4mejatwvtufnvtxizczdx+q5dbbaiea9tzzymgru+3mdlax0icf+niqwvlqyvedka4ksx55gvuciqcdoex6mqgrp78aqjykweogwliszju5fn/lfvkzrcgbjwihamvbblzzaykhy0ikw75kd/lksyouty+20bap+midrqgzaia6r36eerkzqubtcl8lxypb5f79htxd5dcvnib/zgp0uwigwtxi7ixhjycsnomsjdu1j3du9kqquw/eohxrk/oguye=
私鑰加密、公鑰解密——加密 : vjkfsoivelvkes5rprhsjk9tdtzohdells7yluidcyee7dkucm9srj8kwadynhi4m0olafjhk6447hp7ia8x7a==
私鑰加密、公鑰解密——解密:cakin24 security rsa
公鑰加密、私鑰解密——加密 : gawl73uxhto+efkkpmfmdhtk0vh7hb8n+30l1hp8aamiagd21h2x/q/ns+sogsoxnovunzasgzenmzzcjb4vea==
公鑰加密、私鑰解密——解密:cakin24 security rsa

五 應用場景

Java實現RSA算法的方法詳解

希望本文所述對大家java程序設計有所幫助。

原文鏈接:https://blog.csdn.net/chengqiuming/article/details/78755050

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 精品国产一级 | 国产日韩中文字幕 | 亚洲在线 | 激情欧美日韩一区二区 | 福利片一区二区 | 亚洲国产一区二区三区 | 国产黄色播放 | 成人爽a毛片一区二区免费 成年人毛片视频 | 精品日韩 | 日韩精品免费一区二区三区 | 国产激情精品视频 | 国产精品成人3p一区二区三区 | 一区二区日韩 | 日韩免费在线观看视频 | www.亚洲成人| 国产精品久久久久久久9999 | 欧洲精品在线观看 | 欧美激情视频一区二区三区在线播放 | 久久免费精品视频 | 久久久久久综合 | 91精品国产综合久久久久久丝袜 | 久久免费视频3 | 中文字幕日韩在线视频 | 日韩精品免费视频 | 精品国偷自产国产一区 | 91久久在线 | 精品午夜久久 | 中文字幕在线一区二区三区 | 国产一区在线视频播放 | 成人黄色av| 日韩欧美一区二区三区免费观看 | 亚洲综合欧美日韩 | 黄色美女网站 | 亚洲国产高清高潮精品美女 | 国产成人精品一区二区在线 | 日韩中文一区 | 一本一道久久a久久精品逆3p | 中文在线a在线 | 国产高清免费视频 | 亚洲精品成人悠悠色影视 | 成人涩涩日本国产一区 |