PHP에서 WeChat 결제를 구현하는 방법: 1. 공식 데모를 다운로드합니다. 2. 컬 네트워크 요청 구성 코드를 수정합니다. 4. WxPay.Notify.php 파일을 수정합니다. 6. 결제 프로세스를 완료합니다.
이 기사의 운영 환경: Windows 7 시스템, PHP 버전 7.1, DELL G3 컴퓨터
PHP로 WeChat 결제를 구현하는 방법은 무엇입니까?
PHP는 WeChat 결제(jsapi 결제) 프로세스를 구현합니다
최근 WeChat 결제와 관련된 프로젝트를 접하게 되었습니다. 오랫동안 WeChat을 개발해왔지만 결제도 해본 적이 없습니다. 이전에 공개 계정으로 빨간 봉투를 보냈습니다. 선배님들의 탐구에 감사드리며, 선배님들의 블로그 게시물을 읽어 많은 우회로를 구했습니다.
사전 준비:
1. WeChat 인증 서비스 계정 및 WeChat 결제 활성화
2. WeChat 결제 SDK, 다운로드 주소:
https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=11_1
3. 위챗 결제 플랫폼에 로그인하세요
https://pay.weixin.qq.com/index.php/account/api_cert 결제 인증서 다운로드
방법 단계:
1. 데모 파일 처리
(1) 공식 데모를 다운로드하세요. 파일 이름은 WxpayAPI_php_v3이며 이는 나중에 디렉터리를 쉽게 작성할 수 있도록 파일 이름을 wxpay로 변경했습니다.
(2) lib 폴더 아래에 WxPay.Api.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) 인증서 인증서 디렉터리를 열고 내부의 두 인증서를 자신의 결제 인증서로 바꿉니다.
2. 공식 계정 배경 설정
(1) 웹페이지 승인 도메인 이름을 구성합니다. 내 도메인 이름은 (xy.chuyin.ren)입니다. (1) 결제 승인 디렉터리를 구성합니다. 도메인 이름은 (xy.chuyin.ren)이고, 이 도메인 이름이 가리키는 디렉토리의 weixinopen/ 폴더에 데모를 넣었습니다. 데모의 jsapi.php 파일은 example/ 디렉토리에 있으므로 결제 승인이 이루어집니다. 디렉토리는 xy.chuyin.ren/weixinopen/wxpay/ example/
3. 결제 프로세스
예시 디렉토리에서 jsapi.php 파일을 열면 결제 시작 및 처리가 모두 완료됩니다. (1) 사용자 openid 얻기
//①、获取用户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입니다. 결제가 성공했다고 판단되면, 이를 기반으로 결제 성공 페이지로 리디렉션할 수 있습니다.
(4) 성공적인 콜백 지원
通过前端jsApiCall()函数可以监听支付结果,但是这个并不可信。确认是否支付成功还是应当通过notify.php 处理业务逻辑。前边配置好了支付验证链接SetNotify_url(),支付完成后,微信服务器会根据链接自动请求你的notify.php文件,打开这个文件,其实这个文件最主要的代码就两行:
$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); }
这里面的$xml=$GLOBALS['HTTP_RAW_POST_DATA'],就是支付成功后用户返回给你的一个结果,他是一个xml格式的字符串。
我们可以将这里返回的xml数据记录下来,然后打开看看$out_trade_no就是在支付之前我自己设置的订单号码,$attach就是设置的附加参数。
得到了这个订单号,然后我就直接在下面写支付成功后的逻辑了,比如改变数据库中的数据等等。
这样 微信支付的 JsApi支付就大致分析完成了。【推荐学习:《PHP视频教程》】
这是集成了官方的SDK实现的,如果不使用SDK,可以使用更简单的方法,见:PHP实现微信支付(jsapi支付)和退款(无需集成支付SDK)
위 내용은 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를 무료로 생성하십시오.

인기 기사

뜨거운 도구

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

PhpStorm 맥 버전
최신(2018.2.1) 전문 PHP 통합 개발 도구

안전한 시험 브라우저
안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.
