init();
if(file_exists($xj_event_wxset = DISCUZ_ROOT.'./data/sysdata/cache_xj_event_wxset.php')) {
@include $xj_event_wxset;
}
if(function_exists('file_get_contents')){
$xml = file_get_contents("php://input");
}else{
$xml = $GLOBALS["HTTP_RAW_POST_DATA"];
}
$post = xmlToArray($xml);
$paytype = DB::result_first("SELECT paytype FROM ".DB::table('xj_eventpay_log')." WHERE tradeno='".$post['out_trade_no']."'");
if($paytype == 'appwxpay'){
$apikey = $wxset['open_apikey']; //APIKEY
}elseif($paytype == 'xcxwxpay'){
$apikey = $wxset['xcx_apikey']; //APIKEY
}else{
$apikey = $wxset['apikey']; //APIKEY
}
if(checkSign($post)){
if($post['result_code'] == 'SUCCESS'){
$paylog = DB::fetch_first("SELECT * FROM ".DB::table('xj_eventpay_log')." WHERE tradeno='".$post['out_trade_no']."'");
if($paylog['paystate'] != 3){
$data = array();
$data['paystate'] = 3;
$data['orderid'] = $post['transaction_id'];
$data['pay_time'] = $_G['timestamp'];
$data['notify_time'] = $_G['timestamp'];
DB::update("xj_eventpay_log",$data,"tradeno='".$post['out_trade_no']."'");
$paylog = DB::fetch_first("SELECT applyid,trade_status,uid,tid FROM ".DB::table('xj_eventpay_log')." WHERE tradeno='".$post['out_trade_no']."'");
$tid = $paylog['tid'];
$uid = $paylog['uid'];
$data = array();
$data['pay_state'] = 1;
$data['verify'] = 1;
DB::update("xj_eventapply",$data,"tid=$tid AND uid=$uid");
//邀请的奖励处理
$items = DB::fetch(DB::query("SELECT A.*,B.authorid,B.subject FROM ".DB::table('xj_event')." A LEFT JOIN ".DB::table('forum_thread')." B ON A.tid = B.tid WHERE A.tid = $tid"));
$setting = unserialize($items['setting']);
if($setting['yqjl_jfs']>0){
$apply = DB::fetch_first("SELECT * FROM ".DB::table('xj_eventapply')." WHERE applyid = ".$paylog['applyid']);
if($apply['fromuid'] > 0){
$applynumber = DB::result_first("SELECT SUM(applynumber) FROM ".DB::table('xj_eventapply')." WHERE tid=".$tid." AND uid=".$uid);
$yqjl = array();
$yqjl['tid'] = $tid;
$yqjl['fromuid'] = $apply['fromuid'];
$yqjl['applyuid'] = $uid;
$yqjl['jfs'] = $setting['yqjl_jfs']*$applynumber;
$yqjl['jflx'] = $setting['yqjl_jflx'];
$yqjl['dateline'] = $_G['timestamp'];
DB::insert('xj_event_yqjl_log',$yqjl);
updatemembercount($yqjl['fromuid'],array($yqjl['jflx']=>+$yqjl['jfs']));
$username = DB::result_first("SELECT username FROM ".DB::table('common_member')." WHERE uid=$uid");
$eventtitle = DB::result_first("SELECT subject FROM ".DB::table('forum_thread')." WHERE tid = $tid");
notification_add($yqjl['fromuid'],'system',$username.lang('plugin/xj_event','beiniyaoqinbaomincanjiale').' '.$eventtitle.' '.lang('plugin/xj_event','huodonghuode').$yqjl['jfs'].$_G['setting']['extcredits'][$yqjl['jflx']]['title'].lang('plugin/xj_event','jiangli'));
}
}
paysmssend($tid,$uid);
//通知
$username = DB::result_first("SELECT username FROM ".DB::table('common_member')." WHERE uid=$uid");
if($_G['charset']=='gbk'){
notification_add($items['authorid'], 'system', $username.iconv('UTF-8','GBK','报名参加了你的活动').' '.$items['subject'].' '.iconv('UTF-8','GBK','并已支付活动费用'),array(),0);
}else{
notification_add($items['authorid'], 'system', $username.'报名参加了你的活动 '.$items['subject'].' 并已支付活动费用',array(),0);
}
//微信消息
loadcache('plugin');
if($_G['cache']['plugin']['xj_wxmessage']['wxlogin']){
require_once DISCUZ_ROOT . './source/plugin/xj_wxmessage/class/core.class.php';
$xj_wxmessagecore = new xj_wxmessagecore();
$xj_wxmessagecore->send_eventmessage($uid,$tid,1);
$xj_wxmessagecore->send_eventapplymessage($paylog['applyid'],$items['authorid'],2);
}
}
$return = array();
$return['return_code'] = 'SUCCESS'; //SUCCESS/FAIL SUCCESS表示商户接收通知成功并校验成功
$return['return_msg'] = 'ok'; //返回信息,如非空,为错误原因
}else{
$return = array();
$return['return_code'] = 'FAIL'; //SUCCESS/FAIL SUCCESS表示商户接收通知成功并校验成功
$return['return_msg'] = 'ERROR'; //返回信息,如非空,为错误原因
}
echo arrayToXml($return);
}else{
//调试记录开始
$log_name="./wxpay.txt";//log文件路径
log_result($log_name,"【签名".$apikey."不正确】:\r\n".$xml."\r\n【返回的信息】:".arrayToXml($return)."\r\n");
//调试记录结
exit('error');
}
//调试记录开始
//$log_name="./wxpay.txt";//log文件路径
//log_result($log_name,"【接收到的notify通知】:\r\n".$xml."\r\n【返回的信息】:".arrayToXml($return)."\r\n");
//调试记录结束
/*
$url='http://'.$_SERVER['SERVER_NAME'].$_SERVER["REQUEST_URI"];
$url = str_replace('source/plugin/xj_event/event_pay_wx_notify.php','plugin.php?id=xj_event:wsq_pay_notify',$url);
$return = postxml($url,$xml);
*/
function paysmssend($tid,$uid){
global $_G;
//调试记录开始
//$log_name="./alipay.txt";//log文件路径
//log_result($log_name,"【接收到的notify通知】:\r\n".$xml."\r\n【返回的信息】:\r\n");
//调试记录结束
$apply = DB::fetch_first("SELECT * FROM ".DB::table('xj_eventapply')." WHERE first=1 AND tid=$tid AND uid=$uid");
$thread = DB::fetch_first("SELECT authorid,userfield,setting,subject,starttime,event_address FROM ".DB::table('forum_thread')." A,".DB::table('xj_event')." B WHERE A.tid=$tid and A.tid = B.tid");
$setting = unserialize($thread['setting']);
$event_starttime = dgmdate($thread['starttime'],'dt');
if($setting['seccode'] == 1){
$message = cutstr($thread['subject'],30).'活动报名成功,人数:'.$apply['applynumber'].'人 验证码:'.$apply['seccode'].' 活动时间:'.$event_starttime;
$sendtype = '报名验证码短信';
if($_G[charset]=='gbk'){
$message = diconv($message,'UTF-8','GBK');
$sendtype = diconv($sendtype,'UTF-8','GBK');
}
sendsms_vcode($apply['mobile'],$thread['subject'],$apply['applynumber'],$apply['seccode']);
//xjsendsms(array($apply['mobile']),$message,$sendtype);
sendpm($apply['uid'],'',$message,$thread['authorid']);
}elseif($setting['success_sms'] == 1){
sendsms_success($apply['mobile'],$thread['subject'],$event_starttime);
//易活动短信
//$smsuid = DB::result_first("SELECT uid FROM ".DB::table('common_member')." WHERE username='".$setting['event_admin'][0]."'");
//$smsmobile = DB::result_first("SELECT mobile FROM ".DB::table('common_member_profile')." WHERE uid=$smsuid");
//sendsms_notice_yhd($apply['mobile'],$thread['subject'],$event_starttime,$thread['event_address'],$smsmobile);
}
}
function postxml($url,$data){
$ch = curl_init($url);
curl_setopt($ch, CURLOPT_MUTE, 1);
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 0);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 0);
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-Type: text/xml'));
curl_setopt($ch, CURLOPT_POSTFIELDS, "$data");
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
$output = curl_exec($ch);
curl_close($ch);
return $output;
}
/**
* 作用:array转xml
*/
function arrayToXml($arr)
{
$xml = "";
foreach ($arr as $key=>$val)
{
if (is_numeric($val))
{
$xml.="<".$key.">".$val."".$key.">";
}
else
$xml.="<".$key.">".$key.">";
}
$xml.="";
return $xml;
}
/**
* 作用:将xml转为array
*/
function xmlToArray($xml)
{
//将XML转为array
$array_data = json_decode(json_encode(simplexml_load_string($xml, 'SimpleXMLElement', LIBXML_NOCDATA)), true);
return $array_data;
}
// 打印log
function log_result($file,$word)
{
$fp = fopen($file,"a");
flock($fp, LOCK_EX) ;
fwrite($fp,"执行日期:".strftime("%Y-%m-%d-%H:%M:%S",time())."\n".$word."\n\n");
flock($fp, LOCK_UN);
fclose($fp);
}
/**
* 作用:格式化参数,签名过程需要使用
*/
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;
}
//生成签名
function getSign($Obj){
global $apikey;
foreach ($Obj as $k => $v)
{
$Parameters[$k] = $v;
}
//签名步骤一:按字典序排序参数
ksort($Parameters);
$String = formatBizQueryParaMap($Parameters, false);
//echo '【string1】'.$String.'';
//签名步骤二:在string后加入KEY
$String = $String."&key=$apikey";
//echo "【string2】".$String."";
//签名步骤三:MD5加密
$String = md5($String);
//echo "【string3】 ".$String."";
//签名步骤四:所有字符转为大写
$result_ = strtoupper($String);
//echo "【result】 ".$result_."";
return $result_;
}
//验证签名是否正确
function checkSign($xmlarray){
$tmpData = $xmlarray;
unset($tmpData['sign']);
$sign = getSign($tmpData);//本地签名
//调试记录开始
//$log_name="./wxpay.txt";//log文件路径
//log_result($log_name,"【本地签名】:\r\n".$sign."\r\n");
//调试记录结
if ($xmlarray['sign'] == $sign) {
return TRUE;
}
return FALSE;
}
function postXmlCurl($xml,$url,$second=30)
{
//初始化curl
$ch = curl_init();
//设置超时
curl_setopt($ch, CURLOP_TIMEOUT, $second);
//这里设置代理,如果有的话
//curl_setopt($ch,CURLOPT_PROXY, '8.8.8.8');
//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);
//设置header
curl_setopt($ch, CURLOPT_HEADER, FALSE);
//要求结果为字符串且输出到屏幕上
curl_setopt($ch, CURLOPT_RETURNTRANSFER, TRUE);
//post提交方式
curl_setopt($ch, CURLOPT_POST, TRUE);
curl_setopt($ch, CURLOPT_POSTFIELDS, $xml);
//运行curl
$data = curl_exec($ch);
curl_close($ch);
//返回结果
if($data)
{
curl_close($ch);
return $data;
}
else
{
$error = curl_errno($ch);
echo "curl error:$error"."
";
echo "error view";
curl_close($ch);
return false;
}
}
?>