2

フルバイトで動作するVigenere暗号化/復号化関数を作成する必要があります(tcpを介してファイルを暗号化して送信し、反対側で復号化するため)。私の暗号化機能は機能しているようです(多かれ少なかれ、復号化機能なしでは実際にテストすることはできません)。

暗号化機能のコードは次のとおりです。

public static Byte[] encryptByteVigenere(Byte[] plaintext, string key) 
{

    Byte[] result= new Byte[plaintext.Length];

    key = key.Trim().ToUpper();

    int keyIndex = 0;
    int keylength = key.Length;

    for (int i = 0; i < plaintext.Length; i++)
    {
        keyIndex = keyIndex % keylength;
        int shift = (int)key[keyIndex] - 65;
        result[i] = (byte)(((int)plaintext[i] + shift) % 256);
        keyIndex++;
    }

    return result;
}

ただし、復号化関数は、ほぼ同じ方法で記述されていても、エラーが発生します。「ゼロ除算を試みました。」

復号化機能のコード:

public static Byte[] decryptByteVigenere(Byte[] ciphertext, string key)
{
    Byte[] result = new Byte[ciphertext.Length];

    key = key.Trim().ToUpper();

    int keyIndex = 0;
    int keylength = key.Length;

    for (int i = 0; i < ciphertext.Length; i++)
    {             
        keyIndex = keyIndex % keylength;
        int shift = (int)key[keyIndex] - 65;
        result[i]= (byte)(((int)ciphertext[i] + 256 - shift) % 256);
        keyIndex++;               
    }

    return result;
}

エラーポイントは、keyIndex = keyIndex%keylength;という行にあります。しかし、私が不思議に思うのは、コードが最初の関数とほとんど同じであり、問​​題を引き起こしていないように見えることです。受信したfildでテストしていますが、暗号化せずに正しく到着します。誰かがそれを手伝ってくれますか?

編集:復号化機能コードを使用しているメソッド/スレッド:

public void fileListenThread()
{         
    try
    {
        fileServer.Start();

        String receivedFileName = "test.dat";
        String key = (textKlucz.Text).ToUpper();

        while (true)
        {
            fileClient = fileServer.AcceptTcpClient();
            NetworkStream streamFileServer = fileClient.GetStream();
            int thisRead = 0;
            int blockSize = 1024;
            Byte[] dataByte = new Byte[blockSize];
            Byte[] dataByteDecrypted = new Byte[blockSize];

            FileStream fileStream = new FileStream(receivedFileName, FileMode.Create);
            while (true)
            {
                thisRead = streamFileServer.Read(dataByte, 0, blockSize);
                dataByteDecrypted = Program.decryptByteVigenere(dataByte, key);
                fileStream.Write(dataByteDecrypted, 0, thisRead);
                if (thisRead == 0)
                     break;
            }

            fileStream.Close();                 
        }
    }
    catch (SocketException e)
    {
        MessageBox.Show("SocketException: " + e, "Wystąpił wyjątek", MessageBoxButtons.OK, MessageBoxIcon.Error);               
    }
}
4

1 に答える 1

0

問題は確かに機能自体ではなく、送受信方法でした。何が問題を引き起こしたのかはまだよくわかりませんが、関数を書き直したことが役に立ちました。ご意見ありがとうございます。

将来誰かがそのような機能を必要とする場合に備えて、ここに残しておきます...たとえそれがかなり些細なことであっても。

乾杯。

于 2012-11-15T13:52:29.737 に答える