RNGCryptoServiceProviderとは? わかりやすく解説

RNGCryptoServiceProvider クラス

暗号サービス プロバイダ (CSP : Cryptographic Service Provider) によって提供され実装使用して暗号乱数ジェネレータ (RNG : Random Number Generator) を実装ます。このクラス継承できません。

名前空間: System.Security.Cryptography
アセンブリ: mscorlib (mscorlib.dll 内)
構文構文

<ComVisibleAttribute(True)> _
Public NotInheritable Class
 RNGCryptoServiceProvider
    Inherits RandomNumberGenerator
Dim instance As RNGCryptoServiceProvider
[ComVisibleAttribute(true)] 
public sealed class RNGCryptoServiceProvider
 : RandomNumberGenerator
[ComVisibleAttribute(true)] 
public ref class RNGCryptoServiceProvider sealed
 : public RandomNumberGenerator
/** @attribute ComVisibleAttribute(true) */ 
public final class RNGCryptoServiceProvider
 extends RandomNumberGenerator
ComVisibleAttribute(true) 
public final class RNGCryptoServiceProvider
 extends RandomNumberGenerator
使用例使用例

RNGCryptoServiceProvider クラス使用して乱数作成する方法次のコード例示します

'The following sample uses the Cryptography class to simulate the roll
 of a dice.
Imports System
Imports System.IO
Imports System.Text
Imports System.Security.Cryptography



Class RNGCSP
    
    ' Main method.
    Public Shared Sub Main()
        ' Roll the dice 30 times and display 
        ' the results to the console.
        Dim x As Integer
        For x = 0 To 30
            Console.WriteLine(RollDice(6))
        Next x
    End Sub 'Main
     
    ' This method simulates a roll of the dice. The input parameter
 is the 
    ' number of sides of the dice.
    Public Shared Function
 RollDice(NumSides As Integer) As
 Integer
        ' Create a byte array to hold the random value.
        Dim randomNumber(0) As Byte
        
        ' Create a new instance of the RNGCryptoServiceProvider. 
        Dim Gen As New RNGCryptoServiceProvider()
        
        ' Fill the array with a random value.
        Gen.GetBytes(randomNumber)
        
        ' Convert the byte to an integer value to make the modulus operation
 easier.
        Dim rand As Integer
 = Convert.ToInt32(randomNumber(0))
        
        ' Return the random number mod the number
        ' of sides.  The possible values are zero-
        ' based, so we add one.
        Return rand Mod NumSides + 1
    End Function 'RollDice
End Class 'CryptoMemoryStream

//The following sample uses the Cryptography class to simulate the roll
 of a dice.

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

class RNGCSP
{
    // Main method.
    public static void Main()
    {
        // Roll the dice 30 times and display 
        // the results to the console.
        for(int x = 0; x <= 30; x++)
            Console.WriteLine(RollDice(6));
    }
    
    // This method simulates a roll of the dice. The input parameter
 is the 
    // number of sides of the dice.
    public static int RollDice(int
 NumSides)
    {
        // Create a byte array to hold the random value.
        byte[] randomNumber = new byte[1];

        // Create a new instance of the RNGCryptoServiceProvider. 
        RNGCryptoServiceProvider Gen = new RNGCryptoServiceProvider();

        // Fill the array with a random value.
        Gen.GetBytes(randomNumber);

        // Convert the byte to an integer value to make the modulus
 operation easier.
        int rand = Convert.ToInt32(randomNumber[0]);

        // Return the random number mod the number
        // of sides.  The possible values are zero-
        // based, so we add one.
        return rand % NumSides + 1;
    }
}

// The following sample uses the Cryptography class
// to simulate the roll of a dice.

using namespace System;
using namespace System::IO;
using namespace System::Text;
using namespace System::Security::Cryptography;

int RollDice(int numberSides)
{
    // Create a byte array to hold the random value.
    array<Byte>^ randomNumber = gcnew array<Byte>(1);

    // Create a new instance of the RNGCryptoServiceProvider.
    RNGCryptoServiceProvider^ cryptoProvider =
        gcnew RNGCryptoServiceProvider();

    // Fill the array with a random value.
    cryptoProvider->GetBytes(randomNumber);

    // Convert the byte to an integer value to make the modulus operation
    // easier.
    int rand = Convert::ToInt32(randomNumber[0]);

    // Return the random number mod the number of sides.  The possible
    // values are zero-based, so we add one.
    return (rand % numberSides) + 1;
}
    
int main()
{
    // Roll the dice 30 times and display
    // the results to the console.
    for (int i = 0; i <= 30; i++)
    {
        Console::WriteLine(RollDice(6));
    }
}

継承階層継承階層
System.Object
   System.Security.Cryptography.RandomNumberGenerator
    System.Security.Cryptography.RNGCryptoServiceProvider
スレッド セーフスレッド セーフ
この型の public static (Visual Basic では Shared) メンバはすべて、スレッド セーフです。インスタンス メンバ場合は、スレッド セーフであるとは限りません。
プラットフォームプラットフォーム
バージョン情報バージョン情報
参照参照
関連項目
RNGCryptoServiceProvider メンバ
System.Security.Cryptography 名前空間
その他の技術情報
暗号サービス

RNGCryptoServiceProvider コンストラクタ ()

RNGCryptoServiceProvider クラス新しインスタンス初期化します。

名前空間: System.Security.Cryptography
アセンブリ: mscorlib (mscorlib.dll 内)
構文構文

Dim instance As New RNGCryptoServiceProvider
public RNGCryptoServiceProvider ()
public:
RNGCryptoServiceProvider ()
public RNGCryptoServiceProvider ()
public function RNGCryptoServiceProvider ()
使用例使用例

RNGCryptoServiceProvider クラス使用して乱数作成する方法次のコード例示します

'The following sample uses the Cryptography class to simulate the roll
 of a dice.
Imports System
Imports System.IO
Imports System.Text
Imports System.Security.Cryptography



Class RNGCSP
    
    ' Main method.
    Public Shared Sub Main()
        ' Roll the dice 30 times and display 
        ' the results to the console.
        Dim x As Integer
        For x = 0 To 30
            Console.WriteLine(RollDice(6))
        Next x
    End Sub 'Main
     
    ' This method simulates a roll of the dice. The input parameter
 is the 
    ' number of sides of the dice.
    Public Shared Function
 RollDice(NumSides As Integer) As
 Integer
        ' Create a byte array to hold the random value.
        Dim randomNumber(0) As Byte
        
        ' Create a new instance of the RNGCryptoServiceProvider. 
        Dim Gen As New RNGCryptoServiceProvider()
        
        ' Fill the array with a random value.
        Gen.GetBytes(randomNumber)
        
        ' Convert the byte to an integer value to make the modulus operation
 easier.
        Dim rand As Integer
 = Convert.ToInt32(randomNumber(0))
        
        ' Return the random number mod the number
        ' of sides.  The possible values are zero-
        ' based, so we add one.
        Return rand Mod NumSides + 1
    End Function 'RollDice
End Class 'CryptoMemoryStream

//The following sample uses the Cryptography class to simulate the roll
 of a dice.

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

class RNGCSP
{
    // Main method.
    public static void Main()
    {
        // Roll the dice 30 times and display 
        // the results to the console.
        for(int x = 0; x <= 30; x++)
            Console.WriteLine(RollDice(6));
    }
    
    // This method simulates a roll of the dice. The input parameter
 is the 
    // number of sides of the dice.
    public static int RollDice(int
 NumSides)
    {
        // Create a byte array to hold the random value.
        byte[] randomNumber = new byte[1];

        // Create a new instance of the RNGCryptoServiceProvider. 
        RNGCryptoServiceProvider Gen = new RNGCryptoServiceProvider();

        // Fill the array with a random value.
        Gen.GetBytes(randomNumber);

        // Convert the byte to an integer value to make the modulus
 operation easier.
        int rand = Convert.ToInt32(randomNumber[0]);

        // Return the random number mod the number
        // of sides.  The possible values are zero-
        // based, so we add one.
        return rand % NumSides + 1;
    }
}

// The following sample uses the Cryptography class
// to simulate the roll of a dice.

using namespace System;
using namespace System::IO;
using namespace System::Text;
using namespace System::Security::Cryptography;

int RollDice(int numberSides)
{
    // Create a byte array to hold the random value.
    array<Byte>^ randomNumber = gcnew array<Byte>(1);

    // Create a new instance of the RNGCryptoServiceProvider.
    RNGCryptoServiceProvider^ cryptoProvider =
        gcnew RNGCryptoServiceProvider();

    // Fill the array with a random value.
    cryptoProvider->GetBytes(randomNumber);

    // Convert the byte to an integer value to make the modulus operation
    // easier.
    int rand = Convert::ToInt32(randomNumber[0]);

    // Return the random number mod the number of sides.  The possible
    // values are zero-based, so we add one.
    return (rand % numberSides) + 1;
}
    
int main()
{
    // Roll the dice 30 times and display
    // the results to the console.
    for (int i = 0; i <= 30; i++)
    {
        Console::WriteLine(RollDice(6));
    }
}

プラットフォームプラットフォーム
バージョン情報バージョン情報
参照参照
関連項目
RNGCryptoServiceProvider クラス
RNGCryptoServiceProvider メンバ
System.Security.Cryptography 名前空間
その他の技術情報
暗号サービス

RNGCryptoServiceProvider コンストラクタ (CspParameters)

指定したパラメータ使用して、RNGCryptoServiceProvider クラス新しインスタンス初期化します。

名前空間: System.Security.Cryptography
アセンブリ: mscorlib (mscorlib.dll 内)
構文構文

Public Sub New ( _
    cspParams As CspParameters _
)
Dim cspParams As CspParameters

Dim instance As New RNGCryptoServiceProvider(cspParams)
public RNGCryptoServiceProvider (
    CspParameters cspParams
)
public:
RNGCryptoServiceProvider (
    CspParameters^ cspParams
)
public RNGCryptoServiceProvider (
    CspParameters cspParams
)
public function RNGCryptoServiceProvider (
    cspParams : CspParameters
)

パラメータ

cspParams

暗号化サービス プロバイダ (CSP) に渡すパラメータ

プラットフォームプラットフォーム
バージョン情報バージョン情報
参照参照
関連項目
RNGCryptoServiceProvider クラス
RNGCryptoServiceProvider メンバ
System.Security.Cryptography 名前空間
その他の技術情報
暗号サービス

RNGCryptoServiceProvider コンストラクタ (Byte[])

RNGCryptoServiceProvider クラス新しインスタンス初期化します。

名前空間: System.Security.Cryptography
アセンブリ: mscorlib (mscorlib.dll 内)
構文構文

Dim rgb As Byte()

Dim instance As New RNGCryptoServiceProvider(rgb)
public RNGCryptoServiceProvider (
    byte[] rgb
)
public:
RNGCryptoServiceProvider (
    array<unsigned char>^ rgb
)
public RNGCryptoServiceProvider (
    byte[] rgb
)
public function RNGCryptoServiceProvider (
    rgb : byte[]
)

パラメータ

rgb

バイト配列。この値は無視されます。

解説解説

このメソッドでは、RNGCryptoServiceProvider クラス直接初期化されません。このメソッド呼び出すことは、RNGCryptoServiceProvider コンストラクタ呼び出して null 参照 (Visual Basic では Nothing) を渡すことと同じです。

プラットフォームプラットフォーム
バージョン情報バージョン情報
参照参照
関連項目
RNGCryptoServiceProvider クラス
RNGCryptoServiceProvider メンバ
System.Security.Cryptography 名前空間
その他の技術情報
暗号サービス

RNGCryptoServiceProvider コンストラクタ

RNGCryptoServiceProvider クラス新しインスタンス初期化します。
オーバーロードの一覧オーバーロードの一覧

名前 説明
RNGCryptoServiceProvider () RNGCryptoServiceProvider クラス新しインスタンス初期化します。

.NET Compact Framework によってサポートされています。

RNGCryptoServiceProvider (Byte[]) RNGCryptoServiceProvider クラス新しインスタンス初期化します。

.NET Compact Framework によってサポートされています。

RNGCryptoServiceProvider (CspParameters) 指定したパラメータ使用してRNGCryptoServiceProvider クラス新しインスタンス初期化します。

.NET Compact Framework によってサポートされています。

RNGCryptoServiceProvider (String) RNGCryptoServiceProvider クラス新しインスタンス初期化します。

.NET Compact Framework によってサポートされています。

参照参照

関連項目

RNGCryptoServiceProvider クラス
RNGCryptoServiceProvider メンバ
System.Security.Cryptography 名前空間

その他の技術情報

暗号サービス

RNGCryptoServiceProvider コンストラクタ (String)

RNGCryptoServiceProvider クラス新しインスタンス初期化します。

名前空間: System.Security.Cryptography
アセンブリ: mscorlib (mscorlib.dll 内)
構文構文

Dim str As String

Dim instance As New RNGCryptoServiceProvider(str)
public RNGCryptoServiceProvider (
    string str
)
public:
RNGCryptoServiceProvider (
    String^ str
)
public RNGCryptoServiceProvider (
    String str
)
public function RNGCryptoServiceProvider (
    str : String
)

パラメータ

str

文字列入力。このパラメータ無視されます。

解説解説

このメソッドでは、RNGCryptoServiceProvider クラス直接初期化されません。このメソッド呼び出すことは、RNGCryptoServiceProvider コンストラクタ呼び出して null 参照 (Visual Basic では Nothing) を渡すことと同じです。

プラットフォームプラットフォーム
バージョン情報バージョン情報
参照参照
関連項目
RNGCryptoServiceProvider クラス
RNGCryptoServiceProvider メンバ
System.Security.Cryptography 名前空間
その他の技術情報
暗号サービス

RNGCryptoServiceProvider メソッド


パブリック メソッドパブリック メソッド

プロテクト メソッドプロテクト メソッド
参照参照

関連項目

RNGCryptoServiceProvider クラス
System.Security.Cryptography 名前空間

その他の技術情報

暗号サービス

RNGCryptoServiceProvider メンバ

暗号サービス プロバイダ (CSP : Cryptographic Service Provider) によって提供され実装使用して暗号乱数ジェネレータ (RNG : Random Number Generator) を実装ます。このクラス継承できません。

RNGCryptoServiceProvider データ型公開されるメンバを以下の表に示します


パブリック コンストラクタパブリック コンストラクタ
  名前 説明
パブリック メソッド RNGCryptoServiceProvider オーバーロードされます。 RNGCryptoServiceProvider クラス新しインスタンス初期化します。
パブリック メソッドパブリック メソッド
プロテクト メソッドプロテクト メソッド
参照参照

関連項目

RNGCryptoServiceProvider クラス
System.Security.Cryptography 名前空間

その他の技術情報

暗号サービス


このページでは「.NET Framework クラス ライブラリ リファレンス」からRNGCryptoServiceProviderを検索した結果を表示しています。
Weblioに収録されているすべての辞書からRNGCryptoServiceProviderを検索する場合は、下記のリンクをクリックしてください。
 全ての辞書からRNGCryptoServiceProvider を検索

英和和英テキスト翻訳>> Weblio翻訳
英語⇒日本語日本語⇒英語
  

辞書ショートカット

すべての辞書の索引

「RNGCryptoServiceProvider」の関連用語

RNGCryptoServiceProviderのお隣キーワード
検索ランキング

   

英語⇒日本語
日本語⇒英語
   



RNGCryptoServiceProviderのページの著作権
Weblio 辞書 情報提供元は 参加元一覧 にて確認できます。

   
日本マイクロソフト株式会社日本マイクロソフト株式会社
© 2025 Microsoft.All rights reserved.

©2025 GRAS Group, Inc.RSS