Home  >  Article  >  Backend Development  >  PHP implements WeChat payment process sharing

PHP implements WeChat payment process sharing

小云云
小云云Original
2018-03-20 15:42:2416795browse

This article mainly shares with you the process of implementing WeChat payment in PHP. I recently came into contact with a project involving WeChat payment. I have not done any payment since I have been developing WeChat for so long. I have also done a public account to send red envelopes before. Thank you to my predecessors. I read their blog posts based on their exploration, which saved me a lot of detours.
Preliminary preparation:
1. WeChat authentication service account, and activated WeChat payment
2. WeChat payment SDK, download address: https://pay.weixin.qq.com/wiki/doc/api /jsapi.php?chapter=11_1
3. Log in to the WeChat payment platform https://pay.weixin.qq.com/index.php/account/api_cert to download the payment certificate

Method steps:
1.demo file processing
(1) Download the official demo, the file name is WxpayAPI_php_v3, rename this file to wxpay, for the convenience of writing the directory later;

(2) Open the WxPay.Api.php file under the lib folder. There is a curl network request configuration code on line 537:

curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,TRUE);
curl_setopt($ch,CURLOPT_SSL_VERIFYHOST,2);//严格校验

is replaced with:

curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,FALSE);
curl_setopt($ch,CURLOPT_SSL_VERIFYHOST,2);//严格校验

In order to prohibit cURL from verifying the peer certificate (peer's certificate).

(3) Open the WxPay.Config.php file under the lib folder. Starting from line 25, complete the basic information settings according to your account;

const APPID = '公众账号APPID';
const MCHID = '商户号';
const KEY = '商户支付密钥';
const APPSECRET = '公众帐号secert';

(4) Open the lib folder WxPay.Notify.php file under, the code in line 79:

if($needSign == true && 
	$this->GetReturn_code($return_code) == "SUCCESS")
{
	$this->SetSign();
}

is changed to:

if($needSign == true && 
	$this->GetReturn_code() == "SUCCESS")
{
	$this->SetSign();
}

(5) Open the cert certificate directory and replace the two certificates inside with your own Payment certificate.

2. Public account background settings

(1) Configure the web page authorized domain name, my domain name is (xy.chuyin.ren);


(1) Configure the payment authorization directory. The domain name is (xy.chuyin.ren). I put the demo in the weixinopen/ folder of the directory pointed to by this domain name. The jsapi.php file in the demo It is located in the example/ directory, so the payment authorization directory is: xy.chuyin.ren/weixinopen/wxpay/example/


3. Payment process
Open The jsapi.php file in the example directory, payment initiation and processing, are all completed here.
(1) Obtain user openid

I have configured my APPID and APPSecert before, so there is no need to process it here.

//①、获取用户openid
$tools = new JsApiPay();
$openId = $tools->GetOpenid();

The JsApiPay() class initialized here first gets an object. The file corresponds to WxPay.JsApiPay.php in the example/ directory. Calling the GetOpenid() method will automatically obtain its own openID.

(2) Unified order

//②、统一下单
$input = new WxPayUnifiedOrder();
$input->SetBody("test");
$input->SetAttach("test");
$input->SetOut_trade_no(WxPayConfig::MCHID.date("YmdHis"));
$input->SetTotal_fee("1");
$input->SetTime_start(date("YmdHis"));
$input->SetTime_expire(date("YmdHis", time() + 600));
$input->SetGoods_tag("test");
$input->SetNotify_url("http://paysdk.weixin.qq.com/example/notify.php");
$input->SetTrade_type("JSAPI");
$input->SetOpenid($openId);
$order = WxPayApi::unifiedOrder($input);
echo &#39;<font color="#f00"><b>统一下单支付单信息</b></font><br/>&#39;;
printf_info($order);
$jsApiParameters = $tools->GetJsApiParameters($order);

Corresponds to the unifiedOrder() method on line 24 of WxPay.Api.php, which configures the order information and payment callback function. Several parameters need to be modified here:

A. Product name:

$input->SetBody("test");

B. Order number

$input->SetOut_trade_no(WxPayConfig::MCHID.date("YmdHis"));

C. Payment amount

$input->SetTotal_fee(" 1");

D. The payment verification link

is set to the location of your notify.php file, so I set it here to: http: //xy.chuyin.ren/weixinopen/wxpay/example/notify.php

You can also write other addresses. Of course, it must be under the payment authorization domain name. After the payment is successful, it will automatically call back to the address specified by the link. In the method, you can perform judgment and database operations.

$input->SetNotify_url("http://paysdk.weixin.qq.com/example/notify.php");

E. Additional parameters

$input->SetAttach("test");

Additional parameters can be filled in or not. If filled in, it is best not to have spaces in the string.
At this time, click Pay and you should be able to pay successfully.

(3) Initiate payment

<script type="text/javascript">
//调用微信JS api 支付
function jsApiCall()
{
	WeixinJSBridge.invoke(
		&#39;getBrandWCPayRequest&#39;,
		<?php echo $jsApiParameters; ?>,
		function(res){
			WeixinJSBridge.log(res.err_msg);
			alert(res.err_code+res.err_desc+res.err_msg);
		}
	);
}

function callpay()
{
	if (typeof WeixinJSBridge == "undefined"){
		if( document.addEventListener ){
			document.addEventListener(&#39;WeixinJSBridgeReady&#39;, jsApiCall, false);
		}else if (document.attachEvent){
			document.attachEvent(&#39;WeixinJSBridgeReady&#39;, jsApiCall); 
			document.attachEvent(&#39;onWeixinJSBridgeReady&#39;, jsApiCall);
		}
	}else{
		jsApiCall();
	}
}
</script>

Clicking the Pay Now button calls the callpay() function, which will call the jsApiCall() function to open the payment program.


jsApiCall() function will monitor every step of the action:


## res.err_msg is get_brand_wcpay_request:cancel indicates that the front-end judged the payment to be canceled, and es.err_msg is get_brand_wcpay_request:ok, which indicates that the front-end judged that the payment was successful. We can jump to the payment success page based on this.

(4) Support success callback


The payment result can be monitored through the front-end jsApiCall() function, but this is not trustworthy. To confirm whether the payment is successful, the business logic should be processed through notify.php. The payment verification link SetNotify_url() has been configured previously. After the payment is completed, the WeChat server will automatically request your notify.php file according to the link and open this file. In fact, the main code of this file is only two lines:

$notify = new PayNotifyCallBack();
$notify->Handle(false);

Trace this to the Handle() function of the WxPay.Notify.php class file:

/**
 * 
 * 回调入口
 * @param bool $needSign  是否需要签名输出
 */
final public function Handle($needSign = true)
{
	$msg = "OK";
	//当返回false的时候,表示notify中调用NotifyCallBack回调失败获取签名校验失败,此时直接回复失败
	$result = WxpayApi::notify(array($this, &#39;NotifyCallBack&#39;), $msg);
	if($result == false){
		$this->SetReturn_code("FAIL");
		$this->SetReturn_msg($msg);
		$this->ReplyNotify(false);
		return;
	} else {
		//该分支在成功回调到NotifyCallBack方法,处理完成之后流程
		$this->SetReturn_code("SUCCESS");
		$this->SetReturn_msg("OK");
	}
	$this->ReplyNotify($needSign);
}

Main code:

$result = WxpayApi::notify(array($this, &#39;NotifyCallBack&#39;), $msg);

Then go to line 411 of the WxPay.Api.php file, notify () Function:

/**
 * 
 * 支付结果通用通知
 * @param function $callback
 * 直接回调函数使用方法: notify(you_function);
 * 回调类成员函数方法:notify(array($this, you_function));
 * $callback  原型为:function function_name($data){}
 */
public static function notify($callback, &$msg)
{
	//获取通知的数据
	$xml = $GLOBALS[&#39;HTTP_RAW_POST_DATA&#39;];
	//file_put_contents(&#39;log.txt&#39;,$xml,FILE_APPEND);
	//如果返回成功则验证签名
	try {
		$result = WxPayResults::Init($xml);
	} catch (WxPayException $e){
		$msg = $e->errorMessage();
		return false;
	}
	
	return call_user_func($callback, $result);
}

The $xml=$GLOBALS['HTTP_RAW_POST_DATA'] here is a result returned to you by the user after the payment is successful. It is a string in xml format.


We can record the xml data returned here, and then open it to see if $out_trade_no is the order number I set before payment, and $attach is the additional parameter set.

After getting the order number, I will directly write the logic after the payment is successful, such as changing the data in the database, etc.

In this way, the general analysis of JsApi payment of WeChat payment is completed.


This is implemented by integrating the official SDK. If you do not use the SDK, you can use a simpler method. See: PHP implements WeChat payment (jsapi payment) and refund (no need to integrate payment SDK)

Related recommendations:

WeChat payment refund function development

PHP development WeChat payment And Alipay payment example

PHP WeChat payment development WeChat refund function example

The above is the detailed content of PHP implements WeChat payment process sharing. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn