> 백엔드 개발 > PHP 튜토리얼 > WeChat 빨간 봉투 전송 인터페이스의 PHP 버전 사용 예

WeChat 빨간 봉투 전송 인터페이스의 PHP 버전 사용 예

墨辰丷
풀어 주다: 2023-03-28 21:26:01
원래의
1659명이 탐색했습니다.

이 글은 주로 PHP 버전의 WeChat 빨간 봉투 전송 인터페이스의 사용법을 소개하고, PHP의 WeChat 빨간 봉투 전송 인터페이스와 관련된 사용 기술을 예제 형식으로 분석합니다. 도움이 필요한 친구는 참고할 수 있습니다

모두 믿습니다. 친구들은 WeChat 빨간 봉투 기능을 알고 있지만 빨간 봉투를 웹사이트에 통합하려면 어떻게 해야 할까요? 여기서 편집자는 PHP WeChat 빨간 봉투 전송 인터페이스의 테스트 예를 여러분과 공유할 것입니다. 내 친구들 모두에게 도움이 될 수 있습니다

다음은 수업과 사용 방법입니다:

$arr['openid']='ojgTTt8oF9VdYcGsJMACHpA-jy1U';
      $arr['hbname']="提现申请";
      $arr['body']="您的提现申请已经成功";
      $arr['fee']=1;
$comm = new Common_util_pub();
$re = $comm->sendhongbaoto($arr);
var_dump($re);
로그인 후 복사

판매자 백엔드에 설정된 인증서 위치와 키를 수정해야 합니다.

<?php
header("Content-type: text/html; charset=utf-8");
class Common_util_pub
{
  /**
* hbname 红包名称 fee 红包金额 /元 body 内容 openid 微信用户id
* @param undefined $arr
*
* @return
*/
public function sendhongbaoto($arr){
//$comm = new Common_util_pub();
$data[&#39;mch_id&#39;] = &#39;120005402&#39;;
$data[&#39;mch_billno&#39;] = &#39;120005402&#39;.date("Ymd",time()).date("His",time()).rand(1111,9999);
$data[&#39;nonce_str&#39;] = self::createNoncestr();
$data[&#39;re_openid&#39;] = $arr[&#39;openid&#39;];
$data[&#39;wxappid&#39;] = &#39;wx8axxxxxbac4905&#39;;
$data[&#39;nick_name&#39;] = $arr[&#39;hbname&#39;];
$data[&#39;send_name&#39;] = $arr[&#39;hbname&#39;];
$data[&#39;total_amount&#39;] = $arr[&#39;fee&#39;]*100;
$data[&#39;min_value&#39;] = $arr[&#39;fee&#39;]*100;
$data[&#39;max_value&#39;] = $arr[&#39;fee&#39;]*100;
$data[&#39;total_num&#39;] = 1;
$data[&#39;client_ip&#39;] = $_SERVER[&#39;REMOTE_ADDR&#39;];
$data[&#39;act_name&#39;] = &#39;测试活动&#39;;
$data[&#39;remark&#39;] = &#39;备注一下&#39;;
$data[&#39;wishing&#39;] = $arr[&#39;body&#39;];
if(!$data[&#39;re_openid&#39;]) {
   $rearr[&#39;return_msg&#39;]=&#39;缺少用户openid&#39;;
   return $rearr;
}
$data[&#39;sign&#39;] = self::getSign($data);
$xml = self::arrayToXml($data);
//var_dump($xml);
$url ="https://api.mch.weixin.qq.com/mmpaymkttransfers/sendredpack";
$re = self::wxHttpsRequestPem($xml,$url);
$rearr = self::xmlToArray($re);
return $rearr;
}
function trimString($value)
  {
    $ret = null;
    if (null != $value)
    {
      $ret = $value;
      if (strlen($ret) == 0)
      {
        $ret = null;
      }
    }
    return $ret;
  }
  /**
   * 作用:产生随机字符串,不长于32位
   */
  public function createNoncestr( $length = 32 )
  {
    $chars = "abcdefghijklmnopqrstuvwxyz0123456789";
    $str ="";
    for ( $i = 0; $i < $length; $i++ ) {
      $str.= substr($chars, mt_rand(0, strlen($chars)-1), 1);
    }
    return $str;
  }
  /**
   * 作用:格式化参数,签名过程需要使用
   */
  function formatBizQueryParaMap($paraMap, $urlencode)
  {
    $buff = "";
    ksort($paraMap);
    foreach ($paraMap as $k => $v)
    {
      if($urlencode)
      {
        $v = urlencode($v);
      }
      //$buff .= strtolower($k) . "=" . $v . "&";
      $buff .= $k . "=" . $v . "&";
    }
    $reqPar;
    if (strlen($buff) > 0)
    {
      $reqPar = substr($buff, 0, strlen($buff)-1);
    }
    return $reqPar;
  }
  /**
   * 作用:生成签名
   */
  public function getSign($Obj)
  {
    foreach ($Obj as $k => $v)
    {
      $Parameters[$k] = $v;
    }
    //签名步骤一:按字典序排序参数
    ksort($Parameters);
    $String = $this->formatBizQueryParaMap($Parameters, false);
    //echo &#39;【string1】&#39;.$String.&#39;</br>&#39;;
    //签名步骤二:在string后加入KEY
    $String = $String."&key="."254554sefg4exxxxxxxxs5cds1"; // 商户后台设置的key
    //echo "【string2】".$String."</br>";
    //签名步骤三:MD5加密
    $String = md5($String);
    //echo "【string3】 ".$String."</br>";
    //签名步骤四:所有字符转为大写
    $result_ = strtoupper($String);
    //echo "【result】 ".$result_."</br>";
    return $result_;
  }
  /**
   * 作用:array转xml
   */
  public function arrayToXml($arr)
  {
    $xml = "<xml>";
    foreach ($arr as $key=>$val)
    {
       if (is_numeric($val))
       {
        $xml.="<".$key.">".$val."</".$key.">";
       }
       else
        $xml.="<".$key."><![CDATA[".$val."]]></".$key.">";
    }
    $xml.="</xml>";
    return $xml;
  }
  /**
   * 作用:将xml转为array
   */
  public function xmlToArray($xml)
  {
    //将XML转为array
    $array_data = json_decode(json_encode(simplexml_load_string($xml, &#39;SimpleXMLElement&#39;, LIBXML_NOCDATA)), true);
    return $array_data;
  }
   public function wxHttpsRequestPem( $vars,$url, $second=30,$aHeader=array()){
        $ch = curl_init();
        //超时时间
        curl_setopt($ch,CURLOPT_TIMEOUT,$second);
        curl_setopt($ch,CURLOPT_RETURNTRANSFER, 1);
        //这里设置代理,如果有的话
        //curl_setopt($ch,CURLOPT_PROXY, &#39;10.206.30.98&#39;);
        //curl_setopt($ch,CURLOPT_PROXYPORT, 8080);
        curl_setopt($ch,CURLOPT_URL,$url);
        curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,false);
        curl_setopt($ch,CURLOPT_SSL_VERIFYHOST,false);
        //以下两种方式需选择一种
        //第一种方法,cert 与 key 分别属于两个.pem文件
        //默认格式为PEM,可以注释
        curl_setopt($ch,CURLOPT_SSLCERTTYPE,&#39;PEM&#39;);
        curl_setopt($ch,CURLOPT_SSLCERT,dirname(__FILE__).&#39;/hongbao/apiclient_cert.pem&#39;);
        //默认格式为PEM,可以注释
        curl_setopt($ch,CURLOPT_SSLKEYTYPE,&#39;PEM&#39;);
        curl_setopt($ch,CURLOPT_SSLKEY,dirname(__FILE__).&#39;/hongbao/apiclient_key.pem&#39;);
        curl_setopt($ch,CURLOPT_CAINFO,&#39;PEM&#39;);
        curl_setopt($ch,CURLOPT_CAINFO,dirname(__FILE__).&#39;/hongbao/rootca.pem&#39;);
        //第二种方式,两个文件合成一个.pem文件
        //curl_setopt($ch,CURLOPT_SSLCERT,getcwd().&#39;/all.pem&#39;);
        if( count($aHeader) >= 1 ){
            curl_setopt($ch, CURLOPT_HTTPHEADER, $aHeader);
        }
        curl_setopt($ch,CURLOPT_POST, 1);
        curl_setopt($ch,CURLOPT_POSTFIELDS,$vars);
        $data = curl_exec($ch);
        if($data){
            curl_close($ch);
            return $data;
        }
        else {
            $error = curl_errno($ch);
            echo "call faild, errorCode:$error\n";
            curl_close($ch);
            return false;
        }
    }
}
?>
로그인 후 복사

요약: 위 내용이 이 글의 전체 내용입니다. 모든 분들의 공부에 도움이 되었으면 좋겠습니다. H 관련 권장 사항:

Php 推荐 XML의 네 가지 방법 분석 자세한 설명

PHP의 비밀번호 암호화 솔루션 요약

Php Array_multisort 배열 자세한 설명 및 인스턴스 정렬


위 내용은 WeChat 빨간 봉투 전송 인터페이스의 PHP 버전 사용 예의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿