- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我目前正在开发一个瘦 API 包装器来简化调用代码的实现,以便利用 Paypal 的保险库功能,您可以在其中存储信用卡信息,而不必将其存储在我们的本地系统中。作为 api 包装器的一部分,我正在使用 Zend_Http_Client_Adapter_Curl 并一直遇到“401 未授权”错误,但不确定原因。
为了帮助调试,我试图通过 Zend_Http_Client_Adapter_Curl 选项打开冗长但无济于事。如果我在没有 Zend 层的情况下使用 vanialla php 做同样的事情,我会得到预期的冗长。
有谁知道如何为 Zend_Http_Client_Adapter_Curl 打开详细信息,或者为什么我会收到 401 未经授权的响应?
我的 API 包装器:
public function createVaultItem(Hobis_Api_Payment_Gateway_Item_Vault $item)
{
$client = $this->getHttpClient();
// Authorization:Bearer is not a standard http header, so we have to disable strict header checking
$client->setConfig(array('strict' => false));
//$client->setUri(self::URI_VAULT);
$client->setUri('https://api.sandbox.paypal.com/v1/vault/credit-card');
/**
$payload = array(
'expire_month' => $item->expireMonth,
'expire_year' => $item->expireYear,
'first_name' => $item->nameFirst,
'last_name' => $item->nameLast,
'number' => $item->number,
'payer_id' => $item->userId,
'type' => $item->type
);
*
*/
$payload = array(
"expire_month" => 11,
"expire_year" => 2018,
"first_name" => "Tipsy",
"last_name" => "McStagger",
"number" => 4816123412343720,
"payer_id" => 1,
"type" => "visa"
);
$client->getAdapter()->setConfig(array(
"curloptions" => array(
CURLOPT_VERBOSE => 1,
CURLOPT_FOLLOWLOCATION => 1
)
));
$client->setRawData(json_encode($payload), Hobis_Api_Http_Client::ENC_URLENCODED);
$client->setHeaders(
array(
'Accept' => 'application/json',
'Content-Type' => 'application/json',
'Authorization:Bearer' => $this->getAccessToken()
)
);
$response = $client->request(Hobis_Api_Http_Client::POST);
var_dump($client->getLastRequest());
var_dump($client->getLastResponse());
}
响应:
string(351) "POST /v1/vault/credit-card HTTP/1.1
Host: api.sandbox.paypal.com
Accept: application/json
Content-Type: application/json
Authorization:Bearer: 1234
Content-Length: 136
{"expire_month":11,"expire_year":2018,"first_name":"Tipsy","last_name":"McStagger","number":4816123412343720,"payer_id":1,"type":"visa"}"
class Zend_Http_Response#15 (5) {
protected $version => string(3) "1.1"
protected $code => int(401)
protected $message => string(12) "Unauthorized"
protected $headers =>
array(9) {
'Server' => string(17) "Apache-Coyote/1.1"
'Proxy_server_info' => string(43) "host=slcsbjava1.slc.paypal.com;threadId=181"
'Paypal-debug-id' => string(13) "c7eb668ff9035"
'Content-type' => string(16) "application/json"
'Content-length' => string(1) "0"
'Dc' => string(30) "origin2-api.sandbox.paypal.com"
'Date' => string(29) "Wed, 27 Nov 2013 00:57:33 GMT"
'Connection' => string(5) "close"
'Set-cookie' => string(41) "DC=origin2-api.sandbox.paypal.com; secure"
}
protected $body => string(0) ""
}
还有原始代码:
$ch = curl_init('https://api.sandbox.paypal.com/v1/vault/credit-card');
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HTTPHEADER,
array(
'Content-Type: application/json',
sprintf('Authorization:Bearer 1234')
)
);
$payload = array(
"expire_month" => 11,
"expire_year" => 2018,
"first_name" => "Tipsy",
"last_name" => "McStagger",
"number" => 4816123412343720,
"payer_id" => 1,
"type" => "visa"
);
curl_setopt($ch, CURLOPT_POSTFIELDS, json_encode($payload));
curl_setopt($ch, CURLOPT_VERBOSE, true);
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, TRUE);
$response = json_decode(curl_exec($ch));
curl_close($ch);
var_dump(sprintf('State: %s | Mask: %s', $response->state, $response->number));
并输出:
* About to connect() to api.sandbox.paypal.com port 443 (#0)
* Trying 23.5.251.39... * connected
* Connected to api.sandbox.paypal.com (23.5.251.39) port 443 (#0)
* Initializing NSS with certpath: sql:/etc/pki/nssdb
* CAfile: /etc/pki/tls/certs/ca-bundle.crt
CApath: none
* NSS: client certificate not found (nickname not specified)
* SSL connection using SSL_RSA_WITH_RC4_128_SHA
* Server certificate:
* subject: CN=api.sandbox.paypal.com,OU=Partner Support,O="PayPal, Inc.",L=San Jose,ST=CALIFORNIA,C=US
* start date: Aug 20 00:00:00 2013 GMT
* expire date: Aug 21 23:59:59 2015 GMT
* common name: api.sandbox.paypal.com
* issuer: CN=VeriSign Class 3 Secure Server CA - G3,OU=Terms of use at https://www.verisign.com/rpa (c)10,OU=VeriSign Trust Network,O="VeriSign, Inc.",C=US
> POST /v1/vault/credit-card HTTP/1.1
Host: api.sandbox.paypal.com
Accept: */*
Content-Type: application/json
Authorization:Bearer 1234
Content-Length: 136
< HTTP/1.1 201 Created
< Server: Apache-Coyote/1.1
< PROXY_SERVER_INFO: host=slcsbjava3.slc.paypal.com;threadId=444
< Paypal-Debug-Id: 362182266fe6c
< Content-Language: *
< CORRELATION-ID: 362182266fe6c
< SERVER_INFO: vaultplatformserv:v1.vault.credit-card&CalThreadId=89&TopLevelTxnStartTime=1429716e360&Host=slcsbvaultplatformserv502.slc.paypal.com&pid=1239
< Content-Type: application/json
< Content-Length: 686
< DC: origin2-api.sandbox.paypal.com
< Date: Wed, 27 Nov 2013 01:05:29 GMT
< Connection: keep-alive
< Set-Cookie: DC=origin2-api.sandbox.paypal.com; secure
<
* Connection #0 to host api.sandbox.paypal.com left intact
* Closing connection #0
string(34) "State: ok | Mask: xxxxxxxxxxxx3720"
同样,我不确定为什么我会收到 401 Unauthorized,尽管我可能会尝试,但无法获得第一个示例(瘦 API 包装器)来显示详细输出。
最佳答案
乍一看,问题似乎出在您的授权 header 上。我想你想要:
$client->setHeaders(
array(
'Accept' => 'application/json',
'Content-Type' => 'application/json',
'Authorization' => 'Bearer '.$this->getAccessToken()
)
);
为了匹配您的 vanilla PHP 请求。
关于php - Paypal - Zend_Http_Client_Adapter_Curl - 如何打开 CURLOPT_VERBOSE,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20231155/
如果我的交易中的次要收款人没有 Paypal 帐户,会发生什么情况。他会收到要求他创建 Paypal 帐户的通知,还是 API 调用不会成功? 我几乎无法知道销售服务的用户在注册我的平台时是否有Pay
我们知道有这么多的支付网关服务提供商,即 Paypal ,moneybrookers,authorize.net以及许多国内和国际的支付网关提供商。现在,我的问题是,开发我们自己的支付网关服务以处理世
我们正在寻求替代我们对 Authorize.net 的使用。我花了很多时间查看 PayPal 文档,但找不到我的问题的明确答案: 使用 thousand 数十种不同的 PayPal API 可以在我们
我实际上是在为客户工作。我已经在网站上成功实现了 paypal pro,并且一切正常,我相信我遵循了他们的流程和指南,使它按照他们的意思工作。 因此,我一直在阅读 this webpage将网站投入生
我有2件商品要出售。我的运输底价为7.50美元,每增加一个项目,则为2.00美元 我已经设置了高级代码 运费= $ 7.50 运费2 = $ 2.00 一切正常,除非在购物车中添加了其他商品后,购物车
我想在不使用购物车的情况下实现一个不太复杂的解决方案。 我在自己对这个问题的回答中详细说明了解决方案,但如果有人能提出更好的方法,我会很高兴。 谢谢 最佳答案 实际上我最近不得不这样做。毫无疑问,我的
我创建了一个带有默认支付网关的shopify 小商店,即paypal express checkout。 当客户点击 Paypal 结帐按钮时,他们被要求输入他们的信用卡号并输入电子邮件并选择密码以注
一段时间以来,我一直在运行一个网站,该网站通过向 Paypal 网站发送一个 notify_url 来记录 Paypal 交易,并监听该 notify_url。我的监听页面解析从 paypal 发送的
我在网络应用程序中使用 PayPal Subscribe 按钮。我想将订阅开始日期传递给 PayPal,这不会总是今天的日期。 通常情况下,如果没有有效订阅,PayPal 会创建一个从今天开始的订阅。
大家好,我遇到了“立即购买”paypal 按钮这个令人沮丧的问题。 我希望我的客户能够通过 paypal 使用借记卡/信用卡付款,而无需创建 paypal 帐户,同时我希望能够根据产品类型将不同的定价
我想实现 paypal 授权并自动获取付款。我用过 Paypal 标准账户。我已发送带有授权参数的付款请求。
我想在我的 Paypal 沙盒账户中测试批量支付。根据 paypal 文档,它描述了将资金转移到 paypal 帐户的步骤。但我想转账到我客户的银行账户。我该怎么做? 仅供引用:PayPal 文档内容
我正在尝试登录我的沙盒帐户(使用 chrome),但由于 paypal 的新变化我不能。 Paypal 现在要求我登录开发者网站。我愿意。 然后我转到应用程序->沙盒帐户,然后按“sanbox 站点”
我有一个支持 Paypal 付款的 opencart 系统。是否有允许用户(信用卡)付款而无需强制注册 Paypal 帐户的选项。到目前为止,我使用的是 paypal 标准模块。 最佳答案 使用 Pa
我可以使用 Paypal ID 和密码使用 Paypal 详细信息进行付款而无需重定向到 Paypal 网站吗?我想在不离开我的网站的情况下完成所有付款流程。谢谢 最佳答案 您可以使用 PayFlow
当我尝试 https://fpdbs.paypal.com/dynamicimageweb?cmd=_dynamicimage 时,图像损坏了. 这是返回的错误信息: “尝试为应用程序构建 prote
我想向我的客户付款,为此我收到了他们的电子邮件,我想验证电子邮件地址是否存在于 paypal 中! 我搜索并找到了我尝试过的支付身份 API,但它只提供了我的我的数据!这是 LINK那个 API。 我
当从用户的 PayPal 账户中扣款时,PayPal 服务器在一定时间内没有响应(超时)。我们决定假设钱确实已经被拿走了,所以我们会退款。但是,如果钱没有从用户账户中扣除会怎样? PayPal返回什么
我有一个网站可以定期(比如每周一次)从客户那里收到钱。我将我的客户详细信息存储在我的数据库中,我想从我的客户帐户中提取资金,而不是每次都提示他们进行身份验证。金额会因客户而异。我怎样才能用 pay p
我有一个表格,其中一个团队签下他们的球员,然后被运送到 Paypal 进行注册付款,然后当一切都完成后我会收到一个 IPN。我正在做一个类似的表格,发现自从我创建该表格以来,Paypal 发生了很大变
我是一名优秀的程序员,十分优秀!