English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية
PHP로 APP 단 위챗 결제 개발에 대한 개인적인 경험
최근에 회사 요구로 APP 단에서 위챗 결제를 개발해야 했으며, 위챗 문서를 보고 좋았습니다. 큰 문제를 겪지 않았으며, 주의해야 할 점이 많지 않습니다.
메모장을 작성하여 기억할 수 있습니다.
APP 결제 프로세스
위의 이미지에서, 주의해야 할 프로세스는 총3부분;
첫 번째 부분: 주문 API 호출, 예약 결제 주문 반환, 서명한 후 정보 반환(4、5、6、7)
두 번째 부분: 비동기 알림(15、16)
마지막 부분: 결제 결과�断정
가장 주의해야 할 것은 첫 번째 부분: 주문 API 호출, 예약 결제 주문 반환, 서명한 후 정보 반환
위챗 문서상세 설명이 포함되어 있으며, 여기서 다시 설명하지 않습니다.
내 코드를 첨부합니다. 코드를 조금 수정하면 사용할 수 있습니다.
//인터랙션 함수 function weChatPay(){ $json = array(); //예약 결제 트랜잭션 생성에 필요한 필수 매개변수: $newPara = array(); //앱 ID $newPara["appid"] = "wx2421b1c4370ec43"; //사업자 번호 $newPara["mch_id"] = "10000100"; //장치 번호 $newPara["device_info"] = "WEB"; //임의 문자열, 여기서 함수를 사용하는 것이 좋습니다 $newPara["nonce_str"] = "1add1a30ac87aa2db72f57a2375d8fec" //상품 설명 $newPara["body"] = "APP 결제 테스트"; //사업자 주문 번호, 여기서 사업자의 내부 주문 번호 $newPara["out_trade_no"] = "1415659990"; //총 금액 $newPara["total_fee"] = 1; //단말 IP $newPara["spbill_create_ip"] = $_SERVER["REMOTE_ADDR"]; //通知地址,注意,这里的url里面不要加参数 $newPara["notify_url"] = "http://wxpay.wxutil.com/pub_v2/pay/notify.v2.php"; //交易类型 $newPara["trade_type"] = "APP"; //第一次签名 $newPara["sign"] = produceWeChatSign($newPara); //把数组转化成xml格式 $xmlData = getWeChatXML($newPara); //利用PHP的CURL包,将数据传给微信统一下单接口,返回正常的prepay_id $get_data = sendPrePayCurl($xmlData); //返回的结果进行判断。 if($get_data['return_code'] == "SUCCESS" && $get_data['result_code'] == "SUCCESS"){ //根据微信支付返回的结果进行二次签名 //二次签名所需的随机字符串 $newPara["nonce_str"] = "5K8264ILTKCH16CQ2502SI8ZNMTM67VS"; //二次签名所需的时间戳 $newPara['timeStamp'] = time().""; //二次签名剩余参数的补充 $secondSignArray = array( "appid"=>$newPara['appid'], "noncestr"=>$newPara['nonce_str'], "package"=>"Sign=WXPay", "prepayid"=>$get_data['prepay_id'], "partnerid"=>$newPara['mch_id'], "timestamp"=>$newPara['timeStamp'], ); $json['datas'] = $secondSignArray; $json['ordersn'] = $newPara["out_trade_no"]; $json['datas']['sign'] = weChatSecondSign($newPara,$get_data['prepay_id']); $json['message'] = "预支付完成"; //预支付完成,在下方进行自己内部的业务逻辑 /*****************************/ return json_encode($json); } else{ $json['message'] = $get_data['return_msg']; } } return json_encode($json); } //第一次签名的函数produceWeChatSign function produceWeChatSign($newPara){ $stringA = self::getSignContent($newPara); $stringSignTemp=$stringA."&key=";192006250b4c09247ec02edce69f6a2d"; return strtoupper(MD5($stringSignTemp)); } //xml 형식 생성 함수 public static function getWeChatXML($newPara){ $xmlData = "<xml>"; foreach ($newPara as $key => $value) { $xmlData = $xmlData."<".$key.">".$value."</".$key.">"; } $xmlData = $xmlData."</xml>"; return $xmlData; } //위ixin 인터페이스에 데이터를 curl을 통해 전송하는 함수 function sendPrePayCurl($xmlData) { $url = "https://api.mch.weixin.qq.com/pay/unifiedorder"; $header[] = "Content-type: text/xml"; $curl = curl_init(); curl_setopt($curl, CURLOPT_HTTPHEADER, $header); curl_setopt($curl, CURLOPT_URL, $url); curl_setopt($curl, CURLOPT_RETURNTRANSFER, true); curl_setopt($curl, CURLOPT_POST, 1); curl_setopt($curl, CURLOPT_POSTFIELDS, $xmlData); $data = curl_exec($curl); if (curl_errno($curl)) { print curl_error($curl); } curl_close($curl); return self::XMLDataParse($data); } //xml 형식 데이터 분석 함수 public static function XMLDataParse($data){ $msg = array(); $msg = (array)simplexml_load_string($data, 'SimpleXMLElement', LIBXML_NOCDATA); return $msg; } //두 번째 서명의 함수 function weChatSecondSign($newPara,$prepay_id){ $secondSignArray = array( "appid"=>$newPara['appid'], "noncestr"=>$newPara['nonce_str'], "package"=>"Sign=WXPay", "prepayid"=>$prepay_id, "partnerid"=>$newPara['mch_id'], "timestamp"=>$newPara['timeStamp'], ); $stringA = self::getSignContent($secondSignArray); $stringSignTemp=$stringA."&key=";192006250b4c09247ec02edce69f6a2d"; return strtoupper(MD5($stringSignTemp)); }
두 가지 주의 사항:
1. 두 번째 서명은 백엔드에서 완료되어야 하며, 완료된 후, 두 번째 서명에 사용된 모든 정보를 함께 프론트엔드에 전달하여 웨이페이의 부르기를 유도합니다. 이렇게 하면 웨이페이 부르기가 불가능한 경우가 적습니다.
2. 두 번째 서명은 다른 랜덤 문자열을 사용합니다.
이것이 이 문서의 전체 내용입니다. 많은 도움이 되었기를 바랍니다. 또한, 많은 지원을 해 주시기를 바랍니다.
언급: 이 문서의 내용은 인터넷에서 가져온 것입니다. 저작권은 원저자에게 있으며, 인터넷 사용자가 자발적으로 기여하고 자체적으로 업로드한 내용입니다. 이 사이트는 소유권을 가지지 않으며, 인공 편집을 하지 않았으며, 관련 법적 책임도 부담하지 않습니다. 저작권 위반이 의심되는 내용이 있다면, 메일을 보내주시기 바랍니다: notice#oldtoolbag.com(메일을 보내면, #을 @으로 변경하십시오. 신고하고 관련 증거를 제공하시면, 실제로 확인되면 이 사이트는 즉시 저작권 위반 내용을 삭제합니다.