I recently came into contact with a project involving WeChat payment. After developing WeChat for so long, I have never done payment. I have also done public accounts to send red envelopes before. Thanks to the seniors for their exploration, I read their blog posts. It 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 and pay Certificate
Method steps:
1.demo file processing
(1) Download the official demo, the file name is WxpayAPI_php_v3, and rename the file to wxpay, For the convenience of writing the directory later;
(2) Open the WxPay.Api.php file in 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);//严格校验
To disable cURL from verifying 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 is located in the example/ directory. Therefore, the payment authorization directory is: xy.chuyin.ren/weixinopen/wxpay/example/

3. Payment process
Open jsapi in the example directory. PHP files, payment initiation and processing are all completed here.
(1) Obtain user openid
You have configured your 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 '<font color="#f00"><b>统一下单支付单信息</b></font><br/>';
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. Payment verification link
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 method specified in the link, where 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 the payment should be successful.
(3) Initiate payment
<script type="text/javascript">
//调用微信JS api 支付
function jsApiCall()
{
WeixinJSBridge.invoke(
'getBrandWCPayRequest',
<?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('WeixinJSBridgeReady', jsApiCall, false);
}else if (document.attachEvent){
document.attachEvent('WeixinJSBridgeReady', jsApiCall);
document.attachEvent('onWeixinJSBridgeReady', 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 indicates the front-end judgment for get_brand_wcpay_request:cancel To cancel payment, es.err_msg is get_brand_wcpay_request:ok, indicating that the front-end judged that the payment was successful, and we can jump to the 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 the Handle() function of the WxPay.Notify.php class file from this:
/**
*
* 回调入口
* @param bool $needSign 是否需要签名输出
*/
final public function Handle($needSign = true)
{
$msg = "OK";
//当返回false的时候,表示notify中调用NotifyCallBack回调失败获取签名校验失败,此时直接回复失败
$result = WxpayApi::notify(array($this, 'NotifyCallBack'), $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, 'NotifyCallBack'), $msg);
然后来到WxPay.Api.php文件的第411行,notify()函数:
/**
*
* 支付结果通用通知
* @param function $callback
* 直接回调函数使用方法: notify(you_function);
* 回调类成员函数方法:notify(array($this, you_function));
* $callback 原型为:function function_name($data){}
*/
public static function notify($callback, &$msg)
{
//获取通知的数据
$xml = $GLOBALS['HTTP_RAW_POST_DATA'];
//file_put_contents('log.txt',$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 After the payment is successful, the user returns a result to you, which is a string in XML format.

We can record the xml data returned here, and then open it to see. $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 to implement WeChat payment (jsapi payment) and refund (No need to integrate payment SDK).
For more PHP related knowledge, please visit PHP Tutorial!
The above is the detailed content of How to implement WeChat payment (jsapi payment) process in PHP. For more information, please follow other related articles on the PHP Chinese website!
Laravel routing parameter delivery and controller method definition: Avoiding common errors and best practicesJul 23, 2025 pm 07:27 PMThis tutorial details the correct method of parameter passing in Laravel routing, and corrects common errors in writing parameter placeholders into controller method names. The article provides examples of standardized routing definitions and controller methods, and emphasizes that deletion operations should prioritize the use of HTTPDELETE methods to enhance routing semantics and maintainability.
Guide to matching Laravel routing parameter passing and controller methodJul 23, 2025 pm 07:24 PMThis article aims to resolve common errors in the Laravel framework where routing parameter passing matches controller methods. We will explain in detail why writing parameters directly to the controller method name in the routing definition will result in an error of "the method does not exist", and provide the correct routing definition syntax to ensure that the controller can correctly receive and process routing parameters. In addition, the article will explore best practices for using HTTPDELETE methods in deletion operations.
How to use PHP to develop a Q&A community platform Detailed explanation of PHP interactive community monetization modelJul 23, 2025 pm 07:21 PM1. The first choice for the Laravel MySQL Vue/React combination in the PHP development question and answer community is the first choice for Laravel MySQL Vue/React combination, due to its maturity in the ecosystem and high development efficiency; 2. High performance requires dependence on cache (Redis), database optimization, CDN and asynchronous queues; 3. Security must be done with input filtering, CSRF protection, HTTPS, password encryption and permission control; 4. Money optional advertising, member subscription, rewards, commissions, knowledge payment and other models, the core is to match community tone and user needs.
Efficiently use JSON data to implement cascading drop-down menus in Laravel Blade templatesJul 23, 2025 pm 07:18 PMThis article details how to load a local JSON file in a Laravel application and pass its data to a Blade template. By processing JSON parsing by the controller, the view layer uses Blade's @foreach instruction to traverse the data, thereby realizing dynamically generating drop-down menus. In particular, the article also explores in-depth how to combine JavaScript to implement multi-level linkage drop-down menu functions to provide users with dynamic content display based on selection, and provides practical code examples and precautions for implementing such interactions.
Deep analysis of matching Laravel routing parameter transfer and controller methodJul 23, 2025 pm 07:15 PMThis article deeply explores the correct transmission of routing parameters and the matching mechanism of controller methods in the Laravel framework. In response to the common "method does not exist" error caused by writing routing parameters directly to the controller method name, the article elaborates on the correct way to define routing, that is, declare parameters in the URI and receive them as independent parameters in the controller method. At the same time, the article also provides code examples and suggestions on best practices for HTTP methods, aiming to help developers build more robust and RESTful Laravel applications.
PHP integrated AI intelligent image processing PHP image beautification and automatic editingJul 23, 2025 pm 07:12 PMPHP integrated AI image processing requires the help of a third-party API or local model, which cannot be directly implemented; 2. Use ready-made services such as Google CloudVision API to quickly realize facial recognition, object detection and other functions. The advantages are fast development and strong functions. The disadvantages are that they need to pay, rely on the network and have data security risks; 3. Deploy local AI models through PHP image library such as Imagick or GD combined with TensorFlowLite or ONNXRuntime. It can be customized, the data is safer, and the cost is low, but the development is difficult and requires AI knowledge; 4. Mixed solutions can combine the advantages of API and local model, such as using API for detection and beautification of local models; 5. Selecting AI image processing API should be comprehensive
Twilio Voice Call Maintenance and Recovery: Meeting Functions and Independent Call Leg Management PracticeJul 23, 2025 pm 07:09 PMThis article discusses in-depth two main strategies for realizing voice call holding (Hold) and recovery (Unhold) on the Twilio platform. First, we introduce the detailed introduction to leveraging the Twilio Conference feature to easily manage call retention by updating the Participant resources, and provide corresponding code examples. Second, for scenarios where more detailed control of independent call legs (CallLeg) is required, how to combine TwiML instructions (such as and/) to handle call reconnection, while highlighting the complexity of this approach. The article aims to provide professional and practical guidance to help developers choose the most suitable implementation solution according to specific needs.
Laravel routing parameter passing: correctly define the controller method and routing bindingJul 23, 2025 pm 07:06 PMThis article discusses the correct posture of parameter transfer of controller method in Laravel routing in depth. In response to common errors caused by writing routing parameters directly to the controller method name, the correct routing definition syntax is explained in detail, and the mechanism of Laravel automatic parameter binding is emphasized. At the same time, the article recommends using HTTPDELETE method that is more in line with RESTful specifications to handle deletion operations to improve the maintainability and semantics of the application.


Hot AI Tools

Undress AI Tool
Undress images for free

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Dreamweaver Mac version
Visual web development tools

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

SecLists
SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.







