我使用以下命令
使用openssl生成了一个键openssl genrsa 1024
我得到了以下结果
-----BEGIN RSA PRIVATE KEY-----
MIICXAIBAAKBgQC2Lh4HLcCR76Wv3oXl6sZ7pv8l9b/66H+I6Bb86tz8RhWCmTCG
xPVgtZ+w9WutU/rqBHHZOpotX4QDksRD8dRFh6a3HwkIFQdTcDoiD39yNP8F02Gd
dAl8p/URC5jNCLMSfUK38wMocmoI1I5vqdMNrzUnOup18rl4089Z+faMKQIDAQAB
AoGBAJrL4z5iWiengxqV8yETBeU8WcJft+n0dapXzHDNAUo8Izr+AIYEBp1Ot4se
f4igu6zuae80JJ45c2u14p/5dWzN9/URmhTP8xLGjGCjltOJLLyhBPP+ZsLjqu6l
57MNV6jDqDLdRC66w4NMRCN3FACxcldIC5L6B9OA7UvO1ugBAkEA8s1o6BvufTeD
ktyOMfW0ZeLGk/6EXp8nf7BIzYhAAPtSt8DegnfYFx2XDgKnYSB15dTDIDMe/KaA
GcuUb/ZjiQJBAMATb1fFdl7PGccVPgeTaupJayHPySc9PSsACV6VIAnpcU/3NZzd
MkdIL/JsOsD+1M9uQJqvRZO4qQdjcR5Om6ECQEJGgYlB/pJdcePHomTOvcRF55CE
G9u8M8rt8qFvvJDICWcxFUulrO16XT4syUWA1825it2iNqYeSL9By63YIokCQBnm
RPw71xM/r8UleyDAYwlGbxi3EPOmkUnsDldfmltby/ixZ9xIA1CTTkvNBjsh4YY6
4qE5AxPBMaGaahVhGiECQHyQvXUNE2IUco+ZwmmLnb2ey1s5tBg7i0lEZG47G7GV
o+yKdJHpToJD8eRJA/2D+pMhQIZm8X/XDIoi1AQ/TRY=
-----END RSA PRIVATE KEY-----
使用http://lapo.it/asn1js/我已在pem
上方反编译并发现了
p = 12716592588957205057720227362856602359162165918588008158928004904780617816265357754968000322907349867949577092305558696339499022301055839537975977118688137
q = 10059832080410675679274931119486090017360564066559599189867309386706046720813347145402059918876964980032136051476889631968099168811652389989474036177869729
但是平均时间模数
n = 127931248913253271289716500205639992466284651287857358177145251825312810367993147780821624164062592337708505486275588028025122128928225266601591073331803580493341719724935049328478344297205955905466581637169109448199715137939448946445804542355907923908845024638480376219852266194827768486624319018352514599977
当它应该相等时:
N = 127926786079904340486324750015310657558743663036816604629670248604945247855865212421871439992814824964459404054462886419168595224468110358113599485755243718536935880977456835036272916419632947427885989469252242704342884476060911074859116149906854382812141105735147419775039435625802885168567201322191763704873
为什么地狱N
不等于p * q
?
这是我的openssl生成的一堆密钥,我使用的是Mac OS X Mavericks,第一个密钥有正确的N,第二个密钥不正确,我没有检查过其他密钥,但无论如何这个问题似乎都在复制,我正在使用以下openssl版本“OpenSSL 0.9.8y 2013年2月5日”:
-----BEGIN RSA PRIVATE KEY-----
MIICXQIBAAKBgQDb4ZTDCASpFV+89RzD8MYR/xASV/piyXB3+qVq+PueDqq+45EL
Xt5UE2jXanfOh3uE3G3Fi76rm08XUC0CvFB7DxFJAMvchr5LbE9x2EMDmfpuZPOI
bDI+r+XZ+KJF++h296TOnncgnXILoD1gihkld7MS9g49TwsBPOtsMJzDRQIDAQAB
AoGBAMpGFfTormjhacZJcqHqIDwz+RP27TbtetJUuNHUpJw9f+PFMwxTxJFxnZP1
tKtAxWdu5GjDaq8xW6vlrNKEbD9jg2WU/myYffNeHxNVjivzypeQzBSmcE5LKFpM
objHkvXbBkkyX8Oh6ZF/3+NOhxOVZMH7CaZ90a+xPf7ENXJBAkEA+Zx/rwrx81+D
s79thCAUU4EnMVROGFPr/V7mt9AFXjAXHRuvg49Aon23bt48jdroakV5vk0ltKO8
Z5xnRWlGNQJBAOGCSOL+zFJd6zTM+CkbgGtml+DIunr7Avfu2mZyaMv4mLo+GTRN
ctZEKhknYfydewhORLKg51WdLThoe9VG6tECQCUyIvzMnr1rkE6qygEUXrMK3fJF
49VQPCxnhe4CO6qLdAZMZ90s7a7JGRqWV2O0KUoczEWFbYb7l0nBTspTI7kCQGmT
L0BmfY3KPoWXuE62e2bMvyoTj4pn3bnpbwIrafikSAxZaj9cSvkZLIReNbeomqMG
0Y63WdZxIWyZLfBppSECQQCEIkbINrQPJHoLtD57AbptUeyaE5lQBurzXMVf84FA
OJjd5OKmEX+LYbLguzOjvkcysNEZBRphz4L07shvscBC
-----END RSA PRIVATE KEY-----
-----BEGIN RSA PRIVATE KEY-----
MIICXgIBAAKBgQDTzIPHUoq9I+Fmdc8kdpuu6BSzLAmLsXv1FKXdHSYSmqI3HRTs
ZcYDSM1Vp/Svf6jdt2uNuNt0UaXzFowT9fi+sIFE2Zlpl8nEM66YZYHJfHQXy6GR
h2ybiNcDEigasc1wBvbkdSR9RNLUnLzX6YNY+197CY6vgW0R0pzuRRR/JQIDAQAB
AoGBAKAeu3mTM4QufhdB9WoxqR0gI5YZMtZDRd1Q0NxLTx89fGmCOPFHN93/ygx5
v4h2UKneIxevq2lS2MzgPOJSUMwn14/19iujT2+jC6vHKpwcjkGrnLXdsdjowrHJ
X3tnbZC4pS/2UU8r/QKzwX957+Idn4Mt2v2sDzQj5ZoPRtfBAkEA/GLl6BXQQp/4
ymsytyM6gleLdaIklCESUc6yZpY48HJqqg3lJwy/3bgb9fYlok/DPbyiEK/p+cXL
lXycbdA6HQJBANbU2MAwpBprkyliEvb+WAvyIGuf3xCVJq3CicuWfJphtMdUEsQm
cpGbQp/0bXUuFkks/xOFMKfBkAbn7Z5tCqkCQQCffcP56ScFo2AuUpXnA50q1zXr
LX7eGRQhnHRCvfXXhQaA1m0UQ0tQStNomJdpvewMrJLh5rj+PY+MtQWJo8fFAkBm
H5RR+E1qSc0RFRAS3eGY/CaxQrRVO7HBVAMRBp6A/QVk4/Bv0h8QXJAVXapS0+/A
JWW0L9JrTLZcsg/hCdDRAkEAmHZNomd/wptVccGwXtgXIL5ElQWLL/3WEggCqOIp
c+v9IRpKND9qn1zwu3tnBrrUbmC2M8CEOnuHP+lnumc2YQ==
-----END RSA PRIVATE KEY-----
-----BEGIN RSA PRIVATE KEY-----
MIICXAIBAAKBgQCWVkOkNXkWd2QoWudAD8rrzioby2g8k1pruaclCMo2mSns++TG
S3lWgLqS2mPynNONVbqoOedLKKnGY9HYzLCOCuoq5loOYCtIcVyBVGhx4eQrZgmU
AwRqQChztrj09+omveQQF2+QW9DJZrYSsKB836iTt5oAEA3ER6fwcV3fLQIDAQAB
AoGAQKNife4H3CMFS1yaZS7lHrIL5Nt2O+VXUU4HkaLP3t3H6v77BE9bIlhC3/VK
V/wZ8YDUupP64JPhO02b4k1P83oG5SAFTb0zZwmHI1+wVnNomq0DoRPw2710a2P4
Ya09nLbuRlm6SzsAkuwmyv+fPDas8b/m15kWSP/HTKMbAPkCQQDEUaTQUg/8sPH+
jDraHpjGtVRqjkysAZhNgMH+NGWLbk3nujZj4oMfid+4Xg4/Sr5EADqr0HrSlMnV
hhlwBCxjAkEAxAodCSmu9khiuRzMzXAc/gvqdtq+fF6Zx+rTUF5HYeD7l1u3SXes
whDku23Pp41+A4axWHXHTsDlKv49m9YzLwJBAJWIEl9SgjbYmBpouVL2RyvjZf8b
kC7bsCQoVJrJUicXx2MfpNoD6BgXrj4B9hwjVDT7b7T6wPKwveNTlwCJTT0CQGNJ
W/tQCTTi5F0soO1LYuOn1U/s6ZzDrM77t5p0pWKFN+copGOpIO4I8E+dBhauKqxO
g3Nx80eHmolzynAqxDECQEmyZq1mFEpB6buwNhRmj/kyOGmA88IbovZhBT+Un/6o
heaaMVl7Hst7nhihxQ081c3mFuwnH/mjixKKkpVens8=
-----END RSA PRIVATE KEY-----
-----BEGIN RSA PRIVATE KEY-----
MIICXQIBAAKBgQCm7mMUqExF5Nq2qzQ8gLVfq5AqKQlKm47Df4H/XqH9msGNCoIx
tnH4Tbe38tzA9TDRxxYQ6oCmTRUlKqstxb0j8NK7KV63vrxhLUlCIinMk9qcTL/T
tLm7/rBSZ7M6OjupzjjQ8Idu7Jd7HVITvFDYbDtd0uDh7Hd1GCrqrHnAoQIDAQAB
AoGABjMgVuoROx9OyC3/mKenFNCIYCh6Ad1ZJgWcTGG1Xnfa7GQRhcsi3Hf2dMx+
SmRQ1dmxBhvPf12phWHaTa7kYVvyXWVbp4OYPsU24/WuVfXysmA1FhO4OJMoTEqQ
FtNGmC05vhwNge+zuyiyj+4Rvhe4CRWeAlWQT9ucOZStoAECQQDdM7qny+KGMysi
sUttOal551Ow1GsM6vo990tZP5jKD/lYkLhi4GBtib66pdqyizUhQoS5stFgvUk9
ztc8cUKBAkEAwTEOaypn6oUtDZMAiIW8a0m0bNtkXRnSb6UaG6n3VEEz8wkjg2Kx
ZJWIl+vk1JZKlJUOWrH2FhJexEOMt20uIQJBAJWVS5341ABoTb0yI42DNsYG1qN3
ocSkigCpYDzEMvBBiR6JDwdeMBci1OWnDpM6a/1H3DUvZUOD/Slc3FQ1SwECQHfO
93UoWEeNjbIkXylLXt1eWSFFMcm3ENUiG73aO0MqKJBpM3fwhbiuL4afyUq5Zckd
Y0iFoupvPAwVJDhA4mECQQCG/UmJG+N0Stt3nn16QzJwwGu7djFXFgSYn8LGIrRM
E3pfC6OMcJ3exAR5t78Bth1VLbST2S2AWNaT0d0fsSA/
-----END RSA PRIVATE KEY-----
-----BEGIN RSA PRIVATE KEY-----
MIICXQIBAAKBgQC0n8+Te4265j0QqqTyV0QnGbU/v9YWqTWAbfvNwXE5nZuJoLuP
yzL4wjcZknBjQCBLsO64a9rxZx5fmL3R+kHjcF6S8OBB9NEXRk70D+vFgHjexGR9
mOk/SXRjfFfaC/pMiSmbuJMFvGCEcii/9tpm03xYWMvpkjn1UEX69BE+TwIDAQAB
AoGADkEebJEvmjRZVVtiMQ3Z/wv0VdeZ2af45O3JFW/Ss61QfQgGRU7P8vnAx2/b
FroU0mRgMoWwfaSZrQms0UlisaI5lEQu7LbhQZqwV+Bz9h784RAHyHLoTTcHRJ/+
TvRT/naCcwzXzHoSQrXmruIbMh6w0KeqVveA9ZI7RMaAZkECQQDpv0ZWZln4ZXD0
nK96Pv78b7GwRxsBrT3qHFEMEK60B6lMK61shJxFMehb6Nh4UXVth6J295WmphsK
me53CPf5AkEAxdHcdE3ofZwiEKjV3or9aSinZA+AjUw8AqlDxkIS3EGx9qkdQWv+
2tVHJDzlRv68PmkpFotWZyBfKbbKEwzKhwJBALt5ON3FG3X5Tl4yaR9f9TzcDKS4
cvWmUBk7etl1a9lip6s7AM4fkgKBY76Lg0sE8mzVsz09l95gLSIUkckQ/WkCQQC7
BpvAFfxt7ZTDXWy+d3f42SfRUVq/vEisV22tXsDIHxBrXR48wSb1rFkTaMN4aNR+
yRvApcHtxExUeu34Lsq3AkB3HOVsRBj1UlZluiScIEfk1PX2gd84/NBbxT/mhrqi
/wb8sw7ltPobNN7vxlSu5bZG3EfjgEyCCv4EcLNB/uY6
-----END RSA PRIVATE KEY-----
-----BEGIN RSA PRIVATE KEY-----
MIICXgIBAAKBgQDqvM6BgcFGPrwR2A8tnphtH30ruwvE3RBPZk0CUzuqh7BQrPsr
oGNxP0D6ulWg/yWn25ovWjm3ksZ2TaD1PA7PVb3FbzYI3kIQIPFDX6przLwC+faH
J9tqFL1tiMUhjV7Mu8HXx44hTCA8vVbe/GwHn8y1sIZ3FIZnqAlpaFE75QIDAQAB
AoGBAJCHBWKpoHV+pM8bx2SgNFtjuu7U8I8aSTOJ2jpnQuJhPwa9KryWuQN+HaUC
WzyQPAAY7tre45CKd1VZwJOdkcOam4gdRUqrLVSXfYojDCOwn7O7Fwql26v2z42G
YNu/6umdQhsnVCpfked43d/sLuZH4keO2BQVZIS7wxUMMlm1AkEA/CEZ2RuL3Sc5
70+cGyDZ3OOfD3k/Szzz4OTA7yVFoqq6cpepWYYeJKGpno53qeg+WxHusq9TbWBS
1T3UoFz+fwJBAO5XWpiMwAKYg1GtAxkgszIDnkj9Vhe/AL81fvc9KnYFScQQAiZl
PN7MopH0n/oQM8jnXmkusQOmzpVlYBB0W5sCQQCDv7BIGPLfH45QlSMXsfTmTjNh
3JPMdw9hZ2fCD5HxzJEdLE8cLs81iRyfdAbnzCo5YIeA68kGkJz4PRUMr0t1AkBC
hfcvZPmiv9bHUTbwKIRbjU78qFkDP7iBpfjOITBcyJUSODWhadhXh15IxrJwJV2O
0aU0Tmfx0PkQEb+CWDfJAkEAzJPemI3yVYqXG2POBolG5gK2VkHEw7QCQOmMK60Z
+3H7U9F/AvoM3zpRujHBdRxdZlPSrCvbxhyavYhNXDqnjg==
-----END RSA PRIVATE KEY-----
答案 0 :(得分:2)
为什么地狱N不等于p * q?
用提供的密钥确认。但是,在使用openssl genrsa 1024
生成自己的密钥时,我无法复制。
$ ./test-rsa.exe
***** P *****
12716592588957205057720227362856602359162165918588008158928004904780617816265357
754968000322907349867949577092305558696339499022301055839537975977118688137
***** Q *****
10059832080410675679274931119486090017360564066559599189867309386706046720813347
145402059918876964980032136051476889631968099168811652389989474036177869729
***** N *****
12793124891325327128971650020563999246628465128785735817714525182531281036799314
77808216241640625923377085054862755880280251221289282252666015910733318035804933
41719724935049328478344297205955905466581637169109448199715137939448946445804542
355907923908845024638480376219852266194827768486624319018352514599977
*** Calc N ***
12792678607990434048632475001531065755874366303681660462967024860494524785586521
24218714399928148249644594040544628864191685952244681103581135994857552437185369
35880977456835036272916419632947427885989469252242704342884476060911074859116149
906854382812141105735147419775039435625802885168567201322191763704873
$ cat test-rsa.c
#include <stdio.h>
#include <stdlib.h>
#include <signal.h>
#include <openssl/bn.h>
#include <openssl/evp.h>
#include <openssl/rsa.h>
#include <openssl/pem.h>
const char s_key[] = "-----BEGIN RSA PRIVATE KEY-----\n"
"MIICXAIBAAKBgQC2Lh4HLcCR76Wv3oXl6sZ7pv8l9b/66H+I6Bb86tz8RhWCmTCG\n"
"xPVgtZ+w9WutU/rqBHHZOpotX4QDksRD8dRFh6a3HwkIFQdTcDoiD39yNP8F02Gd\n"
"dAl8p/URC5jNCLMSfUK38wMocmoI1I5vqdMNrzUnOup18rl4089Z+faMKQIDAQAB\n"
"AoGBAJrL4z5iWiengxqV8yETBeU8WcJft+n0dapXzHDNAUo8Izr+AIYEBp1Ot4se\n"
"f4igu6zuae80JJ45c2u14p/5dWzN9/URmhTP8xLGjGCjltOJLLyhBPP+ZsLjqu6l\n"
"57MNV6jDqDLdRC66w4NMRCN3FACxcldIC5L6B9OA7UvO1ugBAkEA8s1o6BvufTeD\n"
"ktyOMfW0ZeLGk/6EXp8nf7BIzYhAAPtSt8DegnfYFx2XDgKnYSB15dTDIDMe/KaA\n"
"GcuUb/ZjiQJBAMATb1fFdl7PGccVPgeTaupJayHPySc9PSsACV6VIAnpcU/3NZzd\n"
"MkdIL/JsOsD+1M9uQJqvRZO4qQdjcR5Om6ECQEJGgYlB/pJdcePHomTOvcRF55CE\n"
"G9u8M8rt8qFvvJDICWcxFUulrO16XT4syUWA1825it2iNqYeSL9By63YIokCQBnm\n"
"RPw71xM/r8UleyDAYwlGbxi3EPOmkUnsDldfmltby/ixZ9xIA1CTTkvNBjsh4YY6\n"
"4qE5AxPBMaGaahVhGiECQHyQvXUNE2IUco+ZwmmLnb2ey1s5tBg7i0lEZG47G7GV\n"
"o+yKdJHpToJD8eRJA/2D+pMhQIZm8X/XDIoi1AQ/TRY=\n"
"-----END RSA PRIVATE KEY-----\n";
int main(int argc, char* argv[])
{
UNUSED(argc), UNUSED(argv);
int rc;
FILE* fd = NULL;
EVP_PKEY* pkey = NULL;
RSA* rsa = NULL;
BIGNUM* n = NULL;
BN_CTX* ctx = NULL;
fd = fopen("./key.pem", "w+");
if(fd == NULL) exit(1);
rc = fwrite(s_key, 1, sizeof(s_key), fd);
if(rc != sizeof(s_key)) exit(2);
rc = fseek(fd, 0, SEEK_SET);
if(rc != 0) exit(3);
pkey = PEM_read_PrivateKey(fd, NULL, NULL, NULL);
if(pkey == NULL) exit(4);
rsa = EVP_PKEY_get1_RSA(pkey);
if(rsa == NULL) exit(5);
#if 0
fprintf(stdout, "\n***** RSA *****\n");
RSA_print_fp(stdout, rsa, 0);
#endif
fprintf(stdout, "\n***** P *****\n");
fprintf(stdout, "%s\n", BN_bn2dec(rsa->p));
fprintf(stdout, "\n***** Q *****\n");
fprintf(stdout, "%s\n", BN_bn2dec(rsa->q));
fprintf(stdout, "\n***** N *****\n");
fprintf(stdout, "%s\n", BN_bn2dec(rsa->n));
n = BN_new();
if(!n) exit(6);
ctx = BN_CTX_new();
if(ctx == NULL) exit(7);
rc = BN_mul(n, rsa->p, rsa->q, ctx);
if(rc != 1) exit(8);
fprintf(stdout, "\n*** Calc N ***\n");
fprintf(stdout, "%s\n", BN_bn2dec(n));
BN_CTX_free(ctx);
BN_free(n);
RSA_free(rsa);
EVP_PKEY_free(pkey);
fclose(fd);
return 0;
}
答案 1 :(得分:2)
您好我使用此命令测试了您在编辑中提供的所有6个私钥
$ openssl rsa -check -in privkey
并且所有人都返回RSA key ok
。除第一个外,它返回RSA key error: n does not equal p q
。
我对你问题的回答
为什么地狱N不等于p * q?
是: N不等于p * q 。第一个密钥可能已被修改,或者在传输过程中已被更改,因此它未通过rsa检查测试。深入研究openssl源代码,我们可以看到openssl genrsa
命令由
int rsa_builtin_keygen(RSA *rsa, int bits, BIGNUM *e_value, BN_GENCB *cb)
/crypto/rsa/rsa_gen.c
中的。在ln:289,模数n
用
/* calculate n */
if (!BN_mul(rsa->n,rsa->p,rsa->q,ctx)) goto err;
表示n = p * q。您应该寻找导致问题的其他可能性,而不是对genrsa命令产生怀疑。