示例#1
0
 public void WIFToKey()
 {
     foreach (Tuple <string, byte[], string> key in Keys)
     {
         Assert.AreEqual(key.Item2, ECKey.FromWalletImportFormat(key.Item1).PrivateKeyBytes);
     }
 }
示例#2
0
        public void GenerateSig()
        {
            ECKey key1 = ECKey.FromWalletImportFormat("5JQpgdeNmFSBf261z5q58eT89GJ8VQ4v4FwW1ibGkDXTB8Br7ZZ");
            ECKey key2 = ECKey.FromWalletImportFormat("5K1yDmGvZtDdFhFpXLwLFy5Z6smJZ65LqnNurG2iNTQWG2k9yci");

            byte[] raw          = new byte[] { 0x01, 0x00, 0x00, 0x00, 0x01, 0xE4, 0x1C, 0x5B, 0x7D, 0x6C, 0xF9, 0x67, 0x47, 0x45, 0x0F, 0xAB, 0xC7, 0x31, 0xEE, 0x2B, 0x7A, 0x91, 0x6B, 0x37, 0x1C, 0xDF, 0xC1, 0x9C, 0x9C, 0x6A, 0xB1, 0xBC, 0xC4, 0x1E, 0xB1, 0xE2, 0x7C, 0x06, 0x00, 0x00, 0x00, 0x8A, 0x47, 0x30, 0x44, 0x02, 0x20, 0x56, 0x37, 0x2E, 0x90, 0x4B, 0xE1, 0x15, 0xD2, 0xFC, 0x1E, 0x7C, 0xDC, 0xBC, 0x2A, 0x89, 0xB7, 0xC5, 0xC8, 0xC4, 0x3F, 0x79, 0x23, 0x12, 0x1F, 0x1D, 0xF6, 0xA8, 0xB0, 0x2C, 0xE9, 0xC3, 0xEF, 0x02, 0x20, 0x4A, 0x68, 0xD3, 0x96, 0x72, 0xA0, 0xEB, 0xB2, 0xB4, 0x65, 0x8B, 0x96, 0xB9, 0xC6, 0x2E, 0x8E, 0x25, 0x37, 0xCD, 0x98, 0x1E, 0x59, 0xE0, 0x85, 0xE6, 0x21, 0x0F, 0xC7, 0xB6, 0xDB, 0xF8, 0x3C, 0x01, 0x41, 0x04, 0xEF, 0x96, 0xE3, 0xBC, 0xCC, 0x8F, 0xFF, 0x6B, 0x21, 0xD2, 0x8E, 0x81, 0xF6, 0x1C, 0x4A, 0x93, 0xCF, 0xE0, 0xF1, 0x33, 0x21, 0x4C, 0x95, 0x47, 0xC0, 0xD6, 0x83, 0xA9, 0xFC, 0x12, 0xF5, 0x29, 0x22, 0x9C, 0x8D, 0x1A, 0xB2, 0x00, 0x04, 0xC0, 0xF7, 0xF1, 0x39, 0x61, 0x56, 0x6B, 0x65, 0x49, 0x2C, 0x62, 0x67, 0xFA, 0x45, 0x27, 0x84, 0xC0, 0x72, 0x4B, 0x4F, 0x54, 0x2E, 0x40, 0x01, 0xF1, 0xFF, 0xFF, 0xFF, 0xFF, 0x02, 0xA0, 0x86, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x19, 0x76, 0xA9, 0x14, 0xC2, 0xA3, 0xB7, 0x39, 0xCF, 0x9B, 0x8D, 0x9A, 0xC3, 0xF9, 0xE9, 0xC7, 0xCD, 0x01, 0xB0, 0xDF, 0xC0, 0xA6, 0xF3, 0xE3, 0x88, 0xAC, 0x00, 0x35, 0x0C, 0x00, 0x00, 0x00, 0x00, 0x00, 0x19, 0x76, 0xA9, 0x14, 0x06, 0xF1, 0xC4, 0xA7, 0xCD, 0x50, 0x29, 0x84, 0xB7, 0xC6, 0xEA, 0xE9, 0x5D, 0xB1, 0x76, 0xB9, 0xAE, 0x4A, 0x6E, 0x08, 0x88, 0xAC, 0x00, 0x00, 0x00, 0x00 };
            Script pubKeyScript = Script.FromString("OP_DUP OP_HASH160 06f1c4a7cd502984b7c6eae95db176b9ae4a6e08 OP_EQUALVERIFY OP_CHECKSIG");

            using (BinaryReader reader = new BinaryReader(new MemoryStream(raw))) {
                Transaction tx = new Transaction();
                tx.ReadPayload(reader);

                int trials = 3;
                for (int i = 0; i < trials; i++)
                {
                    byte[] sig1 = tx.GenerateInputSignature(key1, SigHash.All, pubKeyScript, 0);
                    byte[] sig2 = tx.GenerateInputSignature(key2, SigHash.All, pubKeyScript, 0);

                    Assert.IsTrue(tx.SigIsValid(key1.PubKey, sig1, pubKeyScript, 0));
                    Assert.IsTrue(tx.SigIsValid(key2.PubKey, sig2, pubKeyScript, 0));

                    Assert.IsFalse(tx.SigIsValid(key1.PubKey, sig2, pubKeyScript, 0));
                    Assert.IsFalse(tx.SigIsValid(key2.PubKey, sig1, pubKeyScript, 0));
                }
            }
        }