0

我无法让网络资源与 activemerchant 合作。Activemerchant 与 authorize.net 和 paypal 配合得很好。我正在尝试从控制台对其进行测试,因为它在站点中失败了。

gateway = ActiveMerchant::Billing::CyberSourceGateway.new(   
      :login => "CybersourceUserID",
      :password => "CybersourceKey",
      :nexus => "NJ",
      :vat_reg_number =>""
    )


response = gateway.authorize(1000, credit_card, :ip => "127.0.0.1", :order_id=>"23434", :email=>"little@mac.com")

这是我回来的错误:

#<Net::HTTPInternalServerError:0x1113f0838>
<?xml version="1.0" encoding="UTF-8"?>
<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/">
   <soap:Body>
     <soap:Fault xmlns:wsse="http://schemas.xmlsoap.org/ws/2002/04/secext" xmlns:c="urn:schemas-cybersource-com:transaction-data-1.0">
       <faultcode>soap:Client</faultcode>
       <faultstring>
          XML parse error.
          PI with the name 'xml' can occur only in the beginning of the document.
        </faultstring>
     </soap:Fault>
    </soap:Body>
</soap:Envelope>

任何建议在这里将不胜感激!!!

谢谢,

抢。

-------这是假的抄送信息------

credit_card = ActiveMerchant::Billing::CreditCard.new(  
  :type               => "visa",  
  :number             => "4111111111111111",  
  :verification_value => "123",  
  :month              => 1,  
  :year               => 2020,  
  :first_name         => "First",  
  :last_name          => "Last"  
)

这里也是生成的 XML:(编辑了私人信息)

<?xml version="1.0" encoding="UTF-8"?>
<s:Envelope xmlns:s="http://schemas.xmlsoap.org/soap/envelope/">
  <s:Header>
    <wsse:Security xmlns:wsse="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd" s:mustUnderstand="1">
      <wsse:UsernameToken>
        <wsse:Username>CybersourceUserID</wsse:Username>
        <wsse:Password Type="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-username-token-profile-1.0#PasswordText">CybersourceKey</wsse:Password>
      </wsse:UsernameToken>
    </wsse:Security>
  </s:Header>
  <s:Body xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
    <requestMessage xmlns="urn:schemas-cybersource-com:transaction-data-1.69">
      <merchantID>CybersourceUserID</merchantID>
      <merchantReferenceCode>23434</merchantReferenceCode>
      <clientLibrary>Ruby Active Merchant</clientLibrary>
      <clientLibraryVersion>1.34.1</clientLibraryVersion>
      <clientEnvironment>i686-darwin12.2.0</clientEnvironment>
<billTo>
  <firstName>First</firstName>
  <lastName>Last</lastName>
  <street1></street1>
  <city></city>
  <state></state>
  <postalCode></postalCode>
  <country></country>
  <email>little@mac.com</email>
</billTo>
<purchaseTotals>
  <currency>USD</currency>
  <grandTotalAmount>10.00</grandTotalAmount>
</purchaseTotals>
<card>
  <accountNumber>4111111111111111</accountNumber>
  <expirationMonth>01</expirationMonth>
  <expirationYear>2020</expirationYear>
  <cvNumber>123</cvNumber>
  <cardType>001</cardType>
</card>
<ccAuthService run="true"/>
<businessRules>
</businessRules>
    </requestMessage>
  </s:Body>
</s:Envelope>

新信息:

有趣的是,如果我使用上面的 XML(使用正确的商家 ID 等)并使用 curl 通过生产网关处理它,我会得到:

Roberts-MacBook-Air:documents rlittle$ curl --header "content-type: application/soap+xml" --data @testxml2.xml https://ics2ws.ic3.com/commerce/1.x/transactionProcessor

<?xml version="1.0" encoding="utf-8"?>
   <soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/">
      <soap:Header>
         <wsse:Security xmlns:wsse="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd">
            <wsu:Timestamp xmlns:wsu="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd" wsu:Id="Timestamp-1851182716">
               <wsu:Created>2013-07-12T03:32:05.030Z</wsu:Created>
            </wsu:Timestamp>
         </wsse:Security>
   </soap:Header>
   <soap:Body>
       <c:replyMessage xmlns:c="urn:schemas-cybersource-com:transaction-data-1.69">   
            <c:merchantReferenceCode>
              23434
            </c:merchantReferenceCode>
            <c:requestID>
                3735999249970176056695
            </c:requestID>
            <c:decision>
                 REJECT
            </c:decision>
            <c:reasonCode>
                 101
            </c:reasonCode>
            <c:missingField>
                c:billTo/c:country
           </c:missingField>
            <c:missingField>
                c:billTo/c:city
            </c:missingField>
            <c:missingField> 
                 c:billTo/c:street1
            </c:missingField>    
            <c:requestToken>
             (a token)
            </c:requestToken>
            <c:ccAuthReply>
               <c:reasonCode>
                  101
               </c:reasonCode>
            </c:ccAuthReply>
        </c:replyMessage>
    </soap:Body>
</soap:Envelope>

所以一定是gem中的xml解析问题???

4

2 回答 2

0

谢谢您的帮助。

我联系了网络资源(他们非常有帮助)。

今晚它刚刚开始工作,所以我猜他们在最后解决了一些问题。

于 2013-07-12T04:26:03.903 回答
0

我不确切知道这个问题,但我会告诉你我最终是如何让它工作的。

ActiveMerchant::Billing::Base.mode = :test
ActiveMerchant::Billing::CyberSourceGateway::TEST_URL = 'https://ics2wstest.ic3.com/commerce/1.x/transactionProcessor'
gateway = ActiveMerchant::Billing::CyberSourceGateway.new(
  login: "<Cyber source Merchant ID>",
  password: '<Transaction key>',
  test: true,
  ignore_avs: true
)

credit_card = ActiveMerchant::Billing::CreditCard.new(
  :type               => "visa",
  :number             => "4111111111111111",
  :verification_value => "123",
  :month              => 1,
  :year               => Time.now.year+1,
  :first_name         => "Test",
  :last_name          => "Test1"
)
response = gateway.authorize(1000, credit_card, :ip => "127.0.0.1", order_id: "jdgjsahgd", email: "test.test@test.com")

记住:登录不是用户名,而是 Cyber​​space 商家 ID。

于 2013-07-11T19:31:08.463 回答