PHPackages                             slince/youzan-pay - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Payment Processing](/categories/payments)
4. /
5. slince/youzan-pay

ActiveLibrary[Payment Processing](/categories/payments)

slince/youzan-pay
=================

An integrated alipay and wechat payment solution based on YouZan using php

1.0.0(8y ago)7055291MITPHPPHP &gt;=5.6.0

Since Feb 24Pushed 8y ago3 watchersCompare

[ Source](https://github.com/slince/youzan-pay)[ Packagist](https://packagist.org/packages/slince/youzan-pay)[ RSS](/packages/slince-youzan-pay/feed)WikiDiscussions master Synced 2d ago

READMEChangelogDependencies (4)Versions (3)Used By (1)

有赞支付解决方案
========

[](#有赞支付解决方案)

利用有赞云和有赞微小店实现个人收款解决方案

[![Build Status](https://camo.githubusercontent.com/1715795e96aa6f63c2f035074be5f15f231ee317172ae57f46b744c9efe851b2/68747470733a2f2f696d672e736869656c64732e696f2f7472617669732f736c696e63652f796f757a616e2d7061792f6d61737465722e7376673f7374796c653d666c61742d737175617265)](https://travis-ci.org/slince/youzan-pay)[![Latest Stable Version](https://camo.githubusercontent.com/bef313945197f1dbb653dcce87d96f72d2f328fea39dc7262b56144ec421acf4/68747470733a2f2f696d672e736869656c64732e696f2f7061636b61676973742f762f736c696e63652f796f757a616e2d7061792e7376673f7374796c653d666c61742d737175617265266c6162656c3d737461626c65)](https://packagist.org/packages/slince/youzan-pay)[![Scrutinizer](https://camo.githubusercontent.com/9a6a8d23a53b1dfffb25208e008ada75bb41dd08bb63ba668cbcb674814d787b/68747470733a2f2f696d672e736869656c64732e696f2f7363727574696e697a65722f672f736c696e63652f796f757a616e2d7061792e7376673f7374796c653d666c61742d737175617265)](https://scrutinizer-ci.com/g/slince/youzan-pay/?branch=master)

Installation
------------

[](#installation)

使用 Composer 安装

```
$ composer require slince/youzan-pay
```

Basic Usage
-----------

[](#basic-usage)

- 创建 api 上下文和服务对象

```
$apiContext = new Slince\YouzanPay\ApiContext(CLIENT_ID, CLIENTD_SECRET, KDT_ID);

$youzanPay = new Slince\YouzanPay\YouzanPay($apiContext);
```

- 发起付款

```
$qrCode = $youzanPay->charge([
    'name' => '测试收款',
    'price' => 1, //单位是分
    'source' => '自身系统的订单id'
]);

echo  ""; //用户可以使用微信或者支付宝扫描付款
```

方法返回 [`Slince\YouzanPay\QRCode`](./src/Api/QRCode.php) 对象。

- 验证付款

```
$qrCodeId = ...
$result = $youzanPay->checkQRStatus($qrCodeId);

var_dump($result); //布尔类型
```

- 处理推送

怎么设置推送网上有太多帖子这里不再赘述，假设你已经设置好了推送：

```
$data = $youzanPay->verifyWebhook($request);

var_dump($data);
```

`$request` 对象可以是 `Symfony\Component\HttpFoundation\Request`， `Psr\Http\Message\ServerRequestInterface`, 这表示 symfony ， laravel， Sliex, CakePHP ，Slim 等框架用户可以直接将 request对象传给该方法； `$request` 也可以为null或者数组； 所以如果你不使用任何框架也可以很方便的集成；

如果是合法的有赞推送消息，`$data` 是一个数组，结构如下(注：下面是个json结构)

```
{
    "client_id":"6cd25b3f99727975b5",
    "id":"E20170807181905034500002",
    "kdt_id":63077,
    "kdt_name":"Qi码运动馆",
    "mode":1,
    "msg":"%7B%22update_time%22:%222017-08-07%2018:19:05%22,%22payment%22:%2211.00%22,%22tid%22:%22E20170807181905034500002%22,%22status%22:%22TRADE_CLOSED%22%7D",
    "sendCount":0,
    "sign":"5c15274ca4c079197c89154f44b20307",
    "status":"TRADE_CLOSED",
    "test":false,
    "type":"TRADE_ORDER_STATE",
    "version":1502101273
}
```

关于推送相关的文档可以参考 [这里](https://www.youzanyun.com/docs/guide/3401/3448)

接收到推送数据以后，你可以得到响应的 交易的id，但并不是你的订单id；用交易 id获取对应的二维码的id:

```
$trade = $youzanPay->getTrade($data['id']); //上一步获取的id

echo $trade->getQrId();  //获取到二维码id后去你的数据库查询到订单，做相应的处理；
```

`$trade` 是 [`Slince\YouzanPay\Trade`](./src/Api/Trade.php) 的实例；注意，为了聚焦业务，该对象只保留了原生数据的部分字段；

License
-------

[](#license)

采用 [MIT](https://opensource.org/licenses/MIT) 开源许可证

###  Health Score

34

—

LowBetter than 77% of packages

Maintenance20

Infrequent updates — may be unmaintained

Popularity28

Limited adoption so far

Community16

Small or concentrated contributor base

Maturity59

Maturing project, gaining track record

 Bus Factor1

Top contributor holds 85.7% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Every ~48 days

Total

2

Last Release

2952d ago

### Community

Maintainers

![](https://avatars.githubusercontent.com/u/3785826?v=4)[Tao](/maintainers/slince)[@slince](https://github.com/slince)

---

Top Contributors

[![slince](https://avatars.githubusercontent.com/u/3785826?v=4)](https://github.com/slince "slince (6 commits)")[![qloog](https://avatars.githubusercontent.com/u/3043638?v=4)](https://github.com/qloog "qloog (1 commits)")

---

Tags

paymentpayment-gatewayyouzanyouzan-payyouzan-sdkyouzanyunalipaywechatyouzan

###  Code Quality

TestsPHPUnit

### Embed Badge

![Health badge](/badges/slince-youzan-pay/health.svg)

```
[![Health](https://phpackages.com/badges/slince-youzan-pay/health.svg)](https://phpackages.com/packages/slince-youzan-pay)
```

###  Alternatives

[yansongda/pay

可能是我用过的最优雅的 Alipay 和 WeChat 的支付 SDK 扩展包了

5.3k1.2M53](/packages/yansongda-pay)[yansongda/laravel-pay

专注 Alipay/WeChat/Unipay 的 laravel 支付扩展包

1.1k353.2k9](/packages/yansongda-laravel-pay)[yansongda/hyperf-pay

可能是基于 hyperf 的最优雅的支付宝、微信、银联支付 SDK 了

8959.8k1](/packages/yansongda-hyperf-pay)[fantasystudio/easypay

Wechat and Alipay payment SDK

383.4k](/packages/fantasystudio-easypay)[guanguans/yii-pay

适配于 Yii 的 alipay 和 wechat 的支付扩展包

515.5k](/packages/guanguans-yii-pay)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
