《PHP編程:PHP微信紅包生成代碼分享》要點:
本文介紹了PHP編程:PHP微信紅包生成代碼分享,希望對您有用。如果有疑問,可以聯系我們。
PHP實戰本文實例為大家分享了PHP微信公眾號自動發送紅包API代碼,分享給大家供大家參考.具體如下:
PHP實戰貼出核心接口代碼至于數據自己填寫,接口測試OK
wechat_packet.php
PHP實戰
<!--?php
/**
* 發送紅包接口
* Created by PhpStorm.
* User: ADKi
* Date: 2016/4/25 0025
* Time: 15:25
*/
class wechat_packet{
private $url = 'https://api.mch.weixin.qq.com/mmpaymkttransfers/sendredpack';//請求URL
private $mch_id;//商戶號
private $weixin_appid;//公眾賬號appid
private $send_name;//商戶名稱
private $total_num = 1;//發送紅包總人數
private $wishing;//紅包祝福語
private $client_ip;//調用接口的機器Ip地址
private $act_name;//活動名稱
private $remark;//備注信息
private $nonce_str;//隨機字符串,不長于32位
private $api_password;
private $arraytoxml;//數組轉xml
/**
* 公鑰
*/
private $public_key = "/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;
}
}
PHP實戰數組轉xml:arraytoxml.php
PHP實戰
<!--?php
/**
* Created by PhpStorm.
* User: ADKi
* Date: 2016/4/26 0026
* Time: 12:19
*/
class ArrayToXML
{
public function toXml($data){
$xml = '<xml-->';
foreach ($data as $key => $value){
if (is_numeric($value)){
$xml .= "<".$key.">".$value."<!--".$key."-->";
}else{
$xml .= "<".$key."><!--[CDATA[".$value."]]--><!--".$key."-->";
}
}
$xml .= '';
return $xml;
}
}
PHP實戰重寫了一下PHP下面的微信API接口,
PHP實戰微信紅包支持,JSAPI的動態參數接口支持
PHP實戰http://git.oschina.net/youkuiyuan/yky_test/blob/master/class/wxapi.class.php
PHP實戰微信API類 - 增加紅包支持
PHP實戰
<?php
/********************************************************
* @author Kyler You <QQ:2444756311>
* @link http://mp.weixin.qq.com/wiki/home/index.html
* @version 2.0.1
* @uses $wxApi = new WxApi();
* @package 微信API接口 陸續會繼續進行更新
********************************************************/
class WxApi {
const appId = "";
const appSecret = "";
const mchid = ""; //商戶號
const privatekey = ""; //私鑰
public $parameters = array();
public function __construct(){
}
/****************************************************
* 微信提交API方法,返回微信指定JSON
****************************************************/
public function wxHttpsRequest($url,$data = null){
$curl = curl_init();
curl_setopt($curl, CURLOPT_URL, $url);
curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, FALSE);
curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, FALSE);
if (!empty($data)){
curl_setopt($curl, CURLOPT_POST, 1);
curl_setopt($curl, CURLOPT_POSTFIELDS, $data);
}
curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
$output = curl_exec($curl);
curl_close($curl);
return $output;
}
/****************************************************
* 微信帶證書提交數據 - 微信紅包使用
****************************************************/
public function wxHttpsRequestPem($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().'/apiclient_cert.pem');
//默認格式為PEM,可以注釋
curl_setopt($ch,CURLOPT_SSLKEYTYPE,'PEM');
curl_setopt($ch,CURLOPT_SSLKEY,getcwd().'/apiclient_key.pem');
curl_setopt($ch,CURLOPT_CAINFO,'PEM');
curl_setopt($ch,CURLOPT_CAINFO,getcwd().'/rootca.pem');
//第二種方式,兩個文件合成一個.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";
curl_close($ch);
return false;
}
}
/****************************************************
* 微信獲取AccessToken 返回指定微信公眾號的at信息
****************************************************/
public function wxAccessToken($appId = NULL , $appSecret = NULL){
$appId = is_null($appId) ? self::appId : $appId;
$appSecret = is_null($appSecret) ? self::appSecret : $appSecret;
//echo $appId,$appSecret;
$url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=".$appId."&secret=".$appSecret;
$result = $this->wxHttpsRequest($url);
//print_r($result);
$jsoninfo = json_decode($result, true);
$access_token = $jsoninfo["access_token"];
return $access_token;
}
/****************************************************
* 微信通過OPENID獲取用戶信息,返回數組
****************************************************/
public function wxGetUser($openId){
$wxAccessToken = $this->wxAccessToken();
$url = "https://api.weixin.qq.com/cgi-bin/user/info?access_token=".$wxAccessToken."&openid=".$openId."&lang=zh_CN";
$result = $this->wxHttpsRequest($url);
$jsoninfo = json_decode($result, true);
return $jsoninfo;
}
/****************************************************
* 微信通過指定模板信息發送給指定用戶,發送完成后返回指定JSON數據
****************************************************/
public function wxSendTemplate($jsonData){
$wxAccessToken = $this->wxAccessToken();
$url = "https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=".$wxAccessToken;
$result = $this->wxHttpsRequest($url,$jsonData);
return $result;
}
/****************************************************
* 發送自定義的模板消息
****************************************************/
public function wxSetSend($touser, $template_id, $url, $data, $topcolor = '#7B68EE'){
$template = array(
'touser' => $touser,
'template_id' => $template_id,
'url' => $url,
'topcolor' => $topcolor,
'data' => $data
);
$jsonData = json_encode($template);
$result = $this->wxSendTemplate($jsonData);
return $result;
}
/****************************************************
* 微信設置OAUTH跳轉URL,返回字符串信息 - SCOPE = snsapi_base //驗證時不返回確認頁面,只能獲取OPENID
****************************************************/
public function wxOauthBase($redirectUrl,$state = "",$appId = NULL){
$appId = is_null($appId) ? self::appId : $appId;
$url = "https://open.weixin.qq.com/connect/oauth2/authorize?appid=".$appId."&redirect_uri=".$redirectUrl."&response_type=code&scope=snsapi_base&state=".$state."#wechat_redirect";
return $url;
}
/****************************************************
* 微信設置OAUTH跳轉URL,返回字符串信息 - SCOPE = snsapi_userinfo //獲取用戶完整信息
****************************************************/
public function wxOauthUserinfo($redirectUrl,$state = "",$appId = NULL){
$appId = is_null($appId) ? self::appId : $appId;
$url = "https://open.weixin.qq.com/connect/oauth2/authorize?appid=".$appId."&redirect_uri=".$redirectUrl."&response_type=code&scope=snsapi_userinfo&state=".$state."#wechat_redirect";
return $url;
}
/****************************************************
* 微信OAUTH跳轉指定URL
****************************************************/
public function wxHeader($url){
header("location:".$url);
}
/****************************************************
* 微信通過OAUTH返回頁面中獲取AT信息
****************************************************/
public function wxOauthAccessToken($code,$appId = NULL , $appSecret = NULL){
$appId = is_null($appId) ? self::appId : $appId;
$appSecret = is_null($appSecret) ? self::appSecret : $appSecret;
$url = "https://api.weixin.qq.com/sns/oauth2/access_token?appid=".$appId."&secret=".$appSecret."&code=".$code."&grant_type=authorization_code";
$result = $this->wxHttpsRequest($url);
//print_r($result);
$jsoninfo = json_decode($result, true);
//$access_token = $jsoninfo["access_token"];
return $jsoninfo;
}
/****************************************************
* 微信通過OAUTH的Access_Token的信息獲取當前用戶信息 // 只執行在snsapi_userinfo模式運行
****************************************************/
public function wxOauthUser($OauthAT,$openId){
$url = "https://api.weixin.qq.com/sns/userinfo?access_token=".$OauthAT."&openid=".$openId."&lang=zh_CN";
$result = $this->wxHttpsRequest($url);
$jsoninfo = json_decode($result, true);
return $jsoninfo;
}
/*****************************************************
* 生成隨機字符串 - 最長為32位字符串
*****************************************************/
public function wxNonceStr($length = 16, $type = FALSE) {
$chars = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";
$str = "";
for ($i = 0; $i < $length; $i++) {
$str .= substr($chars, mt_rand(0, strlen($chars) - 1), 1);
}
if($type == TRUE){
return strtoupper(md5(time() . $str));
}
else {
return $str;
}
}
/*******************************************************
* 微信商戶訂單號 - 最長28位字符串
*******************************************************/
public function wxMchBillno($mchid = NULL) {
if(is_null($mchid)){
if(self::mchid == "" || is_null(self::mchid)){
$mchid = time();
}
else{
$mchid = self::mchid;
}
}
else{
$mchid = substr(addslashes($mchid),0,10);
}
return date("Ymd",time()).time().$mchid;
}
/*******************************************************
* 微信格式化數組變成參數格式 - 支持url加密
*******************************************************/
public function wxSetParam($parameters){
if(is_array($parameters) && !empty($parameters)){
$this->parameters = $parameters;
return $this->parameters;
}
else{
return array();
}
}
/*******************************************************
* 微信格式化數組變成參數格式 - 支持url加密
*******************************************************/
public function wxFormatArray($parameters = NULL, $urlencode = FALSE){
if(is_null($parameters)){
$parameters = $this->parameters;
}
$restr = "";//初始化空
ksort($parameters);//排序參數
foreach ($parameters as $k => $v){//循環定制參數
if (null != $v && "null" != $v && "sign" != $k) {
if($urlencode){//如果參數需要增加URL加密就增加,不需要則不需要
$v = urlencode($v);
}
$restr .= $k . "=" . $v . "&";//返回完整字符串
}
}
if (strlen($restr) > 0) {//如果存在數據則將最后“&”刪除
$restr = substr($restr, 0, strlen($restr)-1);
}
return $restr;//返回字符串
}
/*******************************************************
* 微信MD5簽名生成器 - 需要將參數數組轉化成為字符串[wxFormatArray方法]
*******************************************************/
public function wxMd5Sign($content, $privatekey){
try {
if (is_null($key)) {
throw new Exception("財付通簽名key不能為空!");
}
if (is_null($content)) {
throw new Exception("財付通簽名內容不能為空");
}
$signStr = $content . "&key=" . $key;
return strtoupper(md5($signStr));
}
catch (Exception $e)
{
die($e->getMessage());
}
}
/*******************************************************
* 微信Sha1簽名生成器 - 需要將參數數組轉化成為字符串[wxFormatArray方法]
*******************************************************/
public function wxSha1Sign($content, $privatekey){
try {
if (is_null($key)) {
throw new Exception("財付通簽名key不能為空!");
}
if (is_null($content)) {
throw new Exception("財付通簽名內容不能為空");
}
$signStr = $content . "&key=" . $key;
return strtoupper(sha1($signStr));
}
catch (Exception $e)
{
die($e->getMessage());
}
}
/*******************************************************
* 將數組解析XML - 微信紅包接口
*******************************************************/
public function wxArrayToXml($parameters = NULL){
if(is_null($parameters)){
$parameters = $this->parameters;
}
if(!is_array($parameters) || empty($parameters)){
die("參數不為數組無法解析");
}
$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;
}
}
PHP實戰后期還是會增加在一起的把這個CLASS做起來,網上資源很多,但是都是有一定基礎的人去看看改改可以,對于沒有接觸剛剛接觸的新手還是需要給予支持的.幫助用戶屢屢思路.
PHP實戰再來一份:
PHP實戰首先給大家看一看這個表格:
PHP實戰
PHP實戰根據微信高級紅包接口,開發PHP版本的API接口,現在進行主要代碼分析.
PHP實戰紅包接口調用請求代碼,所有請求參數為必填參數與文檔對應:
PHP實戰
class Wxapi {
private $app_id = 'wxXXXXXXXXXXXX'; //公眾賬號appid,首先申請與之配套的公眾賬號
private $app_secret = 'XXXXXXXXXXXXXXXXXXXXXXXX';//公眾號secret,用戶獲取用戶授權token
private $app_mchid = 'XXXXXXXX';//商戶號id
function __construct(){
//do sth here....
}
/**
* 微信支付
* @param string $openid 用戶openid
*/
public function pay($re_openid)
{
include_once('WxHongBaoHelper.php');
$commonUtil = new CommonUtil();
$wxHongBaoHelper = new WxHongBaoHelper();
$wxHongBaoHelper->setParameter("nonce_str", $this->great_rand());//隨機字符串,丌長于 32 位
$wxHongBaoHelper->setParameter("mch_billno", $this->app_mchid.date('YmdHis').rand(1000, 9999));//訂單號
$wxHongBaoHelper->setParameter("mch_id", $this->app_mchid);//商戶號
$wxHongBaoHelper->setParameter("wxappid", $this->app_id);
$wxHongBaoHelper->setParameter("nick_name", '紅包');//提供方名稱
$wxHongBaoHelper->setParameter("send_name", '紅包');//紅包發送者名稱
$wxHongBaoHelper->setParameter("re_openid", $re_openid);//相對于醫脈互通的openid
$wxHongBaoHelper->setParameter("total_amount", 100);//付款金額,單位分
$wxHongBaoHelper->setParameter("min_value", 100);//最小紅包金額,單位分
$wxHongBaoHelper->setParameter("max_value", 100);//最大紅包金額,單位分
$wxHongBaoHelper->setParameter("total_num", 1);//紅包Х拋莧聳
$wxHongBaoHelper->setParameter("wishing", '感謝您參與紅包派發活動,祝您新年快樂!');//紅包祝福詫
$wxHongBaoHelper->setParameter("client_ip", '127.0.0.1');//調用接口的機器 Ip 地址
$wxHongBaoHelper->setParameter("act_name", '紅包活動');//活勱名稱
$wxHongBaoHelper->setParameter("remark", '快來搶!');//備注信息
$postXml = $wxHongBaoHelper->create_hongbao_xml();
$url = 'https://api.mch.weixin.qq.com/mmpaymkttransfers/sendredpack';
$responseXml = $wxHongBaoHelper->curl_post_ssl($url, $postXml);
//用作結果調試輸出
//echo htmlentities($responseXml,ENT_COMPAT,'UTF-8');
$responseObj = simplexml_load_string($responseXml, 'SimpleXMLElement', LIBXML_NOCDATA);
return $responseObj->return_code;
}
PHP實戰獲取隨機字符串方法:
PHP實戰
/**
* 生成隨機數
*/
public function great_rand(){
$str = '1234567890abcdefghijklmnopqrstuvwxyz';
for($i=0;$i<30;$i++){
$j=rand(0,35);
$t1 .= $str[$j];
}
return $t1;
}
PHP實戰簽名算法:
PHP實戰
/**
例如:
appid: wxd111665abv58f4f
mch_id: 10000100
device_info: 1000
Body: test
nonce_str: ibuaiVcKdpRxkhJA
第一步:對參數按照 key=value 的格式,并按照參數名 ASCII 字典序排序如下:
stringA="appid=wxd930ea5d5a258f4f&body=test&device_info=1000&mch_i
d=10000100&nonce_str=ibuaiVcKdpRxkhJA";
第二步:拼接支付密鑰:
stringSignTemp="stringA&key=192006250b4c09247ec02edce69f6a2d"
sign=MD5(stringSignTemp).toUpperCase()="9A0A8659F005D6984697E2CA0A
9CF3B7"
*/
protected function get_sign(){
define('PARTNERKEY',"QSRXXXXXXXXXXXXXXXXXXXXX");
try {
if (null == PARTNERKEY || "" == PARTNERKEY ) {
throw new SDKRuntimeException("密鑰不能為空!" . "<br>");
}
if($this->check_sign_parameters() == false) { //檢查生成簽名參數
throw new SDKRuntimeException("生成簽名參數缺失!" . "<br>");
}
$commonUtil = new CommonUtil();
ksort($this->parameters);
$unSignParaString = $commonUtil->formatQueryParaMap($this->parameters, false);
$md5SignUtil = new MD5SignUtil();
return $md5SignUtil->sign($unSignParaString,$commonUtil->trimString(PARTNERKEY));
}catch (SDKRuntimeException $e)
{
die($e->errorMessage());
}
}
PHP實戰CURL請求以及發送證書:
PHP實戰
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_URL,$url);
curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,false);
curl_setopt($ch,CURLOPT_SSL_VERIFYHOST,false);
//cert 與 key 分別屬于兩個.pem文件
//請確保您的libcurl版本是否支持雙向認證,版本高于7.20.1
curl_setopt($ch,CURLOPT_SSLCERT,dirname(__FILE__).DIRECTORY_SEPARATOR.'zhengshu'.DIRECTORY_SEPARATOR.'apiclient_cert.pem');
curl_setopt($ch,CURLOPT_SSLKEY,dirname(__FILE__).DIRECTORY_SEPARATOR.'zhengshu'.DIRECTORY_SEPARATOR.'apiclient_key.pem');
curl_setopt($ch,CURLOPT_CAINFO,dirname(__FILE__).DIRECTORY_SEPARATOR.'zhengshu'.DIRECTORY_SEPARATOR.'rootca.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";
curl_close($ch);
return false;
}
}
PHP實戰入口文件:
PHP實戰
@require "pay.php";
//獲取用戶信息
$get = $_GET['param'];
$code = $_GET['code'];
//判斷code是否存在
if($get=='access_token' && !empty($code)){
$param['param'] = 'access_token';
$param['code'] = $code;
$packet = new Packet();
//獲取用戶openid信息
$userinfo = $packet->_route('userinfo',$param);
if(empty($userinfo['openid'])){
exit("NOAUTH");
}
//調取支付方法
$packet->_route('wxpacket',array('openid'=>$userinfo['openid']));
}else{
$packet->_route('userinfo');
}
PHP實戰以上就是本文的全部內容,希望對大家學習PHP程序設計有所幫助,也希望大家多多支持維易PHP.
轉載請注明本頁網址:
http://www.snjht.com/jiaocheng/3137.html