English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية

PHP로 APP 단위 위챗 결제 기능 개발

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(메일을 보내면, #을 @으로 변경하십시오. 신고하고 관련 증거를 제공하시면, 실제로 확인되면 이 사이트는 즉시 저작권 위반 내용을 삭제합니다.