質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.46%
Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

プログラミング言語

プログラミング言語はパソコン上で実行することができるソースコードを記述する為に扱う言語の総称です。

Q&A

解決済

1回答

598閲覧

マルチスレッドRSAクラッキング

cha-

総合スコア6

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

プログラミング言語

プログラミング言語はパソコン上で実行することができるソースコードを記述する為に扱う言語の総称です。

0グッド

1クリップ

投稿2020/12/13 21:58

編集2020/12/14 16:03

マルチスレッドを使用して、指定されたビット長のRSAキーをクラックします。それが機能するようになったら、より長いビット長でコードを試してください。

コードの弱点は、キーの平方根からビット長で可能な最大値まで、考えられる要因を検索することです。十分に小さい範囲に達するまで検索範囲のサイズを繰り返し半分にし、その後実際の検索を開始します。

mainを変更してこのコードを改善し、ForkJoinRsaTaskの呼び出しで開始範囲が狭くなるようにし(たとえば、20000など)、これをループして範囲を最大までカバーします。可能な限り最大のビット長でコードを効率的に機能させるようにしてください。 32ビットが使用できない場合があることに注意してください。 8ビット(実際には16ビット暗号化)から徐々に作業を進めて、どこまで進むことができるかを確認してください。

このアプローチは、11〜15行目で使用されている暗号化技術を攻撃しようとします。テストのp、q、およびn値を作成した後、現在の時刻をミリ秒単位でキャプチャします。
その量を妥当な量だけデクリメントします(pとqが作成された正確な時刻がわからないふりをするため)。

Random()の可能なシード値をループしてnを因数分解し、そこからpを作成して(pをテストするだけでよいので、qは必要ありません)、pを因数としてテストします。

それが機能しない場合は、次のシードに進みます。因数分解のランダムの作成、および因数分解テストコードは、計算メソッドに表示される必要があります-範囲(iおよびmax)がテストする潜在的な因数ではなく、この範囲(i、max)がテストする可能性のあるシード値の範囲です。

作ったコードは下です。

import java.math.BigInteger;
import java.util.;
import java.util.concurrent.
;

public class Rsa {

static final BigInteger TWO = new BigInteger("2"); public static void main (String [] args) { Random r = new Random(); int bitLength = 2048; // start at 8 and double BigInteger p = BigInteger.probablePrime(bitLength, r); BigInteger q = BigInteger.probablePrime(bitLength, r); BigInteger n = p.multiply(q); System.out.println("p="+p+" q="+q+" n="+n); int calcBitLength = n.bitLength()/2; BigInteger max = TWO.pow(calcBitLength+1).subtract(BigInteger.ONE); System.out.println("bitLength="+calcBitLength+ ",\n max="+max); // nを因数分解しようとします // BigInteger i = n.sqrt(); BigInteger i = n.multiply(n); System.out.println("initial i="+i); ForkJoinPool fjPool = new ForkJoinPool(); // ForkJoinRsaTaskを機能させた後、次の行をループに入れます //検索スペースのより狭い範囲(おそらく1000または20000)を段階的に攻撃します。 //サイズをいじって、何が最適かを確認できます ForkJoinRsaTask forkJoinRsaTask = new ForkJoinRsaTask(n, i, max); fjPool.invoke(forkJoinRsaTask); }

}

class ForkJoinRsaTask extends RecursiveAction {
BigInteger i, n, max;
private static final BigInteger THRESHOLD = new BigInteger("100");

public ForkJoinRsaTask(BigInteger n, BigInteger i, BigInteger max) { this.i = i; this.n=n; this.max=max; } @Override protected void compute() { BigInteger diff = max.subtract(i);

//Random()の可能なシード値をループしてnを因数分解し、そこからpを作成して(pをテストするだけでよいので、qは必要ありません)、pを因数としてテストします。

if (diff.compareTo(THRESHOLD)<0) {

// max 未満の各素数をループし、n を除算するかどうかを確認します。 その場合は、見つ
かった値を出力し、システムを終了してすべてのスレッドを終了します
//ループを通過するたびに、BigIntegernextProbablePrime メソッドを使用してテストする
次の値を選択します
int i=0,n=0,max=0;
ForkJoinRsaTask(i,n,max);

} else {//それが機能しない場合

//リストを半分に切り、2 つの半分に対して ForkJoinRsaTask を呼び出します(マルチスレ
ッドクイックソートと同様)
List<ForkJoinRsaTask> folkjoinrsatask=new ArrayList<ForkJoinRsaTask>();
folkjoinrsatask.add(0);
folkjoinrsatask.add(1);
List<ForkJoinRsaTask> sbList = folkjoinrsatask.subList(1, 3);

} }

}

computeメソッドで、

max 未満の各素数をループし、n を除算するかどうかを確認します。 その場合は、見つ
かった値を出力し、システムを終了してすべてのスレッドを終了し、
ループを通過するたびに、BigIntegernextProbablePrime メソッドを使用してテストするために値を選択し、無理ならelseでリストを半分に切り、2 つの半分に対して ForkJoinRsaTask を呼び出します(マルチスレ
ッドクイックソートと同様)にはどうしたらいいのかわかりません。(私のコードだとエラーが出ます。)

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

y_waiwai

2020/12/13 23:13

> 迷っています で、しつもんはなんでしょうか
dodox86

2020/12/13 23:51

「迷う」と言うのは、自分の中でいくつか既にできあがっている選択肢があって、どれを使おうか悩んでいることを指します。
cha-

2020/12/14 15:52

computeのifの中はForkJoinRsaTask(i,n,max);と呼び出しをしましたが、エラーのままでです。 ループを通過するたびに、BigIntegernextProbablePrime メソッドを使用してテストってなると方法がおもいつきません elseに関してはリストを半分に切りたいですが、 List<ForkJoinRsaTask> folkjoinrsatask=new ArrayList<ForkJoinRsaTask>(); folkjoinrsatask.add(0); folkjoinrsatask.add(1); List<ForkJoinRsaTask> sbList = folkjoinrsatask.subList(1, 3); だと作動しません
cha-

2021/03/10 18:14

解決できました!
guest

回答1

0

自己解決

解決できてはいませんが、もうちょっと勉強してみます

投稿2021/03/10 18:15

cha-

総合スコア6

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.46%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問