铁雪资源网 Design By www.gsvan.com
本文实例为大家分享了PHP微信公众号自动发送红包API代码,分享给大家供大家参考。具体如下:
贴出核心接口代码至于数据自己填写,接口测试OK
wechat_packet.php
<!--"/api/wechat/cert/apiclient_cert.pem"; /** * 私钥 */ private $private_key = '/api/wechat/cert/apiclient_key.pem'; /** * ca证书 */ private $rootca = 'api/wechat/cert/rootca.pem'; public function __construct() { //初始化红包设置信息 $this--->weixin_appid = C('wap_weixin_appid'); $this->mch_id = C('wechat_mch_id'); $this->send_name = C('wechat_send_name'); $this->wishing = C('wechat_wishing'); $this->act_name = C('wechat_act_name'); $this->client_ip = $_SERVER['SERVER_ADDR']; $this->remark = C('wechat_remark'); $this->nonce_str = $this->create_nonce_str(32); $this->api_password = C('wechat_api_password'); $inc_file = BASE_PATH.DS.'api'.DS.'wechat'.DS.'arraytoxml.php'; if(is_file($inc_file)) { require($inc_file); } $this->arraytoxml = new ArrayToXML(); } public function send_post($mch_billno,$re_openid,$total_amount){ $sign = $this->create_sign($mch_billno,$re_openid,$total_amount); $send_array = array( 'nonce_str' => $this->nonce_str, 'mch_billno' => $mch_billno, 'mch_id' => $this->mch_id, 'wxappid' => $this->weixin_appid, 'send_name' => $this->send_name, 're_openid' => $re_openid, 'total_amount' => $total_amount, 'total_num' => $this->total_num, 'wishing' => $this->wishing, 'client_ip' => $this->client_ip, 'act_name' => $this->act_name, 'remark' => $this->remark, 'sign' => $sign, ); $send_xml = $this->arraytoxml->toXml($send_array,''); $data = $this->curl_post_ssl($this->url, $send_xml); $data = $this->xmlToArray($data); file_put_contents('adki',var_export($data,true),FILE_APPEND); } /* 请确保您的libcurl版本是否支持双向认证,版本高于7.20.1 */ private function curl_post_ssl($url, $vars, $second=30,$aHeader=array()){ $ch = curl_init(); //超时时间 curl_setopt($ch,CURLOPT_TIMEOUT,$second); curl_setopt($ch,CURLOPT_RETURNTRANSFER, 1); //这里设置代理,如果有的话 //curl_setopt($ch,CURLOPT_PROXY, '10.206.30.98'); //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,'PEM'); curl_setopt($ch,CURLOPT_SSLCERT,getcwd().$this->public_key); //默认格式为PEM,可以注释 curl_setopt($ch,CURLOPT_SSLKEYTYPE,'PEM'); curl_setopt($ch,CURLOPT_SSLKEY,getcwd().$this->private_key); //ca证书 curl_setopt($ch,CURLOPT_CAINFO,$this->rootca); //第二种方式,两个文件合成一个.pem文件 //curl_setopt($ch,CURLOPT_SSLCERT,getcwd().'/all.pem'); 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\n\n\n"; curl_close($ch); return false; } } //生成签名 private function create_sign($mch_billno,$re_openid,$total_amount){ $string_array = array( 'act_name' => $this->act_name, 'client_ip' => $this->client_ip, 'mch_billno' => $mch_billno, 'mch_id' => $this->mch_id, 'nonce_str' => $this->nonce_str, 're_openid' => $re_openid, 'remark' => $this->remark, 'send_name' => $this->send_name, 'total_amount' => $total_amount, 'total_num' => $this->total_num, 'wishing' => $this->wishing, 'wxappid' => $this->weixin_appid, ); foreach ($string_array as $key => $value){ if(!empty($value)){ $stringA .= "$key=$value"; if($key != 'wxappid'){ $stringA .= '&'; } } } //转成UTF-8 $stringA = $this->gbkToUtf8($stringA); $stringSignTemp="$stringA&key=$this->api_password"; $sign = MD5($stringSignTemp); $sign = strtoupper($sign); return $sign; } //生成随机字符串 private function create_nonce_str($length){ $str = null; $strPol = "ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789abcdefghijklmnopqrstuvwxyz"; $max = strlen($strPol)-1; for($i=0;$i<$length;$i++){ $str.=$strPol[rand(0,$max)];//rand($min,$max)生成介于min和max两个数之间的一个随机整数 } return $str; } /** *自动判断把gbk或gb2312编码的字符串转为utf8 *能自动判断输入字符串的编码类,如果本身是utf-8就不用转换,否则就转换为utf-8的字符串 *支持的字符编码类型是:utf-8,gbk,gb2312 *@$str:string 字符串 */ private function gbkToUtf8($str){ $charset = mb_detect_encoding($str,array('ASCII','UTF-8','GBK','GB2312')); $charset = strtolower($charset); if("utf-8" != $charset){ $str = iconv('UTF-8',$charset,$str); } return $str; } private function xmlToArray($postStr){ $msg = array(); $msg = (array)simplexml_load_string($postStr, 'SimpleXMLElement', LIBXML_NOCDATA); return $msg; } }
数组转xml:arraytoxml.php
<!--"<".$key.">".$value."<!--".$key."-->"; }else{ $xml .= "<".$key."><!--[CDATA[".$value."]]--><!--".$key."-->"; } } $xml .= ''; return $xml; } }
以上就是本文的全部内容,希望对大家学习PHP程序设计有所帮助,也希望大家多多支持。
铁雪资源网 Design By www.gsvan.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
铁雪资源网 Design By www.gsvan.com
暂无PHP微信公众号自动发送红包API的评论...
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。