shiqc/alisdk

支付宝SDK在Laravel5封装包。

V1.2.2 2020-04-21 13:54 UTC

This package is auto-updated.

Last update: 2024-09-21 23:45:44 UTC


README

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

该扩展包旨在在Laravel5/Lumen框架下方便使用支付宝。

安装

composer require shiqc/alisdk dev-master

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

使用

要使用支付宝SDK服务提供者,你必须将服务提供者注册到Laravel/Lumen的服务提供者列表中。基本有两种方法可以实现。

Laravel

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

    'providers' => [
        // ...
        'Shiqc\AliSDK\AlipayServiceProvider',
    ]

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

Lumen

bootstrap/app.php 中注册服务。

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

由于Lumen的 artisan 命令不支持 vendor:publish,需要手动将 src/config 下的配置文件复制到项目的 config 目录下,并将 config.php 重命名为 shiqc-alisdk.phpmobile.php 重命名为 shiqc-alisdk-mobile.phpweb.php 重命名为 shiqc-alisdk-web.php

说明

配置文件 config/shiqc-alisdk.php 是公共配置信息文件,config/shiqc-alisdk-web.php 是Web版支付宝SDK配置,config/shiqc-alisdk-mobile.php 是手机端支付宝SDK配置。

例子

支付请求

网页端

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

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

手机端

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

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

结果通知

网页端

	/**
	 * 异步通知
	 */
	public function webNotify()
	{
		// 验证请求。
		if (! app('alisdk.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('alisdk.web')->verify()) {
			Log::notice('Alipay return query data verification fail.', [
				'data' => Request::getQueryString()
			]);
			return view('alisdk.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('alisdk.success');
	}

手机端

	/**
	 * 支付宝异步通知
	 */
	public function alisdkNotify()
	{
		// 验证请求。
		if (! app('alisdk.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';
	}