aws-sdk-ruby Aws :: ACM :: Client#import_certificate文件路径或文件内容

时间:2017-08-03 16:28:10

标签: ruby amazon-web-services aws-sdk aws-sdk-ruby

我尝试使用aws-sdk-ruby将证书导入ACM。但是,当我尝试使用以下任一方法使用Aws::ACM::Client#import_certificate时,堆栈跟踪告诉我我的私钥不是1024或2048.如果是这样的话,Entrust就不会签署我的证书。我还告诉openssl程序生成为2048.

错误讯息

  

不支持私钥。仅允许RSA 1024位和2048位私钥。

第一个代码示例

def acm_upload(options)
  require 'aws-sdk'
  @aws_region = ENV['AWS_REGION'] || ENV['AWS_DEFAULT_REGION'] || 'us-west-2'
  @aws_profile = ENV['AWS_PROFILE'] || ENV['AWS_DEFAULT_PROFILE'] || 'default'

  acm = Aws::ACM::Client.new(region: @aws_region, profile: @aws_profile)
  begin
    puts '=> Uploading Key, Cert, and Chain to ACM.'
    aws_response = acm.import_certificate({
      certificate: options[:cert_name],
      private_key: options[:key_name],
      certificate_chain: options[:chain_name],
    })
  rescue Aws::ACM::Errors::ServiceError => e
    puts 'An AWS ACM Service Error has occured.'
    raise e.message
  rescue Aws::Errors::ServiceError => e
    puts 'An AWS Error has occured.'
    raise e.message
  end

  puts aws_response
end

acm_upload({
  cert_name: './ssl/certificate/signed_cert.crt',
  key_name: './ssl/key/private_key.pem',
  chain_name: './ssl/chains/cert_chain.crt'
})

第一个方法调用说我的密钥不是2048bit。然后第二种方法也可以:

acm_upload({
  cert_name: File.read('./ssl/certificate/signed_cert.crt'),
  key_name: File.read('./ssl/key/private_key.pem'),
  chain_name: File.read('./ssl/chains/cert_chain.crt)'
})

与上述相同的错误。关于它的期望,我的文档并不是很清楚。它说数据,我认为这是证书文件的内容。有没有其他人之前有这个问题?

我能够使用他们使用aws提供的file:// Python CLI将密钥,证书和链上传到ACM。

1 个答案:

答案 0 :(得分:0)

尝试使用AWS CLI,看看它是否适合您:

aws acm import-certificate --certificate file://certificate.crt --private-key file://private_key.key --certificate-chain file://certificate_chain.crt

aws --version

注意:与版本兼容:aws-cli / 1.14.18 Python / 2.7.9 Windows / 8 botocore / 1.8.22

注意:与版本不兼容:aws-cli / 1.10.21 Python / 2.7.9 Windows / 8 botocore / 1.4.12