minchao / shopee-php
Shopee Partner API PHP SDK
0.2.2
2022-04-02 09:12 UTC
Requires
- php: >=7.1
- ext-json: *
- guzzlehttp/guzzle: ^6.5 || ^7.0
- psr/http-message: ^1.0
Requires (Dev)
- phpstan/phpstan: ^0.12.14 || ^1.0.0
- phpunit/phpunit: ^7.5 || ^8.0 || ^9.0
- squizlabs/php_codesniffer: ^3.5
README
这是PHP的Shopee OpenAPI 1.0客户端。
⚠️ Shopee Open API v.1.0将于2022年12月26日后完全弃用.
要求
安装
执行以下命令以获取包
$ composer require minchao/shopee-php
使用方法
创建Shopee客户端实例,然后使用它访问Shopee Partner API。
<?php use Shopee\Client; require __DIR__ . '/vendor/autoload.php'; $client = new Client([ 'secret' => getenv('SHOPEE_PARTNER_KEY'), 'partner_id' => getenv('SHOPEE_PARTNER_ID'), 'shopid' => getenv('SHOPEE_SHOP_ID'), ]);
示例
获取商品详情
$response = $client->item->getItemDetail(['item_id' => 1978]);
或者,您也可以在请求中使用参数模型。
$parameters = (new \Shopee\Nodes\Item\Parameters\GetItemDetail()) ->setItemId(1978); $response = $client->item->getItemDetail($parameters);
Webhook
使用Webhook接收传入的推送通知
<?php /** * Push Mechanism (WebHook) * * @see https://open.shopee.com/documents?module=63&type=2&id=55 */ use Psr\Http\Message\ResponseInterface as Response; use Psr\Http\Message\ServerRequestInterface as Request; use Shopee\SignatureGenerator; use Shopee\SignatureValidator; use Slim\Factory\AppFactory; require __DIR__ . '/vendor/autoload.php'; $app = AppFactory::create(); $signatureGenerator = new SignatureGenerator(getenv('PARTNER_KEY')); $signatureValidator = new SignatureValidator($signatureGenerator); $app->post('/webhook', function (Request $request, Response $response) use ($signatureValidator) { // Verify push content if (!$signatureValidator->isValid($request)) { error_log('Invalid authorization signature'); return $response; } // TODO here to handle your business logic // HTTP response must with status code 2xx and empty body return $response; }); $app->run();
许可证
查看LICENSE文件以了解许可权利和限制(BSD 3-Clause)。