yilu/alipay

支付宝SDK在Laravel5封装包。

1.0 2016-11-07 08:12 UTC

This package is not auto-updated.

Last update: 2024-12-30 14:31:12 UTC


README

支付宝SDK在Laravel5/Lumen封装包。

该拓展包想要达到在Laravel5/Lumen框架下,便捷使用支付宝的目的。

部分代码参考latrell/Alipay。

安装

composer require yilu/alipay dev-master

更新你的依赖包 composer update 或者全新安装 composer install

使用

要使用支付宝SDK服务提供者,你必须自己注册服务提供者到Laravel/Lumen服务提供者列表中。 基本上有两种方法可以做到这一点。

Laravel

找到 config/app.php 配置文件中,key为 providers 的数组,在数组中添加服务提供者。

    'providers' => [
        // ...
        'Yilu\Alipay\AlipayServiceProvider',
    ]

运行 php artisan vendor:publish 命令,发布配置文件到你的项目中。

Lumen

bootstrap/app.php里注册服务。

//Register Service Providers
$app->register(Yilu\Alipay\AlipayServiceProvider::class);

由于Lumen的artisan命令不支持vendor:publish,需要自己手动将src/config下的配置文件拷贝到项目的config目录下, 并将config.php改名成yilu-alipay.php, mobile.php改名成yilu-alipay-mobile.php, web.php改名成yilu-alipay-web.phpbatch_trans.php改名成yilu-alipay-batch_trans.php.

说明

配置文件 config/alipay/yilu-alipay.php 为公共配置信息文件, config/alipay/yilu-alipay-web.php 为Web版支付宝SDK配置, config/alipay/yilu-alipay-mobile.php 为手机端支付宝SDK配置, config/alipay/yilu-alipay-batch_trans.php 为批量付款到支付宝账户SDK配置。

例子

支付申请

网页

	// 创建支付单。
	$alipay = app('alipay.web');
	$alipay->setOutTradeNo('order_id');
	$alipay->setTotalFee('order_price');
	$alipay->setSubject('goods_name');
	$alipay->setBody('goods_description');
	
	$alipay->setQrPayMode('4'); //该设置为可选,添加该参数设置,支持二维码支付。

	// 跳转到支付页面。
	return redirect()->to($alipay->getPayLink());

手机端

	// 创建支付单。
	$alipay = app('alipay.mobile');
	$alipay->setOutTradeNo('order_id');
	$alipay->setTotalFee('order_price');
	$alipay->setSubject('goods_name');
	$alipay->setBody('goods_description');

	// 返回签名后的支付参数给支付宝移动端的SDK。
	return $alipay->getPayPara();

手机网站支付(Wap)

	// 创建支付单。
	$alipay = app('alipay.wap');
	$alipay->setOutTradeNo('order_id');
	$alipay->setTotalFee('order_price');
	$alipay->setSubject('goods_name');
	$alipay->setBody('goods_description');

	// 返回支付链接到手机浏览器唤醒支付宝支付。
	return '<script>location.href = "'.$alipay->getPayLink().'";</script>';

批量付款到支付宝账户(开发者测试中......)

$alipay = app('alipay.batch_trans');
$a=[
	"notify_url" => '',
	"pay_date" => '20161111', 
	"batch_no" => '20161111001', 
	"batch_fee" => '0.01', 
	"batch_num" => '1', 
	"detail_data" => '12345678^收款方支付宝账号^名字^0.01^备注', //多人请用 | 隔开
];
$result = $alipay->buildRequestForm($a);
return $result;

结果通知

手机网站支付(Wap)

	// 创建支付单。
	$alipay = app('alipay.wap');
	$alipay->setOutTradeNo('order_id');
	$alipay->setTotalFee('order_price');
	$alipay->setSubject('goods_name');
	$alipay->setBody('goods_description');

	// 返回支付链接到手机浏览器唤醒支付宝支付。
	return '<script>location.href = "'.$alipay->getPayLink().'";</script>';

结果通知

网页

	/**
	 * 异步通知
	 */
	public function webNotify()
	{
		// 验证请求。
		if (! app('alipay.web')->verify()) {
			Log::notice('Alipay notify post data verification fail.', [
				'data' => Request::instance()->getContent()
			]);
			return 'fail';
		}

		// 判断通知类型。
		switch (Input::get('trade_status')) {
			case 'TRADE_SUCCESS':
			case 'TRADE_FINISHED':
				// TODO: 支付成功,取得订单号进行其它相关操作。
				Log::debug('Alipay notify post data verification success.', [
					'out_trade_no' => Input::get('out_trade_no'),
					'trade_no' => Input::get('trade_no')
				]);
				break;
		}
	
		return 'success';
	}

	/**
	 * 同步通知
	 */
	public function webReturn()
	{
		// 验证请求。
		if (! app('alipay.web')->verify()) {
			Log::notice('Alipay return query data verification fail.', [
				'data' => Request::getQueryString()
			]);
			return view('alipay.fail');
		}

		// 判断通知类型。
		switch (Input::get('trade_status')) {
			case 'TRADE_SUCCESS':
			case 'TRADE_FINISHED':
				// TODO: 支付成功,取得订单号进行其它相关操作。
				Log::debug('Alipay notify get data verification success.', [
					'out_trade_no' => Input::get('out_trade_no'),
					'trade_no' => Input::get('trade_no')
				]);
				break;
		}

		return view('alipay.success');
	}

手机端

	/**
	 * 支付宝异步通知
	 */
	public function alipayNotify()
	{
		// 验证请求。
		if (! app('alipay.mobile')->verify()) {
			Log::notice('Alipay notify post data verification fail.', [
				'data' => Request::instance()->getContent()
			]);
			return 'fail';
		}

		// 判断通知类型。
		switch (Input::get('trade_status')) {
			case 'TRADE_SUCCESS':
			case 'TRADE_FINISHED':
				// TODO: 支付成功,取得订单号进行其它相关操作。
				Log::debug('Alipay notify get data verification success.', [
					'out_trade_no' => Input::get('out_trade_no'),
					'trade_no' => Input::get('trade_no')
				]);
				break;
		}

		return 'success';
	}