L'exemple de cet article décrit la méthode d'implémentation du développement de l'enveloppe rouge WeChat dans le compte public PHP WeChat. Partagez-le avec tout le monde pour votre référence, les détails sont les suivants :
Ces derniers jours, j'ai rencontré un client qui souhaitait ajouter la fonction d'enveloppe rouge WeChat cash à sa plateforme publique WeChat It. est une fonction de développement secondaire. Recherchez-la simplement sur Baidu, cela ne s'avère pas compliqué. Commençons par développer des fonctions. Publiez maintenant le processus de développement et les exigences à partager :
1. Exigences :
Les fans cliquent sur leur entreprise sur la plateforme publique du client et placent un commande, puis donnez à la commande un cashback de cinq yuans, qui sera envoyé à l'identifiant WeChat de la commande.
2. Idées de développement :
1 : Obtenez d'abord l'openid de suivre ce fan, qui est l'identifiant WeChat de suivre un certain public compte, afin que cette personne puisse être localisée en tant qu'opérateur de la commande.
2 : Envoyer des données XML pour demander le serveur WeChat.
Le code contient deux fichiers php
1.oauth2.php
<?php $code=$_GET['code']; $state=$_GET['state']; $appid='XXXX'; $appsecret='XXXXXXXX';// if (empty($code)) $this->error('授权失败'); $token_url='https://api.weixin.qq.com/sns/oauth2/access_token?appid='.$appid'&secret='.$appsecret.'&code='.$code.'&grant_type=authorization_code'; $token=json_decode(file_get_contents($token_url)); if (isset($token->errcode)) { echo '<h1>错误1</h1>'.$token->errcode; echo '<br/><h2>错误信息1:</h2>'.$token->errmsg; exit; } session_start(); $_SESSION['openid']= $token->openid; header('location:http://www.XXXXXXX.com/XXXXX/XXXXXX/XXXXXX/hongbao.php');//要跳转的文件路径 ?>
2.hongbao.php
<?php //XXXXX。。是需要开发者自己填写的内容,注意不要泄密 // 从session中获取到openid; $openid=$_SESSION["openid"]; if(empty($openid)) { header('location:https://open.weixin.qq.com/connect/oauth2/authorize?appid=XXXXXXXX&redirect_uri=http://www.XXXXXXX.com/oauth2.php&respose_type=code&scope=snsapi_base&state=XXXX&connect_redirect=1#wechat_redirect'); } } // 关键的函数 public function weixin_red_packet(){ // 请求参数 // 随机字符串 $data['nonce_str']=$this->get_unique_value(); //商户号,输入你的商户号 $data['mch_id']="XXXXXXX"; //商户订单号,可以按要求自己组合28位的商户订单号 $data['mch_billno']=$data['mch_id'].date("ymd")."XXXXXX".rand(1000,9999); //公众帐号appid,输入自己的公众号appid $data['wxappid']="XXXXXXX"; //商户名称 $data['send_name']="XXXXX"; //用户openid,输入待发红包的用户openid session_start(); $data['re_openid']=$_SESSION["openid"]; //付款金额 $data['total_amount']="XXXX"; //红包发放总人数 $data['total_num']="XXXX"; //红包祝福语 $data['wishing']="XXXX"; //IP地址 $data['client_ip']=$_SERVER['LOCAL_ADDR']; //活动名称 $data['act_name']="XXXXX"; //备注 $data['remark']="XXXXX"; // 生成签名 //对数据数组进行处理 //API密钥,输入自己的K 微信商户号里面的K $appsecret="XXXXXXXXXXXXXX"; // $data=array_filter($data); ksort($data); $str=""; foreach($data as $k=>$v){ $str.=$k."=".$v."&"; } $str.="key=".$appsecret; $data['sign']=strtoupper(MD5($str)); /* 发红包操作过程: 1.将请求数据转换成xml 2.发送请求 3.将请求结果转换为数组 4.将请求信息和请求结果录入到数据库中 4.判断是否通信成功 5.判断是否转账成功 */ //发红包接口地址 $url="api.mch.weixin.qq.com/mmpaymkttransfers/sendredpack"; //将请求数据由数组转换成xml $xml=$this->arraytoxml($data); //进行请求操作 $res=$this->curl($xml,$url); //将请求结果由xml转换成数组 $arr=$this->xmltoarray($res); } // 生成32位唯一随机字符串 private function get_unique_value(){ $str=uniqid(mt_rand(),1); $str=sha1($str); return md5($str); } // 将数组转换成xml private function arraytoxml($arr){ $xml="<xml>"; foreach($arr as $k=>$v){ $xml.="<".$k.">".$v."</".$k.">"; } $xml.="</xml>"; return $xml; } // 将xml转换成数组 private function xmltoarray($xml){ //禁止引用外部xml实体 libxml_disable_entity_loader(true); $xmlstring=simplexml_load_string($xml,"SimpleXMLElement",LIBXML_NOCDATA); $arr=json_decode(json_encode($xmlstring),true); return $arr; } //进行curl操作 private function curl($param="",$url) { $postUrl = $url; $curlPost = $param; //初始化curl $ch = curl_init(); //抓取指定网页 curl_setopt($ch, CURLOPT_URL,$postUrl); //设置header curl_setopt($ch, CURLOPT_HEADER, 0); //要求结果为字符串且输出到屏幕上 curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); //post提交方式 curl_setopt($ch, CURLOPT_POST, 1); // 增加 HTTP Header(头)里的字段 curl_setopt($ch, CURLOPT_POSTFIELDS, $curlPost); // 终止从服务端进行验证 curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE); curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE); //证书放到网站根目录的cert文件夹底下 curl_setopt($ch,CURLOPT_SSLCERT,dirname(FILE).DIRECTORY_SEPARATOR. 'cert'.DIRECTORY_SEPARATOR.'apiclient_cert.pem'); curl_setopt($ch,CURLOPT_SSLKEY,dirname(FILE).DIRECTORY_SEPARATOR. 'cert'.DIRECTORY_SEPARATOR.'apiient_key.pem'); curl_setopt($ch,CURLOPT_CAINFO,dirname(FILE).DIRECTORY_SEPARATOR. 'cert'.DIRECTORY_SEPARATOR.'rootca.pem'); //运行curl $data = curl_exec($ch); //关闭curl curl_close($ch); return $data; } ?>
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!