| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133 |
- <?php
- // This file is auto-generated, don't edit it. Thanks.
- namespace Alipay\EasySDK\Payment\Page;
- use Alipay\EasySDK\Kernel\EasySDKKernel;
- use Alipay\EasySDK\Payment\Page\Models\AlipayTradePagePayResponse;
- class Client {
- protected $_kernel;
- public function __construct($kernel){
- $this->_kernel = $kernel;
- }
- /**
- * @param string $subject
- * @param string $outTradeNo
- * @param string $totalAmount
- * @param string $returnUrl
- * @return AlipayTradePagePayResponse
- */
- public function pay($subject, $outTradeNo, $totalAmount, $returnUrl){
- $systemParams = [
- "method" => "alipay.trade.page.pay",
- "app_id" => $this->_kernel->getConfig("appId"),
- "timestamp" => $this->_kernel->getTimestamp(),
- "format" => "json",
- "version" => "1.0",
- "alipay_sdk" => $this->_kernel->getSdkVersion(),
- "charset" => "UTF-8",
- "sign_type" => $this->_kernel->getConfig("signType"),
- "app_cert_sn" => $this->_kernel->getMerchantCertSN(),
- "alipay_root_cert_sn" => $this->_kernel->getAlipayRootCertSN()
- ];
- $bizParams = [
- "subject" => $subject,
- "out_trade_no" => $outTradeNo,
- "total_amount" => $totalAmount,
- "product_code" => "FAST_INSTANT_TRADE_PAY"
- ];
- $textParams = [
- "return_url" => $returnUrl
- ];
- $sign = $this->_kernel->sign($systemParams, $bizParams, $textParams, $this->_kernel->getConfig("merchantPrivateKey"));
- $response = [
- "body" => $this->_kernel->generatePage("POST", $systemParams, $bizParams, $textParams, $sign)
- ];
- return AlipayTradePagePayResponse::fromMap($response);
- }
- /**
- * ISV代商户代用,指定appAuthToken
- *
- * @param $appAuthToken String 代调用token
- * @return $this 本客户端,便于链式调用
- */
- public function agent($appAuthToken)
- {
- $this->_kernel->injectTextParam("app_auth_token", $appAuthToken);
- return $this;
- }
- /**
- * 用户授权调用,指定authToken
- *
- * @param $authToken String 用户授权token
- * @return $this
- */
- public function auth($authToken)
- {
- $this->_kernel->injectTextParam("auth_token", $authToken);
- return $this;
- }
- /**
- * 设置异步通知回调地址,此处设置将在本调用中覆盖Config中的全局配置
- *
- * @param $url String 异步通知回调地址,例如:https://www.test.com/callback
- * @return $this
- */
- public function asyncNotify($url)
- {
- $this->_kernel->injectTextParam("notify_url", $url);
- return $this;
- }
- /**
- * 将本次调用强制路由到后端系统的测试地址上,常用于线下环境内外联调,沙箱与线上环境设置无效
- *
- * @param $testUrl String 后端系统测试地址
- * @return $this
- */
- public function route($testUrl)
- {
- $this->_kernel->injectTextParam("ws_service_url", $testUrl);
- return $this;
- }
- /**
- * 设置API入参中没有的其他可选业务请求参数(biz_content下的字段)
- *
- * @param $key String 业务请求参数名称(biz_content下的字段名,比如timeout_express)
- * @param $value object 业务请求参数的值,一个可以序列化成JSON的对象
- * 如果该字段是一个字符串类型(String、Price、Date在SDK中都是字符串),请使用String储存
- * 如果该字段是一个数值型类型(比如:Number),请使用Long储存
- * 如果该字段是一个复杂类型,请使用嵌套的array指定各下级字段的值
- * 如果该字段是一个数组,请使用array储存各个值
- * @return $this
- */
- public function optional($key, $value)
- {
- $this->_kernel->injectBizParam($key, $value);
- return $this;
- }
- /**
- * 批量设置API入参中没有的其他可选业务请求参数(biz_content下的字段)
- * optional方法的批量版本
- *
- * @param $optionalArgs array 可选参数集合,每个参数由key和value组成,key和value的格式请参见optional方法的注释
- * @return $this
- */
- public function batchOptional($optionalArgs)
- {
- foreach ($optionalArgs as $key => $value) {
- $this->_kernel->injectBizParam($key, $value);
- }
- return $this;
- }
- }
|