I’m looking to secure the software update procedure for a little device I’m maintaining that runs Linux. I want to generate an md5sum of the update package’s contents and then encrypt that hash with a private key before sending it out to the customer. When they load the update, the device should then decrypt the hash, verify it, and proceed with installation of the package.
I’m trying to do this with OpenSSL and RSA. I found this thread, and was discouraged. I then found this thread and wondered how Perl gets around the purported impossibility of it all. I’m doing this in C, so perhaps there’s a parallel function in an SSL library somewhere?
So my question really is: can I force command line Linux to take a public key as the decryption input, or perhaps use C to circumvent that limitation?
Thanks in advance, all.
Let’s assume you have generated a public and private RSA key using
openssl genrsa:You can sign something with the private key like this:
You can verify this data using the public key:
Is this what you’re looking for?