사전 준비:
1. WeChat 인증 서비스 계정 및 WeChat 결제 활성화
2. WeChat 결제 SDK 다운로드 주소: https://pay.weixin.qq.com/wiki/doc /api/jsapi.php?chapter=11_1
3. WeChat 결제 플랫폼 https://pay.weixin.qq.com/index.php/account/api_cert에 로그인하여 결제 인증서를 다운로드하세요.
방법 단계 :
1. 데모 파일 처리
(1) 공식 데모를 다운로드합니다. 파일 이름은 WxpayAPI_php_v3입니다. 나중에 디렉토리 작성의 편의를 위해 이 파일의 이름을 wxpay로 바꿉니다.
(2) 다음에서 WxPay.Api를 엽니다. lib 폴더 .php 파일에는 537행에 컬 네트워크 요청 구성 코드가 있습니다.
curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,TRUE); curl_setopt($ch,CURLOPT_SSL_VERIFYHOST,2);//严格校验
는
curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,FALSE); curl_setopt($ch,CURLOPT_SSL_VERIFYHOST,2);//严格校验
로 대체되어 cURL이 피어 인증서를 확인하지 못하도록 합니다.
(3) lib 폴더 아래의 WxPay.Config.php 파일을 엽니다. 25번째 줄부터 계정에 따라 기본 정보 설정을 완료합니다.
const APPID = '公众账号APPID'; const MCHID = '商户号'; const KEY = '商户支付密钥'; const APPSECRET = '公众帐号secert';
(4) lib 아래의 WxPay.Notify.php 파일을 엽니다. 폴더, 79행의 코드:
if($needSign == true && $this->GetReturn_code($return_code) == "SUCCESS") { $this->SetSign(); }
는 다음과 같이 변경됩니다.
if($needSign == true && $this->GetReturn_code() == "SUCCESS") { $this->SetSign(); }
(5) 인증서 인증서 디렉터리를 열고 내부의 두 인증서를 자신의 결제 인증서로 바꿉니다.
관련 권장 사항: "PHP 튜토리얼"
2. 공개 계정 배경 설정
(1) 웹 페이지 승인 도메인 이름을 구성합니다. 내 도메인 이름은 (xy.chuyin.ren)입니다. 2) 구성 결제 승인 디렉터리, 도메인 이름은 (xy.chuyin.ren), 이 도메인 이름이 가리키는 디렉터리의 weixinopen/ 폴더에 데모를 넣었습니다. 데모의 jsapi.php 파일은 다음 위치에 있습니다. example/ 디렉터리이므로 결제 승인 디렉터리는 다음과 같습니다. xy .chuyin.ren/weixinopen/wxpay/example/
3. 결제 프로세스
결제 시작에서 jsapi.php 파일을 엽니다. 여기에서 모든 처리가 완료됩니다.
//①、获取用户openid $tools = new JsApiPay(); $openId = $tools->GetOpenid();여기에서 초기화된 JsApiPay() 클래스는 먼저 객체를 얻습니다. 파일은 example/ 디렉터리의 WxPay.JsApiPay.php에 해당합니다. GetOpenid() 메서드를 호출하면 자동으로 자체 openID를 얻습니다. (2) 통합 주문
//②、统一下单 $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);주문 정보 및 결제 콜백 기능을 구성하는 WxPay.Api.php의 24행에 있는 UnifiedOrder() 메소드에 해당합니다. 여기에서 몇 가지 매개변수를 수정해야 합니다. A. :
$input->SetBody("test");B. 주문번호
$input->SetOut_trade_no(WxPayConfig::MCHID.date("YmdHis"));C. 결제 금액
$input->SetTotal_fee("1");D. 결제 확인 링크는 inform.php 파일 위치로 설정되어 있으므로 http://xy로 설정했습니다. chuyin.ren /weixinopen/wxpay/example/notify.php다른 주소도 쓸 수 있습니다. 물론 결제 승인 도메인 이름에 있어야 하며, 결제가 성공한 후에는 자동으로 지정된 방법으로 콜백됩니다. 링크를 통해 판단 및 데이터베이스 작업을 수행할 수 있습니다.
$input->SetNotify_url("http://paysdk.weixin.qq.com/example/notify.php");E. 추가 매개변수
$input->SetAttach("test");추가 매개변수는 입력할 수도 있고 입력하지 않을 수도 있습니다. 입력할 경우 문자열에 공백을 두지 않는 것이 좋습니다. 이때 결제를 클릭하시면 결제가 성공됩니다. (3) 결제 시작
<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>Pay Now 버튼을 클릭하여 callpay() 함수를 호출하면 jsApiCall() 함수가 호출되어 결제 프로그램이 열립니다.
jsApiCall() 함수는 작업의 모든 단계를 모니터링합니다.
res.err_msg는 프런트 엔드에서 판단한 결제 취소를 나타내는 get_brand_wcpay_request:cancel이고, es.err_msg는 get_brand_wcpay_request:ok를 나타내는 get_brand_wcpay_request:ok입니다. 프론트엔드에서 결제 성공 여부를 판단하면 이를 기반으로 결제 성공 페이지로 이동합니다.
(4) 성공 콜백 지원
프런트엔드 jsApiCall() 함수를 통해 결제 결과를 모니터링할 수 있지만 이는 신뢰할 수 없습니다. 결제 성공 여부를 확인하려면 inform.php를 통해 비즈니스 로직을 처리해야 한다. 결제 확인 링크 SetNotify_url()은 이전에 구성되었습니다. 결제가 완료된 후 WeChat 서버는 링크에 따라 자동으로 inform.php 파일을 요청하고 이 파일을 엽니다. 실제로 이 파일의 주요 코드는 2개뿐입니다. 줄:
$notify = new PayNotifyCallBack(); $notify->Handle(false);다음을 따르세요. WxPay.Notify.php 클래스 파일의 Handle() 함수로 이동하세요.
/** * * 回调入口 * @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); }기본 코드:
$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'] 여기에 반환된 결과는 다음과 같습니다. 결제가 성공한 후 사용자가 제공하는 문자열입니다. xml 형식입니다.
여기에 반환된 xml 데이터를 기록하고 열어서 확인할 수 있습니다. $out_trade_no는 결제 전 설정한 주문 번호이고, $attach는 추가 매개변수 설정입니다.
주문번호를 받은 뒤 데이터베이스의 데이터 변경 등 결제 성공 후 로직을 바로 아래에 작성했습니다.
이렇게 WeChat 결제의 JsApi 결제를 대략적으로 분석합니다.
위 내용은 PHP WeChat 결제 프로세스는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

이 기사는 산 및 기본 데이터베이스 모델을 비교하여 특성과 적절한 사용 사례를 자세히 설명합니다. 산은 금융 및 전자 상거래 애플리케이션에 적합한 데이터 무결성 및 일관성을 우선시하는 반면 Base는 가용성 및

이 기사는 코드 주입과 같은 취약점을 방지하기 위해 PHP 파일 업로드 보안에 대해 설명합니다. 파일 유형 유효성 검증, 보안 저장 및 오류 처리에 중점을 두어 응용 프로그램 보안을 향상시킵니다.

기사는 내장 함수 사용, 화이트리스트 접근 방식 및 서버 측 유효성 검사와 같은 기술에 중점을 둔 보안을 향상시키기 위해 PHP 입력 유효성 검증에 대한 모범 사례를 논의합니다.

이 기사는 토큰 버킷 및 누출 된 버킷과 같은 알고리즘을 포함하여 PHP에서 API 요율 제한을 구현하고 Symfony/Rate-Limiter와 같은 라이브러리 사용 전략에 대해 설명합니다. 또한 모니터링, 동적 조정 요율 제한 및 손도 다룹니다.

이 기사에서는 PHP에서 암호를 보호하기 위해 PHP에서 Password_hash 및 Password_Verify 사용의 이점에 대해 설명합니다. 주요 주장은 이러한 기능이 자동 소금 생성, 강한 해싱 알고리즘 및 Secur를 통해 암호 보호를 향상 시킨다는 것입니다.

이 기사는 PHP 및 완화 전략의 OWASP Top 10 취약점에 대해 설명합니다. 주요 문제에는 PHP 응용 프로그램을 모니터링하고 보호하기위한 권장 도구가 포함 된 주입, 인증 파손 및 XSS가 포함됩니다.

이 기사는 PHP의 XSS 공격을 방지하기위한 전략, 입력 소독, 출력 인코딩 및 보안 향상 라이브러리 및 프레임 워크 사용에 중점을 둔 전략에 대해 설명합니다.

이 기사는 각각의 사용시기에 중점을 둔 PHP의 인터페이스 및 추상 클래스 사용에 대해 설명합니다. 인터페이스는 관련없는 클래스 및 다중 상속에 적합한 구현없이 계약을 정의합니다. 초록 클래스는 일반적인 기능을 제공합니다


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

VSCode Windows 64비트 다운로드
Microsoft에서 출시한 강력한 무료 IDE 편집기
