RC2CryptoServiceProvider クラス

定義

RC2 アルゴリズムの暗号サービス プロバイダー (CSP: Cryptographic Service Provider) 実装にアクセスするためのラッパー オブジェクトを定義します。Defines a wrapper object to access the cryptographic service provider (CSP) implementation of the RC2 algorithm. このクラスは継承できません。This class cannot be inherited.

public ref class RC2CryptoServiceProvider sealed : System::Security::Cryptography::RC2
[System.Runtime.InteropServices.ComVisible(true)]
public sealed class RC2CryptoServiceProvider : System.Security.Cryptography.RC2
type RC2CryptoServiceProvider = class
    inherit RC2
Public NotInheritable Class RC2CryptoServiceProvider
Inherits RC2
継承
RC2CryptoServiceProvider
属性

次のコード例では、文字列を暗号化してから復号化します。The following code example encrypts and then decrypts a string.

using System;
using System.IO;
using System.Text;
using System.Security.Cryptography;

namespace RC2CryptoServiceProvider_Examples
{
    class MyMainClass
    {
        public static void Main()
        {

            // Create a new instance of the RC2CryptoServiceProvider class
            // and automatically generate a Key and IV.
            RC2CryptoServiceProvider rc2CSP = new RC2CryptoServiceProvider();

            Console.WriteLine("Effective key size is {0} bits.", rc2CSP.EffectiveKeySize);

            // Get the key and IV.
            byte[] key = rc2CSP.Key;
            byte[] IV = rc2CSP.IV;

            // Get an encryptor.
            ICryptoTransform encryptor = rc2CSP.CreateEncryptor(key, IV);

            // Encrypt the data as an array of encrypted bytes in memory.
            MemoryStream msEncrypt = new MemoryStream();
            CryptoStream csEncrypt = new CryptoStream(msEncrypt, encryptor, CryptoStreamMode.Write);

            // Convert the data to a byte array.
            string original = "Here is some data to encrypt.";
            byte[] toEncrypt = Encoding.ASCII.GetBytes(original);

            // Write all data to the crypto stream and flush it.
            csEncrypt.Write(toEncrypt, 0, toEncrypt.Length);
            csEncrypt.FlushFinalBlock();

            // Get the encrypted array of bytes.
            byte[] encrypted = msEncrypt.ToArray();

            ///////////////////////////////////////////////////////
            // This is where the data could be transmitted or saved.          
            ///////////////////////////////////////////////////////

            //Get a decryptor that uses the same key and IV as the encryptor.
            ICryptoTransform decryptor = rc2CSP.CreateDecryptor(key, IV);

            // Now decrypt the previously encrypted message using the decryptor
            // obtained in the above step.
            MemoryStream msDecrypt = new MemoryStream(encrypted);
            CryptoStream csDecrypt = new CryptoStream(msDecrypt, decryptor, CryptoStreamMode.Read);

            // Read the decrypted bytes from the decrypting stream
            // and place them in a StringBuilder class.

            StringBuilder roundtrip = new StringBuilder();
            
            int b = 0;

            do
            {
                b = csDecrypt.ReadByte();
                
                if (b != -1)
                {
                    roundtrip.Append((char)b);
                }

            } while (b != -1);
 

            // Display the original data and the decrypted data.
            Console.WriteLine("Original:   {0}", original);
            Console.WriteLine("Round Trip: {0}", roundtrip);

            Console.ReadLine();
        }
    }
}
Imports System.IO
Imports System.Text
Imports System.Security.Cryptography



Module Crypto

    Sub Main()

        ' Create a new instance of the RC2CryptoServiceProvider class
        ' and automatically generate a Key and IV.
        Dim rc2CSP As New RC2CryptoServiceProvider()

        Console.WriteLine("Effective key size is {0} bits.", rc2CSP.EffectiveKeySize)

        ' Get the key and IV.
        Dim key As Byte() = rc2CSP.Key
        Dim IV As Byte() = rc2CSP.IV

        ' Get an encryptor.
        Dim encryptor As ICryptoTransform = rc2CSP.CreateEncryptor(key, IV)

        ' Encrypt the data as an array of encrypted bytes in memory.
        Dim msEncrypt As New MemoryStream()
        Dim csEncrypt As New CryptoStream(msEncrypt, encryptor, CryptoStreamMode.Write)

        ' Convert the data to a byte array.
        Dim original As String = "Here is some data to encrypt."
        Dim toEncrypt As Byte() = Encoding.ASCII.GetBytes(original)

        ' Write all data to the crypto stream and flush it.
        csEncrypt.Write(toEncrypt, 0, toEncrypt.Length)
        csEncrypt.FlushFinalBlock()

        ' Get the encrypted array of bytes.
        Dim encrypted As Byte() = msEncrypt.ToArray()

        '''''''''''''''''''''''''''''''''''''''''''''''''''''''
        ' This is where the data could be transmitted or saved.          
        '''''''''''''''''''''''''''''''''''''''''''''''''''''''

        'Get a decryptor that uses the same key and IV as the encryptor.
        Dim decryptor As ICryptoTransform = rc2CSP.CreateDecryptor(key, IV)

        ' Now decrypt the previously encrypted message using the decryptor
        ' obtained in the above step.
        Dim msDecrypt As New MemoryStream(encrypted)
        Dim csDecrypt As New CryptoStream(msDecrypt, decryptor, CryptoStreamMode.Read)

        ' Read the decrypted bytes from the decrypting stream
        ' and place them in a StringBuilder class.
        Dim roundtrip As New StringBuilder()

        Dim b As Integer = 0

        Do
            b = csDecrypt.ReadByte()

            If b <> -1 Then
                roundtrip.Append(ChrW(b))
            End If
        Loop While b <> -1

        ' Display the original data and the decrypted data.
        Console.WriteLine("Original:   {0}", original)
        Console.WriteLine("Round Trip: {0}", roundtrip)

        Console.ReadLine()

    End Sub
End Module

注釈

このRC2CryptoServiceProvider実装では、40ビットから128ビットまでのキー長を8ビット単位でサポートしています。The RC2CryptoServiceProvider implementation supports key lengths from 40 bits to 128 bits in increments of 8 bits.

RC2CryptoServiceProviderオブジェクトは、8バイトのブロックでデータを暗号化および復号化するブロック暗号です。The RC2CryptoServiceProvider object is a block cipher that encrypts and decrypts data in blocks of 8 bytes. このクラスは、データの最後のブロックが8バイト未満の場合に埋め込みます。This class pads the final block of data if it is less than 8 bytes. この埋め込みの結果、暗号化されたデータの長さは元のプレーンテキストよりも大きくなる可能性があります。As a result of this padding, the length of encrypted data could be greater than the original plaintext.

RC2CryptoServiceProviderオブジェクトが salt を使用していないことに注意してください。Note that the RC2CryptoServiceProvider object does not use salt.

注意

新しい対称暗号化アルゴリズム (Advanced Encryption Standard (AES)) を使用できます。A newer symmetric encryption algorithm, Advanced Encryption Standard (AES), is available. RC2CryptoServiceProviderクラスではなく、 Aesアルゴリズムとその派生クラスを使用することを検討してください。Consider using the Aes algorithm and its derived classes instead of the RC2CryptoServiceProvider class. レガシRC2CryptoServiceProviderアプリケーションとデータとの互換性のためだけに使用してください。Use RC2CryptoServiceProvider only for compatibility with legacy applications and data.

コンストラクター

RC2CryptoServiceProvider()

RC2CryptoServiceProvider クラスの新しいインスタンスを初期化します。Initializes a new instance of the RC2CryptoServiceProvider class.

フィールド

BlockSizeValue

暗号操作のブロック サイズをビット単位で表します。Represents the block size, in bits, of the cryptographic operation.

(継承元 SymmetricAlgorithm)
EffectiveKeySizeValue

RC2 アルゴリズムで使用する共有キーの有効なサイズをビット単位で表します。Represents the effective size of the secret key used by the RC2 algorithm in bits.

(継承元 RC2)
FeedbackSizeValue

暗号操作のフィードバック サイズをビット単位で表します。Represents the feedback size, in bits, of the cryptographic operation.

(継承元 SymmetricAlgorithm)
IVValue

対称アルゴリズムで使用する初期化ベクター (IV) を表します。Represents the initialization vector (IV) for the symmetric algorithm.

(継承元 SymmetricAlgorithm)
KeySizeValue

対称アルゴリズムで使用する共有キーのサイズをビット単位で表します。Represents the size, in bits, of the secret key used by the symmetric algorithm.

(継承元 SymmetricAlgorithm)
KeyValue

対称アルゴリズムの共有キーを表します。Represents the secret key for the symmetric algorithm.

(継承元 SymmetricAlgorithm)
LegalBlockSizesValue

対称アルゴリズムでサポートされているブロック サイズをビット単位で指定します。Specifies the block sizes, in bits, that are supported by the symmetric algorithm.

(継承元 SymmetricAlgorithm)
LegalKeySizesValue

対称アルゴリズムでサポートされているキー サイズをビット単位で指定します。Specifies the key sizes, in bits, that are supported by the symmetric algorithm.

(継承元 SymmetricAlgorithm)
ModeValue

対称アルゴリズムで使用する暗号モードを表します。Represents the cipher mode used in the symmetric algorithm.

(継承元 SymmetricAlgorithm)
PaddingValue

対称アルゴリズムで使用する埋め込みモードを表します。Represents the padding mode used in the symmetric algorithm.

(継承元 SymmetricAlgorithm)

プロパティ

BlockSize

暗号操作のブロック サイズをビット単位で取得または設定します。Gets or sets the block size, in bits, of the cryptographic operation.

(継承元 SymmetricAlgorithm)
EffectiveKeySize

RC2 アルゴリズムで使用する共有キーの有効サイズを、ビット単位で取得または設定します。Gets or sets the effective size, in bits, of the secret key used by the RC2 algorithm.

FeedbackSize

暗号操作のフィードバック サイズをビット単位で取得または設定します。Gets or sets the feedback size, in bits, of the cryptographic operation.

(継承元 SymmetricAlgorithm)
IV

対称アルゴリズムの初期化ベクター (IV) を取得または設定します。Gets or sets the initialization vector (IV) for the symmetric algorithm.

(継承元 SymmetricAlgorithm)
Key

対称アルゴリズムの共有キーを取得または設定します。Gets or sets the secret key for the symmetric algorithm.

(継承元 SymmetricAlgorithm)
KeySize

RC2 アルゴリズムで使用する共有キーのサイズをビット単位で取得または設定します。Gets or sets the size of the secret key used by the RC2 algorithm in bits.

(継承元 RC2)
LegalBlockSizes

対称アルゴリズムでサポートされているブロック サイズをビット単位で取得します。Gets the block sizes, in bits, that are supported by the symmetric algorithm.

(継承元 SymmetricAlgorithm)
LegalKeySizes

対称アルゴリズムでサポートされているキー サイズをビット単位で取得します。Gets the key sizes, in bits, that are supported by the symmetric algorithm.

(継承元 SymmetricAlgorithm)
Mode

対称アルゴリズムの操作モードを取得または設定します。Gets or sets the mode for operation of the symmetric algorithm.

(継承元 SymmetricAlgorithm)
Padding

対称アルゴリズムで使用する埋め込みモードを取得または設定します。Gets or sets the padding mode used in the symmetric algorithm.

(継承元 SymmetricAlgorithm)
UseSalt

11 バイト長、値 0 の salt を使用してキーを作成するかどうかを指定する値を取得または設定します。Gets or sets a value that determines whether to create a key with an 11-byte-long, zero-value salt.

メソッド

Clear()

SymmetricAlgorithm クラスによって使用されているすべてのリソースを解放します。Releases all resources used by the SymmetricAlgorithm class.

(継承元 SymmetricAlgorithm)
CreateDecryptor()

現在の Key プロパティおよび初期化ベクター (IV) を使用して、対称復号化オブジェクトを作成します。Creates a symmetric decryptor object with the current Key property and initialization vector (IV).

(継承元 SymmetricAlgorithm)
CreateDecryptor(Byte[], Byte[])

指定したキー (RC2) および初期化ベクター (Key) を使用して、対称 IV 復号化オブジェクトを作成します。Creates a symmetric RC2 decryptor object with the specified key (Key) and initialization vector (IV).

CreateEncryptor()

現在の Key プロパティおよび初期化ベクター (IV) を使用して、対称暗号化オブジェクトを作成します。Creates a symmetric encryptor object with the current Key property and initialization vector (IV).

(継承元 SymmetricAlgorithm)
CreateEncryptor(Byte[], Byte[])

指定したキー (RC2) および初期化ベクター (Key) を使用して、対称 IV 暗号化オブジェクトを作成します。Creates a symmetric RC2 encryptor object with the specified key (Key) and initialization vector (IV).

Dispose()

SymmetricAlgorithm クラスの現在のインスタンスによって使用されているすべてのリソースを解放します。Releases all resources used by the current instance of the SymmetricAlgorithm class.

(継承元 SymmetricAlgorithm)
Dispose(Boolean)

SymmetricAlgorithm によって使用されているアンマネージド リソースを解放し、オプションでマネージド リソースも解放します。Releases the unmanaged resources used by the SymmetricAlgorithm and optionally releases the managed resources.

(継承元 SymmetricAlgorithm)
Equals(Object)

指定されたオブジェクトが現在のオブジェクトと等しいかどうかを判定します。Determines whether the specified object is equal to the current object.

(継承元 Object)
GenerateIV()

アルゴリズムに使用するランダムな初期化ベクター (IV) を生成します。Generates a random initialization vector (IV) to use for the algorithm.

GenerateKey()

アルゴリズムで使用するランダム キー (Key) を生成します。Generates a random key (Key) to be used for the algorithm.

GetHashCode()

既定のハッシュ関数として機能します。Serves as the default hash function.

(継承元 Object)
GetType()

現在のインスタンスの Type を取得します。Gets the Type of the current instance.

(継承元 Object)
MemberwiseClone()

現在の Object の簡易コピーを作成します。Creates a shallow copy of the current Object.

(継承元 Object)
ToString()

現在のオブジェクトを表す string を返します。Returns a string that represents the current object.

(継承元 Object)
ValidKeySize(Int32)

指定されたキー サイズが、現在のアルゴリズムに対して有効かどうかを判断します。Determines whether the specified key size is valid for the current algorithm.

(継承元 SymmetricAlgorithm)

明示的なインターフェイスの実装

IDisposable.Dispose()

SymmetricAlgorithm によって使用されているアンマネージド リソースを解放し、オプションでマネージド リソースも解放します。Releases the unmanaged resources used by the SymmetricAlgorithm and optionally releases the managed resources.

(継承元 SymmetricAlgorithm)

適用対象

こちらもご覧ください