Author

Topic: Key generator in hex format (Read 376 times)

newbie
Activity: 12
Merit: 0
February 01, 2021, 08:36:03 PM
#19
Hello.
Tell me a program for generating Private Key Hexadecimal on Linux. You need the program to generate keys randomly. Example I specify to start generating the range 00000000000000000000000000000000000000000000000000000000xxxx The program should create all possible keys in this range randomly.
newbie
Activity: 12
Merit: 0
February 06, 2020, 07:07:30 AM
#18
Thank you for trying to help me. But unfortunately I don't know how to compile the program. I have a ready-made program that can be sent from another program through a pipe the data that the program will generate. It should work like this
Code:
 generator rex | input data handler program
all I need is continuous generation of hex keys with high speed and transfer to the program handler. I would be very grateful if you describe step by step how to implement this in Linux
legendary
Activity: 3472
Merit: 10611
February 06, 2020, 12:52:40 AM
#16
generates 17000 keys per second.

if you want speed then you shouldn't be using bash and while you're at it avoid using strings (hex) altogether. you are adding a couple of bottlenecks that slow down your process.
instead write your own code and generate random keys based on what you need. you didn't say what you are using it for, so i'll guess it is nothing serious and randomness doesn't matter. for that case you can simply use a fast hash algorithm that produces 256-bit digests and hash numbers from 1 to 1 mil (or whatever message you want) and use the result as the random key. that shouldn't take any more than a  seconds or so.

I can't write this code. Can you help me with this?

compile with .net core. it takes 1.2 seconds in debug mode to generate all these hashes.
Code:
using System.Security.Cryptography;

namespace ValueGen
{
    class Program
    {
        private static byte[] max = { 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 254, 186, 174, 220, 230, 175, 72, 160, 59, 191, 210, 94, 140, 208, 54, 65, 64 };

        static void Main(string[] args)
        {
            SHA256 hash = SHA256.Create();
            for (int i = 0; i < 1_000_000; i++)
                Foo(hash.ComputeHash(new byte[4] { (byte)i, (byte)(i >> 8), (byte)(i >> 16), 0 }));
        }
        public static void Foo(byte[] key)
        {
            if (((ReadOnlySpan)key).SequenceEqual(new byte[32]) ||((ReadOnlySpan)key).SequenceEqual(max))
                return;

            // Do whatever with the key!
        }
    }
}
newbie
Activity: 12
Merit: 0
February 05, 2020, 11:05:46 AM
#15
generates 17000 keys per second.

if you want speed then you shouldn't be using bash and while you're at it avoid using strings (hex) altogether. you are adding a couple of bottlenecks that slow down your process.
instead write your own code and generate random keys based on what you need. you didn't say what you are using it for, so i'll guess it is nothing serious and randomness doesn't matter. for that case you can simply use a fast hash algorithm that produces 256-bit digests and hash numbers from 1 to 1 mil (or whatever message you want) and use the result as the random key. that shouldn't take any more than a  seconds or so.

I can't write this code. Can you help me with this?
legendary
Activity: 3472
Merit: 10611
February 05, 2020, 08:40:59 AM
#14
generates 17000 keys per second.

if you want speed then you shouldn't be using bash and while you're at it avoid using strings (hex) altogether. you are adding a couple of bottlenecks that slow down your process.
instead write your own code and generate random keys based on what you need. you didn't say what you are using it for, so i'll guess it is nothing serious and randomness doesn't matter. for that case you can simply use a fast hash algorithm that produces 256-bit digests and hash numbers from 1 to 1 mil (or whatever message you want) and use the result as the random key. that shouldn't take any more than a  seconds or so.
newbie
Activity: 12
Merit: 0
February 05, 2020, 07:19:21 AM
#13
Code:
for thing in {1..100}; do openssl rand -hex 32 >> privkeys; done
This is what I need. Tell me how to immediately send to another program through the pipe and not save to a file?
Remove the ">> privkeys" and pipe the whole thing:
Code:
for thing in {1..100}; do openssl rand -hex 32; done | wc -l
This sends it to "word count" as an example.

This is a terribly slow method for generating private keys though.

Unfortunately, this works very slowly and loads the computer's memory very much. If you set this command as
Code:
keys=60000000; openssl rand $[32*keys] | xd-p-c32
generates 17000 keys per second. But no more than 60000000 keys at a time. And I need continuous generation of keys in hex format with their transfer through a pipe to another program.
legendary
Activity: 3472
Merit: 10611
February 04, 2020, 11:41:47 PM
#12
and less than:
FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFEBAAEDCE6AF48A03BBFD25E8CD0364140

"less than or equal to" instead (or just add +1 to the value) since the order of sekp256k1 curve is FF....4141 and private keys are chosen in range of [1, n-1] and the quoted value is n-1 not n.
for reference (page 9): https://www.secg.org/sec2-v2.pdf
legendary
Activity: 3514
Merit: 4895
February 04, 2020, 09:44:08 AM
#11
Code:
for thing in {1..100}; do openssl rand -hex 32 >> privkeys; done

that'll put them in a file named privkeys. replace 100 with 1,000,000 or whatever once you are satisfied it does what you want it to.

btw this may interest you

While rare and generally unlikely, it is possible that the provided command may generate values that are out of range for a Bitcoin Private key.  To be sure that you are only generating valid private keys, you'll want to check each 32 byte value and make sure it's greater than:

0000000000000000000000000000000000000000000000000000000000000000

and less than:

FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFEBAAEDCE6AF48A03BBFD25E8CD0364140
legendary
Activity: 3290
Merit: 16489
Thick-Skinned Gang Leader and Golden Feather 2021
February 04, 2020, 09:32:50 AM
#10
Code:
for thing in {1..100}; do openssl rand -hex 32 >> privkeys; done
This is what I need. Tell me how to immediately send to another program through the pipe and not save to a file?
Remove the ">> privkeys" and pipe the whole thing:
Code:
for thing in {1..100}; do openssl rand -hex 32; done | wc -l
This sends it to "word count" as an example.

This is a terribly slow method for generating private keys though.
newbie
Activity: 12
Merit: 0
February 04, 2020, 06:58:06 AM
#9
Code:
for thing in {1..100}; do openssl rand -hex 32 >> privkeys; done

that'll put them in a file named privkeys. replace 100 with 1,000,000 or whatever once you are satisfied it does what you want it to.

btw this may interest you



This is what I need. Tell me how to immediately send to another program through the pipe and not save to a file?
legendary
Activity: 3710
Merit: 1586
February 02, 2020, 11:47:06 PM
#8
Code:
for thing in {1..100}; do openssl rand -hex 32 >> privkeys; done

that'll put them in a file named privkeys. replace 100 with 1,000,000 or whatever once you are satisfied it does what you want it to.

btw this may interest you

newbie
Activity: 12
Merit: 0
February 02, 2020, 09:51:10 PM
#7
You can try https://sourceforge.net/projects/pwgen-win/
This is also under Linux
On my pc it can generate 1M keys for 3-4sec, file size 60Mb for 1B will 60Gb  Wink

https://i.ibb.co/KFbHfRY/screenshot-10.jpg

https://i.ibb.co/B3wSjS4/screenshot-8.jpg


Thanks. Tell me How to run linux in the terminal?
newbie
Activity: 12
Merit: 0
February 02, 2020, 09:27:31 PM
#6
I need continuous generation of random keys
Can you share what you're trying to accomplish?
Unfortunately, I can't say what I need it for yet.
full member
Activity: 211
Merit: 101
February 02, 2020, 04:41:07 PM
#5
You can try https://sourceforge.net/projects/pwgen-win/
This is also under Linux
On my pc it can generate 1M keys for 3-4sec, file size 60Mb for 1B will 60Gb  Wink




legendary
Activity: 3290
Merit: 16489
Thick-Skinned Gang Leader and Golden Feather 2021
February 02, 2020, 01:02:41 PM
#4
I need continuous generation of random keys
Can you share what you're trying to accomplish?
newbie
Activity: 12
Merit: 0
February 02, 2020, 12:31:44 PM
#3
Something like https://github.com/matja/bitcoin-tool ?

I'm not sure what would be the most efficient library to generate millions of keys in HEX format (or why you would want HEX format, as you'd lose compression data(?))
But i guess you could also use https://github.com/bitcoinjs/bitcoinjs-lib

I tried the command keys=1000; openssl rand $[32*keys] | xd-pc 32
but more than 60000000 at a time does not generate I need continuous generation of random keys
legendary
Activity: 1946
Merit: 1427
February 02, 2020, 12:12:17 PM
#2
Something like https://github.com/matja/bitcoin-tool ?

I'm not sure what would be the most efficient library to generate millions of keys in HEX format.
But i guess you could also use https://github.com/bitcoinjs/bitcoinjs-lib (But again, for something more efficient you might want to use a more low-level language..)
newbie
Activity: 12
Merit: 0
February 02, 2020, 05:50:46 AM
#1
Hi, everybody.
Tell me how I can generate millions of keys in hex format with output one per line without any extra characters?
This should work on Linux
Jump to: