1

4 つの番号を暗号化したいのですが、今のところ暗号化されているのは 2 つだけです。メソッドをループに配置しようとしencryptましたが、2 つ以上の番号を暗号化および復号化できません。誰でもこれを手伝うことができますか?

public class TEA {

    private static int delta = 0x9E3779B9; /* a key schedule constant */

    private static int[] key = { 78945677, 87678687, 234234, 234234 };

    public void encrypt(int[] v, int[] k) {

        int v0 = v[0], v1 = v[1], sum = 0, n = 32;
        int k0 = k[0], k1 = k[1], k2 = k[2], k3 = k[3]; /* cache key */
        while (n-- > 0) {
            sum += delta;
            v0 += ((v1 << 4) + k0) ^ (v1 + sum) ^ ((v1 >>> 5) + k1);
            v1 += ((v0 << 4) + k2) ^ (v0 + sum) ^ ((v0 >>> 5) + k3);
        }
        v[0] = v0;
        v[1] = v1;
        System.out.println(v0 + "," + v1);

    }

    public void decrypt(int[] v, int[] k) {
        int v0 = v[0], v1 = v[1], sum = 0xC6EF3720, n = 32; /* set up */
        int k0 = k[0], k1 = k[1], k2 = k[2], k3 = k[3]; /* cache key */
        while (n-- > 0) {
            v1 -= ((v0 << 4) + k2) ^ (v0 + sum) ^ ((v0 >>> 5) + k3);
            v0 -= ((v1 << 4) + k0) ^ (v1 + sum) ^ ((v1 >>> 5) + k1);
            sum -= delta;
        }
        v[0] = v0;
        v[1] = v1;

        System.out.println(v0 + "," + v1);
    }

    public static void main(String[] args) throws IOException {

        TEA tea = new TEA();
        int n = 0;
        int cc[] = new int[100];

        Scanner input = new Scanner(System.in);

        for (int i = 0; i < 4; i++) {
            System.out.println("Enter 4 number to encrypt: ");
            n = input.nextInt();
            cc[i] = n;

        }

        tea.encrypt(cc, key);
        tea.decrypt(cc, key);

    }

}
4

1 に答える 1

2

encrypt()との両方decrypt()が最初の 2 つの要素で機能します。

したがって、呼び出しメソッドで配列をサイクルでシフトするか、次のような暗号化/復号化メソッドで連続するペアにサイクルを導入する必要があります

for (int idx = 0; idx < v.length; idx *= 2)
{
    int v0 = v[idx], v1 = v[idx + 1], sum = 0, n = 32;
    ...
}

UPDATEウィキペディアの例に よると、このメソッドは 2 つの整数のみを想定しています (長さの配列は想定していません)。次のように、数字をペアで渡す必要があります

for (int idx = 0; idx < 4; idx =* 2)
{
    int[] tmp = {cc[idx], cc[idx + 1};
    tea.encrypt(tmp, key);
    cc[idx] = tmp[0];
    cc[idx + 1] = tmp[1];
}

その結果、整数のペアごとに、暗号化された別の整数のペアを受け取ります。

于 2013-05-10T07:56:20.317 に答える