【问题标题】:Railscast 143 (Paypal security) resulting in "We were unable to decrypt the certificate id."Railscast 143(Paypal 安全)导致“我们无法解密证书 ID”。
【发布时间】:2011-12-13 10:28:03
【问题描述】:

做 railscast #143。代码如下。当我添加安全内容时,我得到“我们无法解密证书 ID”。开发中。当我把安全的东西拿出来时,它又能正常工作了。我已经用新证书等重做了整个过程几次。没有运气。

对接下来要尝试什么有什么想法吗?

我遇到了与这篇帖子完全相同的问题,它在生产中遇到过它并且神奇地开始工作:

Can't get PayPal Encrypted Website Payments to work in Rails

在“购买这些”页面:

<%= form_tag "https://www.sandbox.paypal.com/cgi-bin/webscr" do %>
<%= hidden_field_tag :cmd, "_s-xclick" %>
<%= hidden_field_tag :encrypted, @cart.paypal_encrypted("#{@url}/buy_these", payment_notifications_url) %>
<p><%= submit_tag "Buy these for #{number_to_currency(@cart.total_price)}" %></p>

在 cart.rb 中:

PAYPAL_CERT_PEM = File.read("#{Rails.root}/certs/paypal_cert.pem")
APP_CERT_PEM = File.read("#{Rails.root}/certs/app_cert.pem")
APP_KEY_PEM = File.read("#{Rails.root}/certs/app_key.pem")

def encrypt_for_paypal(values)
    signed = OpenSSL::PKCS7::sign(OpenSSL::X509::Certificate.new(APP_CERT_PEM), OpenSSL::PKey::RSA.new(APP_KEY_PEM, ''), values.map { |k, v| "#{k}=#{v}" }.join("\n"), [], OpenSSL::PKCS7::BINARY)
    OpenSSL::PKCS7::encrypt([OpenSSL::X509::Certificate.new(PAYPAL_CERT_PEM)], signed.to_der, OpenSSL::Cipher::Cipher::new("DES3"), OpenSSL::PKCS7::BINARY).to_s.gsub("\n", "")
end

def paypal_encrypted(return_url, notify_url)
  values = {
    :business => 'seller_1316654707_biz@myurl.com',
    :cmd => '_cart',
    :upload => 1,
    :return => return_url,
    :invoice => id,
    :notify_url => notify_url,
    :cert_id => 'DVFY6JS476MR8'
  }
things.each_with_index do |item, index|
    values.merge!({
      "amount_#{index+1}" => item.price,
      "item_name_#{index+1}" => item.id,
      "item_number_#{index+1}" => item.id,
      "quantity_#{index+1}" => 1
    })
  end
  encrypt_for_paypal(values)
end

【问题讨论】:

  • 那个 Railscast 已经快三年了。您是否将这些说明与 PayPal 当前的 API 文档进行了比较?您是否考虑过使用可用的many PayPal gems 之一?
  • 感谢您的建议!事实证明我可以让它工作,只是不可靠。

标签: ruby-on-rails paypal railscasts


【解决方案1】:

我将整个过程重复了几次,它开始工作了。还在类似于下一个答案的过程中查看了每个值。不幸的是,每当我切换部署平台时,我似乎都会遇到同样的问题。最终,它又开始工作了。

【讨论】:

    【解决方案2】:

    我遇到了同样的问题,但问题与 paypal_cert.pem 文件有关,即 Paypal 的证书文件。

    Paypal 使用不同的证书进行登台和直播环境。请检查paypal_cert.pem 文件,您会看到第一行提到它应该使用的环境。

    我使用以下代码

    paypal_cert_file_name = ENV["paypal_cert_file_name"] || "paypal_cert_prod";
    
    PAYPAL_CERT_PEM = File.read("#{Rails.root}/certs/#{paypal_cert_file_name}.pem")
    

    有两个文件 paypal_cert_prod.pempaypal_cert_sandbox.pem 每个环境一个。

    【讨论】:

      【解决方案3】:

      由于我们在 paypal_encrypted 方法中加密了许多值,因此在同一过程中发生一些加密错误时可能会出现此错误。

      确保问题不是由于加密错误的最佳方法,请尝试从上述给定值哈希中逐一删除键值对并提出付款请求。

      【讨论】:

      • 谢谢!这是答案的一部分。
      猜你喜欢
      • 1970-01-01
      • 2013-10-08
      • 2013-12-27
      • 2011-09-28
      • 2018-12-03
      • 2012-05-07
      • 1970-01-01
      • 2021-09-25
      • 2019-09-26
      相关资源
      最近更新 更多