當前位置: 首頁>>代碼示例>>C#>>正文


C# SecureRandom.SetSeed方法代碼示例

本文整理匯總了C#中Org.BouncyCastle.Security.SecureRandom.SetSeed方法的典型用法代碼示例。如果您正苦於以下問題:C# SecureRandom.SetSeed方法的具體用法?C# SecureRandom.SetSeed怎麽用?C# SecureRandom.SetSeed使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Org.BouncyCastle.Security.SecureRandom的用法示例。


在下文中一共展示了SecureRandom.SetSeed方法的6個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: GenerateNewMachineKey

        private static SecureString GenerateNewMachineKey(int keySize)
        {
            var random = new SecureRandom();
            random.SetSeed(random.GenerateSeed(128));

            var machineKeyString = "";
            for (var x = 0; x < keySize; x++)
            {
                machineKeyString += (char)random.Next(33, 126);
            }

            return machineKeyString.ConvertToSecureString();
        }
開發者ID:mRemoteNG,項目名稱:mRemoteNG,代碼行數:13,代碼來源:EncryptedSecureString.cs

示例2: RandMult

        private void RandMult(string label, X9ECParameters spec)
        {
            ECCurve C = spec.Curve;
            ECPoint G = (ECPoint)spec.G;
            BigInteger n = spec.N;

            SecureRandom random = new SecureRandom();
            random.SetSeed(DateTimeUtilities.CurrentUnixMs());

            Console.WriteLine(label);

            int[] coords = ECCurve.GetAllCoordinateSystems();
            for (int i = 0; i < coords.Length; ++i)
            {
                int coord = coords[i];
                if (C.SupportsCoordinateSystem(coord))
                {
                    ECCurve c = C;
                    ECPoint g = G;

                    bool defaultCoord = (c.CoordinateSystem == coord);
                    if (!defaultCoord)
                    {
                        c = C.Configure().SetCoordinateSystem(coord).Create();
                        g = c.ImportPoint(G);
                    }

                    double avgRate = RandMult(random, g, n);
                    string coordName = COORD_NAMES[coord];
                    StringBuilder sb = new StringBuilder();
                    sb.Append("   ");
                    sb.Append(defaultCoord ? '*' : ' ');
                    sb.Append(coordName);
                    for (int j = sb.Length; j < 30; ++j)
                    {
                        sb.Append(' ');
                    }
                    sb.Append(": ");
                    sb.Append(avgRate);
                    sb.Append(" mults/sec");
                    for (int j = sb.Length; j < 64; ++j)
                    {
                        sb.Append(' ');
                    }
                    sb.Append('(');
                    sb.Append(1000.0 / avgRate);
                    sb.Append(" millis/mult)");
                    Console.WriteLine(sb.ToString());
                }
            }
        }
開發者ID:KimikoMuffin,項目名稱:bc-csharp,代碼行數:51,代碼來源:ECPointPerformanceTest.cs

示例3: PerformTest

        public override void PerformTest()
        {
            SecureRandom    rand = new SecureRandom(new byte[20]);

            rand.SetSeed(DateTime.Now.Ticks);

            doTestPadding(new Pkcs7Padding(), rand,
                Hex.Decode("ffffff0505050505"),
                Hex.Decode("0000000004040404"));

            Pkcs7Padding padder = new Pkcs7Padding();
            try
            {
                padder.PadCount(new byte[8]);

                Fail("invalid padding not detected");
            }
            catch (InvalidCipherTextException e)
            {
                if (!"pad block corrupted".Equals(e.Message))
                {
                    Fail("wrong exception for corrupt padding: " + e);
                }
            }

            doTestPadding(new ISO10126d2Padding(), rand,
                null,
                null);

            doTestPadding(new X923Padding(), rand,
                null,
                null);

            doTestPadding(new TbcPadding(), rand,
                Hex.Decode("ffffff0000000000"),
                Hex.Decode("00000000ffffffff"));

            doTestPadding(new ZeroBytePadding(), rand,
                Hex.Decode("ffffff0000000000"),
                null);

            doTestPadding(new ISO7816d4Padding(), rand,
                Hex.Decode("ffffff8000000000"),
                Hex.Decode("0000000080000000"));
        }
開發者ID:RecursosOnline,項目名稱:c-sharp,代碼行數:45,代碼來源:PaddingTest.cs

示例4: Test1000

		public void Test1000()
		{
			byte[] testData = new byte[10000];
			SecureRandom rand = new SecureRandom();

			rand.SetSeed(0);

			for (int i = 0; i != 10; i++)
			{
				CmsCompressedDataStreamGenerator gen = new CmsCompressedDataStreamGenerator();
				MemoryStream bOut = new MemoryStream();

				Stream cOut = gen.Open(bOut, CmsCompressedDataStreamGenerator.ZLib);

				rand.NextBytes(testData);

				cOut.Write(testData, 0, testData.Length);

				cOut.Close();

				CmsCompressedDataParser ed = new CmsCompressedDataParser(bOut.ToArray());

				Assert.IsTrue(Arrays.AreEqual(testData, CmsTestUtil.StreamToByteArray(ed.GetContent().ContentStream)));
			}
		}
開發者ID:KimikoMuffin,項目名稱:bc-csharp,代碼行數:25,代碼來源:CompressedDataStreamTest.cs

示例5: RandomTests

 private void RandomTests()
 {
     SecureRandom srng = new SecureRandom();
     srng.SetSeed(DateTimeUtilities.CurrentUnixMs());
     for (int i = 0; i < 10; ++i)
     {
         RandomTest(srng);
     }
 }
開發者ID:KimikoMuffin,項目名稱:bc-csharp,代碼行數:9,代碼來源:OCBTest.cs

示例6: RandomTests

 private void RandomTests()
 {
     SecureRandom srng = new SecureRandom();
     srng.SetSeed(DateTimeUtilities.CurrentUnixMs());
     RandomTests(srng, null);
     RandomTests(srng, new BasicGcmMultiplier());
     RandomTests(srng, new Tables8kGcmMultiplier());
     RandomTests(srng, new Tables64kGcmMultiplier());
 }
開發者ID:KimikoMuffin,項目名稱:bc-csharp,代碼行數:9,代碼來源:GCMTest.cs


注:本文中的Org.BouncyCastle.Security.SecureRandom.SetSeed方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。