?? pp_dederemote_asp.php
字號:
<?php
/*-------------------------------------------
通行站反向整合接口遠程調用文件
本接口不需要導入第三方程序的用戶和密碼信息,系統會自動判斷和生成
本文件僅作為網關供遠程調用
請使用或參考 pp_dederemote_interface.asp 提供的接口函數進行整合編程
-----------------------------------------*/
require_once(dirname(__FILE__)."/../../include/config_base.php");
header("Content-Type: text/html; charset=gb2312");
if($cfg_pp_isopen = 0){
echo "系統沒開啟通行證功能,禁止遠程調用!";
exit();
}
$cfg_ndsql = 0;
if(empty($rmdata)){
echo "沒接收到任何遠程數據!";
exit();
}
$keys = Array('userid','signstr','action');
foreach($keys as $v) $$v = '';
//解碼GET字符串
$datas = explode('&',$rmdata);
foreach($datas as $ky){
$nkys = explode('=',$ky);
if(in_array($nkys[0],$keys) && isset($nkys[1])) ${$nkys[0]} = urldecode($nkys[1]);
}
$ntime = time();
if($action!='exit'){
//驗證證書
if($userid==''||!TestStringSafe($userid)){
echo "用戶ID為空或存在非法字符串!".$oldrmdata;
exit();
}
if(strlen($userid)>24){
echo "用戶ID長度不能超過24位!";
exit();
}
$testSign = substr(md5($userid.$cfg_cookie_encode),0,24);
if($testSign!=$signstr){
echo "證書驗證失敗!";
exit();
}
}
//注解里的function僅方便UltraEdit索引,并無其它意義
/*--------------------------------
會員注冊
function __UserReg()
---------------------------------*/
if($action=='reg'){
Z_OpenSql();
$row = $cfg_ndsql->GetOne("Select ID,pwd From #@__member where userid = '$userid' ");
//如果已經存在用戶名,檢測密碼是否正確,如果密碼正確,則返回登錄信息,否則不允許注冊
if(is_array($row)){
echo "用戶ID:{$userid} 已存在,請使用其它用戶名!";
Z_CloseSql();
exit();
}
$userpwd = chr(mt_rand(ord('A'),ord('Z'))).chr(mt_rand(ord('a'),ord('z'))).chr(mt_rand(ord('A'),ord('Z'))).chr(mt_rand(ord('A'),ord('Z'))).chr(mt_rand(ord('a'),ord('z'))).mt_rand(1000,9999).chr(mt_rand(ord('A'),ord('Z')));
$userpwd = GetEncodePwd($userpwd);
$loginip = Z_GetIP();
$inQuery = "
INSERT INTO #@__member(userid,pwd,uname,sex,birthday,membertype,money,
weight,height,job,province,city,myinfo,tel,oicq,email,homepage,
jointime,joinip,logintime,loginip,showaddr,address)
VALUES ('$userid','$userpwd','$userid','','0000-00-00','10','0',
'0','0','','0','0','','','','','','$ntime','$loginip','$ntime','$loginip','0','');";
$cfg_ndsql->ExecuteNoneQuery($inQuery);
$row = $cfg_ndsql->GetOne("Select ID From #@__member where userid like '$userid' ");
if(!is_array($row)){
Z_CloseSql();
echo "系統出錯,無法完成注冊,請聯系管理員!";
exit();
}
$ID = $row['ID'];
Z_CloseSql();
$backString = $ID;
echo 'OK!'.$backString;
exit();
}
/*--------------------------------
會員登錄
function __UserLogin()
---------------------------------*/
else if($action=='login'){
Z_OpenSql();
$row = $cfg_ndsql->GetOne("Select ID,pwd From #@__member where userid like '$userid' ");
if(!is_array($row)){
$userpwd = chr(mt_rand(ord('A'),ord('Z'))).chr(mt_rand(ord('a'),ord('z'))).chr(mt_rand(ord('A'),ord('Z'))).chr(mt_rand(ord('A'),ord('Z'))).chr(mt_rand(ord('a'),ord('z'))).mt_rand(1000,9999).chr(mt_rand(ord('A'),ord('Z')));
$userpwd = GetEncodePwd($userpwd);
$loginip = Z_GetIP();
$inQuery = "
INSERT INTO #@__member(userid,pwd,uname,sex,birthday,membertype,money,
weight,height,job,province,city,myinfo,tel,oicq,email,homepage,
jointime,joinip,logintime,loginip,showaddr,address)
VALUES ('$userid','$userpwd','$userid','','0000-00-00','10','0',
'0','0','','0','0','','','','','','$ntime','$loginip','$ntime','$loginip','0','');";
$cfg_ndsql->ExecuteNoneQuery($inQuery);
$row = $cfg_ndsql->GetOne("Select ID,pwd From #@__member where userid like '$userid' ");
}
$ID = $row['ID'];
$loginip = Z_GetIP();
$cfg_ndsql->ExecuteNoneQuery("update #@__member set logintime='$ntime',loginip='$loginip' where ID='$ID' ");
Z_CloseSql();
$backString = $ID;
echo 'OK!'.$backString;
exit();
}
/*--------------------------------
退出系統
function __UserExit()
---------------------------------*/
else if($action=='exit'){
$backString = "0";
echo 'OK!'.$backString;
exit();
}
/*--------------------------------
無法識別遠程動作
function __ActionError()
---------------------------------*/
else{
echo "無法識別你的動作!";
exit();
}
//其它功能如函數
function Z_OpenSql(){
global $cfg_ndsql;
if(!$cfg_ndsql) $cfg_ndsql = new DedeSql(false);
}
function Z_CloseSql(){
global $cfg_ndsql;
if($cfg_ndsql) $cfg_ndsql->Close();
}
function Z_GetIP(){
if(!empty($_SERVER["HTTP_CLIENT_IP"])) $cip = $_SERVER["HTTP_CLIENT_IP"];
else if(!empty($_SERVER["HTTP_X_FORWARDED_FOR"])) $cip = $_SERVER["HTTP_X_FORWARDED_FOR"];
else if(!empty($_SERVER["REMOTE_ADDR"])) $cip = $_SERVER["REMOTE_ADDR"];
else $cip = "無法獲取!";
return $cip;
}
?>
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -