更新--我用Python做了完全相同的事情,它完美地工作了!!
import os
os.system('certutil.exe -v -getkey "614D628A00000000014C" C:/Users/kra/kevin')有人能解释一下这个问题吗?
如果我运行这个ruby代码:
require 'open3'
stdin, stdout, stderr = Open3.popen3('certutil -v -getkey "614D628A00000000014C" C:/Users/kra/kevin')
puts stdout.read我得到以下错误:
Querying WIN-3CF41NBPT85.demo.com\demo-CA
CommonName: 614D628A00000000014C
CertUtil: -GetKey command FAILED: 0x80092004 (-2146885628)
CertUtil: Cannot find object or property.但是,如果我直接从命令行运行该命令,它将正常工作。
C:\Users\kra>certutil -getkey "614D628A00000000014C" C:/Users/kra/kevin
Querying WIN-3CF41NBPT85.cjndemo.com\cjndemo-CA.....................
"WIN-3CF41NBPT85.demo.com\demo-CA"
Serial Number: 614d628a00000000014c
Subject: CN=Kevin, C=GB
NotBefore: 11/30/2012 10:20 AM
NotAfter: 5/7/2013 9:29 AM
Template: Copy of Web Server
Version: 3
Cert Hash(sha1): 88 b1 7a 74 8c be 73 d5 16 07 7f 19 16 57 14 c5 dd a9 79 7f
Recipient Info[0]:
CMSG_KEY_TRANS_RECIPIENT(1)
CERT_ID_ISSUER_SERIAL_NUMBER(1)
Serial Number: 129e45d3000000000130
Issuer: CN=demo-CA, DC=demo, DC=com
Subject: CN=kra, CN=Users, DC=demo, DC=com
CertUtil: -GetKey command completed successfully.有趣的是,如果我运行这个ruby代码:
require 'open3'
stdin, stdout, stderr = Open3.popen3('certutil -recoverkey -p lexicon C:\Users\kra\kevin C:\Users\kra\kevin.pfx')
puts stdout.read它也是有效的。
Computed Hash: 6e d3 b8 ad 93 16 7b f0 fb b3 f5 cd 7e e4 bb ad fb 95 a0 81
User Certificate:
Serial Number: 614d628a00000000014c
Issuer: CN=demo-CA, DC=demo, DC=com
Subject: CN=Kevin, C=GB
Cert Hash(sha1): 88 b1 7a 74 8c be 73 d5 16 07 7f 19 16 57 14 c5 dd a9 79 7f
CertUtil: -RecoverKey command completed successfully.我假设这是某种奇怪的环境问题,因为显然ruby能够调用certutil.exe命令?
发布于 2012-12-01 05:02:27
Open3.popen3的第一个参数是要传递给子命令的环境。我不得不使用它来让事情像我有时所期望的那样工作:
Open3.popen3(ENV, 'command') { ... }它将当前脚本的环境传递给子命令。当前脚本将从命令行继承其环境,因此,从理论上讲,子命令将具有与在命令行发出的命令相同的信息。
如有必要,您还可以提取ENV的子集,或者在调用popen3之前临时覆盖变量。
尝试使用capture3而不是popen3。它非常相似,但我认为它没有那么低级。我在popen3上看到了一些奇怪的行为,capture3很好地避免了这些行为。同样,请注意,您可以传入ENV。
https://stackoverflow.com/questions/13652235
复制相似问题