検索

Destoon 核心

May 25, 2016 pm 05:09 PM
php

1. [代码]Destoon 核心    

<?php
/*
	[Destoon B2B System] Copyright (c) 2008-2011 Destoon.COM
	This is NOT a freeware, use is subject to license.txt
*/
defined(&#39;IN_DESTOON&#39;) or exit(&#39;Access Denied&#39;);
function dhtmlspecialchars($string) {
    return is_array($string) ? array_map(&#39;dhtmlspecialchars&#39;, $string) : str_replace(&#39;&amp;&#39;, &#39;&&#39;, htmlspecialchars($string, ENT_QUOTES));
}

function daddslashes($string) {
	if(!is_array($string)) return addslashes($string);
	foreach($string as $key => $val) $string[$key] = daddslashes($val);
	return $string;
}

function dstripslashes($string) {
	if(!is_array($string)) return stripslashes($string);
	foreach($string as $key => $val) $string[$key] = dstripslashes($val);
	return $string;
}

function dsafe($string) {
	if(is_array($string)) {
		return array_map(&#39;dsafe&#39;, $string);
	} else {
		if(strlen($string) < 20) return $string;
		$match = array("/&#([a-z0-9]+)([;]*)/i", "/(j[\s\r\n\t]*a[\s\r\n\t]*v[\s\r\n\t]*a[\s\r\n\t]*s[\s\r\n\t]*c[\s\r\n\t]*r[\s\r\n\t]*i[\s\r\n\t]*p[\s\r\n\t]*t|jscript|js|vbscript|vbs|about|expression|script|frame|link|import)/i", "/on(mouse|exit|error|click|dblclick|key|load|unload|change|move|submit|reset|cut|copy|select|start|stop)/i");
		$replace = array("", "<d>\\1</d>", "on\n\\1");
		return preg_replace($match, $replace, $string);
	}
}

function dtrim($string, $js = false) {
	$string = str_replace(array(chr(10), chr(13)), array(&#39;&#39;, &#39;&#39;), $string);
	return $js ? str_replace("&#39;", "\&#39;", $string) : $string;
}

function dheader($url) {
	global $DT;	
	if(!defined(&#39;DT_ADMIN&#39;) && $DT[&#39;defend_reload&#39;]) sleep($DT[&#39;defend_reload&#39;]);
	exit(header(&#39;location:&#39;.$url));
}

function dmsg($dmsg = &#39;&#39;, $dforward = &#39;&#39;) {
	if(!$dmsg && !$dforward) {
		$dmsg = get_cookie(&#39;dmsg&#39;);
		if($dmsg) {
			echo &#39;<script type="text/javascript">showmsg(\&#39;&#39;.$dmsg.&#39;\&#39;);</script>&#39;;
			set_cookie(&#39;dmsg&#39;, &#39;&#39;);
		}
	} else {
		set_cookie(&#39;dmsg&#39;, $dmsg);
		$dforward = preg_replace("/(.*)([&?]rand=[0-9]*)(.*)/i", "\\1\\3", $dforward);
		$dforward = str_replace(&#39;.php&&#39;, &#39;.php?&#39;, $dforward);
		$dforward = strpos($dforward, &#39;?&#39;) === false ? $dforward.&#39;?rand=&#39;.mt_rand(10, 99) : str_replace(&#39;?&#39;, &#39;?rand=&#39;.mt_rand(10, 99).&#39;&&#39;, $dforward);
		dheader($dforward);
	}
}

function dalert($dmessage = errmsg, $dforward = &#39;&#39;, $extend = &#39;&#39;) {
	global $CFG, $DT;
	exit(include template(&#39;alert&#39;, &#39;message&#39;));
}

function dsubstr($string, $length, $suffix = &#39;&#39;, $start = 0) {
	if($start) {
		$tmp = dsubstr($string, $start);
		$string = substr($string, strlen($tmp));
	}
	$strlen = strlen($string);
	if($strlen <= $length) return $string;
	$string = str_replace(array(&#39;&quot;&#39;, &#39;&lt;&#39;, &#39;&gt;&#39;), array(&#39;"&#39;, &#39;<&#39;, &#39;>&#39;), $string);
	$length = $length - strlen($suffix);
	$str = &#39;&#39;;
	if(strtolower(DT_CHARSET) == &#39;utf-8&#39;) {
		$n = $tn = $noc = 0;
		while($n < $strlen)	{
			$t = ord($string{$n});
			if($t == 9 || $t == 10 || (32 <= $t && $t <= 126)) {
				$tn = 1; $n++; $noc++;
			} elseif(194 <= $t && $t <= 223) {
				$tn = 2; $n += 2; $noc += 2;
			} elseif(224 <= $t && $t <= 239) {
				$tn = 3; $n += 3; $noc += 2;
			} elseif(240 <= $t && $t <= 247) {
				$tn = 4; $n += 4; $noc += 2;
			} elseif(248 <= $t && $t <= 251) {
				$tn = 5; $n += 5; $noc += 2;
			} elseif($t == 252 || $t == 253) {
				$tn = 6; $n += 6; $noc += 2;
			} else {
				$n++;
			}
			if($noc >= $length) break;
		}
		if($noc > $length) $n -= $tn;
		$str = substr($string, 0, $n);
	} else {
		for($i = 0; $i < $length; $i++) {
			$str .= ord($string{$i}) > 127 ? $string{$i}.$string{++$i} : $string{$i};
		}
	}
	$str = str_replace(array(&#39;"&#39;, &#39;<&#39;, &#39;>&#39;), array(&#39;&quot;&#39;, &#39;&lt;&#39;, &#39;&gt;&#39;), $str);
	return $str == $string ? $str : $str.$suffix;
}

function encrypt($txt, $key = &#39;&#39;) {
	$rnd = md5(microtime());
	$len = strlen($txt);
	$ren = strlen($rnd);
	$ctr = 0;
	$str = &#39;&#39;;
	for($i = 0; $i < $len; $i++) {
		$ctr = $ctr == $ren ? 0 : $ctr;
		$str .= $rnd[$ctr].($txt[$i] ^ $rnd[$ctr++]);
	}
	return str_replace(&#39;=&#39;, &#39;&#39;, base64_encode(kecrypt($str, $key)));
}

function decrypt($txt, $key = &#39;&#39;) {
	$txt = kecrypt(base64_decode($txt), $key);
	$len = strlen($txt);
	$str = &#39;&#39;;
	for($i = 0; $i < $len; $i++) {
		$tmp = $txt[$i];
		$str .= $txt[++$i] ^ $tmp;
	}
	return $str;
}

function kecrypt($txt, $key) {
	$key = md5($key);
	$len = strlen($txt);
	$ken = strlen($key);
	$ctr = 0;
	$str = &#39;&#39;;
	for($i = 0; $i < $len; $i++) {
		$ctr = $ctr == $ken ? 0 : $ctr;
		$str .= $txt[$i] ^ $key[$ctr++];
	}
	return $str;
}

function strtohex($str) {
	$hex = &#39;&#39;;
	for($i = 0; $i < strlen($str); $i++) {
		$hex .= dechex(ord($str[$i]));
	}
	return $hex;
}

function hextostr($hex) {
	$str = &#39;&#39;;
	for($i = 0; $i < strlen($hex) - 1; $i += 2) {
		$str .= chr(hexdec($hex[$i].$hex[$i+1]));
	}
	return $str;
}

function dround($var, $precision = 2, $sprinft = false) {
	$var = round(floatval($var), $precision);
	if($sprinft) $var = sprintf(&#39;%.&#39;.$precision.&#39;f&#39;, $var);
	return $var;
}

function dalloc($i, $n = 5000) {
	return ceil($i/$n);
}

function strip_sql($string) {
	$search = array("/union[\s|\t]/i","/select[\s|\t]/i","/update[\s|\t]/i","/outfile[\s|\t]/i","/ascii/i","/[\s|\t]or[\s|\t]/i","/\/\*/i");
	$replace = array(&#39;union &#39;,&#39;select &#39;,&#39;update &#39;,&#39;outfile &#39;,&#39;ascii &#39;,&#39; or &#39;, &#39;&#39;);
	return is_array($string) ? array_map(&#39;strip_sql&#39;, $string) : preg_replace($search, $replace, $string);
}

function strip_nr($string, $js = false) {
	$string =  str_replace(array(chr(13), chr(10), "\n", "\r", "\t", &#39;  &#39;),array(&#39;&#39;, &#39;&#39;, &#39;&#39;, &#39;&#39;, &#39;&#39;, &#39;&#39;), $string);
	if($js) $string = str_replace("&#39;", "\&#39;", $string);
	return $string;
}

function template($template = &#39;index&#39;, $dir = &#39;&#39;) {
	global $CFG;
	$to = $dir ? DT_CACHE.&#39;/tpl/&#39;.$dir.&#39;-&#39;.$template.&#39;.php&#39; : DT_CACHE.&#39;/tpl/&#39;.$template.&#39;.php&#39;;
	$isfileto = is_file($to);
	if($CFG[&#39;template_refresh&#39;] || !$isfileto) {
		if($dir) $dir = $dir.&#39;/&#39;;
        $from = DT_ROOT.&#39;/template/&#39;.$CFG[&#39;template&#39;].&#39;/&#39;.$dir.$template.&#39;.htm&#39;;
		if($CFG[&#39;template&#39;] != &#39;default&#39; && !is_file($from)) {
			$from = DT_ROOT.&#39;/template/default/&#39;.$dir.$template.&#39;.htm&#39;;
		}
        if(!$isfileto || filemtime($from) > filemtime($to) || (filesize($to) == 0 && filesize($from) > 0)) {
			require_once DT_ROOT.&#39;/include/template.func.php&#39;;
			template_compile($from, $to);
		}
	}
	return $to;
}

function ob_template($template, $dir = &#39;&#39;) {
	extract($GLOBALS, EXTR_SKIP);
	ob_start();
	include template($template, $dir);
	$contents = ob_get_contents();
	ob_clean();
	return $contents;
}

function message($dmessage = errmsg, $dforward = &#39;goback&#39;, $dtime = 1) {
	global $CFG, $DT;
	if(!$dmessage && $dforward && $dforward != &#39;goback&#39;) dheader($dforward);
	exit(include template(&#39;message&#39;, &#39;message&#39;));
}

function login() {
	global $_userid, $MODULE, $DT_URL, $DT;
	$_userid or dheader($MODULE[2][&#39;linkurl&#39;].$DT[&#39;file_login&#39;].&#39;?forward=&#39;.rawurlencode($DT_URL));
}

function random($length, $chars = &#39;ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789abcdefghijklmnopqrstuvwxyz&#39;) {
	$hash = &#39;&#39;;
	$max = strlen($chars) - 1;
	for($i = 0; $i < $length; $i++)	{
		$hash .= $chars[mt_rand(0, $max)];
	}
	return $hash;
}

function set_cookie($var, $value = &#39;&#39;, $time = 0) {
	global $CFG, $DT_TIME;
	$time = $time > 0 ? $time : (empty($value) ? $DT_TIME - 3600 : 0);
	$port = $_SERVER[&#39;SERVER_PORT&#39;] == &#39;443&#39; ? 1 : 0;
	$var = $CFG[&#39;cookie_pre&#39;].$var;
	return setcookie($var, $value, $time, $CFG[&#39;cookie_path&#39;], $CFG[&#39;cookie_domain&#39;], $port);
}

function get_cookie($var) {
	global $CFG;
	$var = $CFG[&#39;cookie_pre&#39;].$var;
	return isset($_COOKIE[$var]) ? $_COOKIE[$var] : &#39;&#39;;
}

function get_table($moduleid, $data = 0) {
	global $DT_PRE, $MODULE;
	$module = $MODULE[$moduleid][&#39;module&#39;];
	if($data) {
		return in_array($module, array(&#39;article&#39;, &#39;info&#39;)) ? $DT_PRE.$module.&#39;_data_&#39;.$moduleid : $DT_PRE.$module.&#39;_data&#39;;
	} else {
		return in_array($module, array(&#39;article&#39;, &#39;info&#39;)) ? $DT_PRE.$module.&#39;_&#39;.$moduleid : $DT_PRE.$module;
	}
}

function get_process($fromtime, $totime) {
	global $DT_TIME;
	if($fromtime && $DT_TIME < $fromtime) return 1;
	if($totime && $DT_TIME > $totime) return 3;
	return 2;
}

function send_message($touser, $title, $content, $typeid = 4, $fromuser = &#39;&#39;) {
	global $db, $DT_TIME, $DT_IP;
	if($touser == $fromuser) return false;
	if(check_name($touser) && $title && $content) {
		$title = addslashes($title);
		$content = addslashes($content);
		$r = $db->get_one("SELECT black FROM {$db->pre}member WHERE username=&#39;$touser&#39;");
		if($r) {
			if($r[&#39;black&#39;] && $typeid != 4) {
				$blacks = explode(&#39; &#39;, $r[&#39;black&#39;]);
				$_from = $fromuser ? $fromuser : &#39;Guest&#39;;
				if(in_array($_from, $blacks)) return false;
			}
			$db->query("INSERT INTO {$db->pre}message (title,typeid,touser,fromuser,content,addtime,ip,status) VALUES (&#39;$title&#39;, $typeid, &#39;$touser&#39;,&#39;$fromuser&#39;,&#39;$content&#39;,&#39;$DT_TIME&#39;,&#39;$DT_IP&#39;,3)");			
			$db->query("UPDATE {$db->pre}member SET message=message+1 WHERE username=&#39;$touser&#39;");
			if($fromuser) {
				$db->query("INSERT INTO {$db->pre}message (title,typeid,content,fromuser,touser,addtime,ip,status) VALUES (&#39;$title&#39;,&#39;$typeid&#39;,&#39;$content&#39;,&#39;$fromuser&#39;,&#39;$touser&#39;,&#39;$DT_TIME&#39;,&#39;$DT_IP&#39;,&#39;2&#39;)");
			}
			return true;
		}
	}
	return false;
}

function send_mail($mail_to, $mail_subject, $mail_body, $mail_from = &#39;&#39;, $mail_sign = true) {
	global $DT;
	require_once DT_ROOT.&#39;/include/mail.func.php&#39;;
	$result = dmail(trim($mail_to), $mail_subject, $mail_body, $mail_from, $mail_sign);
	$success = $result == &#39;SUCCESS&#39; ? 1 : 0;
	if($DT[&#39;mail_log&#39;]) {
		global $DT_TIME, $db;
		$status = $success ? 3 : 2;
		$note = $success ? &#39;&#39; : addslashes($result);
		$mail_subject = stripslashes($mail_subject);
		$mail_body = stripslashes($mail_body);
		$mail_subject = addslashes($mail_subject);
		$mail_body = addslashes($mail_body);
		$db->query("INSERT INTO {$db->pre}mail_log (email,title,content,addtime,status,note) VALUES (&#39;$mail_to&#39;,&#39;$mail_subject&#39;,&#39;$mail_body&#39;,&#39;$DT_TIME&#39;,&#39;$status&#39;,&#39;$note&#39;)");
	}
	return $success;
}

function strip_sms($message) {
	global $DT;
	$message = strip_tags($message);
	$message = preg_replace("/&([a-z]{1,});/", &#39;&#39;, $message);
	$message = str_replace(&#39; &#39;, &#39;&#39;, $message);
	if($DT[&#39;sms_sign&#39;]) $message .= $DT[&#39;sms_sign&#39;];
	return $message;
}

function send_sms($mobile, $message, $word = 0, $time = 0) {
	global $db, $DT, $DT_TIME, $DT_IP, $_username;
	if(!$DT[&#39;sms&#39;] || !$DT[&#39;sms_uid&#39;] || !$DT[&#39;sms_key&#39;]) return false;
	$word or $word = word_count($message);
	$sms_message = rawurlencode(convert($message, DT_CHARSET, &#39;UTF-8&#39;));
	$data = &#39;sms_uid=&#39;.$DT[&#39;sms_uid&#39;].&#39;&sms_key=&#39;.$DT[&#39;sms_key&#39;].&#39;&sms_charset=&#39;.DT_CHARSET.&#39;&sms_mobile=&#39;.$mobile.&#39;&sms_message=&#39;.$sms_message.&#39;&sms_time=&#39;.$time;
	$header = "POST /send.php HTTP/1.0\r\n";
	$header .= "Accept: */*\r\n";
	$header .= "Content-Type: application/x-www-form-urlencoded\r\n";
	$header .= "Content-Length: ".strlen($data)."\r\n\r\n";
	$DT[&#39;sms_host&#39;] or $DT[&#39;sms_host&#39;] = &#39;sms&#39;;
	$fp = fsockopen($DT[&#39;sms_host&#39;].&#39;.destoon.com&#39;, 8820);
	$code = &#39;&#39;;
	if($fp) {
		fputs($fp, $header.$data);
		while(!feof($fp)) {
			$code .= fgets($fp, 1024);
		}
		fclose($fp);
		if($code && strpos($code, &#39;destoon_sms_code=&#39;) !== false) {
			$code = explode(&#39;destoon_sms_code=&#39;, $code);
			$code = $code[1];
		} else {
			$code = &#39;Can Not Connect SMS Server&#39;;
		}
	} else {
		$code = &#39;Can Not Connect SMS Server&#39;;
	}
	$db->query("INSERT INTO {$db->pre}sms (mobile,message,word,editor,sendtime,code) VALUES (&#39;$mobile&#39;,&#39;$message&#39;,&#39;$word&#39;,&#39;$_username&#39;,&#39;$DT_TIME&#39;,&#39;$code&#39;)");
	return $code;
}

function word_count($string) {
	$string = convert($string, DT_CHARSET, &#39;gbk&#39;);
	$length = strlen($string);
	$count = 0;
	for($i = 0; $i < $length; $i++) {
		$t = ord($string[$i]);
		if($t > 127) $i++;
		$count++;
	}
	return $count;
}

function cache_read($file, $dir = &#39;&#39;, $mode = &#39;&#39;) {
	$file = $dir ? DT_CACHE.&#39;/&#39;.$dir.&#39;/&#39;.$file : DT_CACHE.&#39;/&#39;.$file;
	if(!is_file($file)) return array();
	return $mode ? file_get($file) : include $file;
}

function cache_write($file, $string, $dir = &#39;&#39;) {
	if(is_array($string)) $string = "<?php defined(&#39;IN_DESTOON&#39;) or exit(&#39;Access Denied&#39;); return ".strip_nr(var_export($string, true))."; ?>";
	$file = $dir ? DT_CACHE.&#39;/&#39;.$dir.&#39;/&#39;.$file : DT_CACHE.&#39;/&#39;.$file;
	$strlen = file_put($file, $string);
	return $strlen;
}

function cache_delete($file, $dir = &#39;&#39;) {
	$file = $dir ? DT_CACHE.&#39;/&#39;.$dir.&#39;/&#39;.$file : DT_CACHE.&#39;/&#39;.$file;
	return file_del($file);
}

function cache_clear($str, $type = &#39;&#39;, $dir = &#39;&#39;) {
	$dir = $dir ? DT_CACHE.&#39;/&#39;.$dir.&#39;/&#39; : DT_CACHE.&#39;/&#39;;
	$files = glob($dir.&#39;*&#39;);
	if(is_array($files)) {
		if($type == &#39;dir&#39;) {
			foreach($files as $file) {
				if(is_dir($file)) {dir_delete($file);} else {if(file_ext($file) == $str) file_del($file);}
			}
		} else {
			foreach($files as $file) {
				if(!is_dir($file) && strpos(basename($file), $str) !== false) file_del($file);
			}
		}
	}
}

function content_table($moduleid, $itemid, $split, $table_data = &#39;&#39;) {
	if($split) {
		return split_table($moduleid, $itemid);
	} else {
		$table_data or $table_data = get_table($moduleid, 1);
		return $table_data;
	}
}

function split_table($moduleid, $itemid) {
	global $DT_PRE;
	$part = split_id($itemid);
	return $DT_PRE.$moduleid.&#39;_&#39;.$part;
}

function split_id($id) {
	return $id > 0 ? ceil($id/500000) : 1;
}

function ip2area($ip) {
	$area = &#39;&#39;;
	if(is_ip($ip)) {
		$tmp = explode(&#39;.&#39;, $ip);
		if($tmp[0] == 10 || $tmp[0] == 127 || ($tmp[0] == 192 && $tmp[1] == 168) || ($tmp[0] == 172 && ($tmp[1] >= 16 && $tmp[1] <= 31))) {
			$area = &#39;LAN&#39;;
		} elseif($tmp[0] > 255 || $tmp[1] > 255 || $tmp[2] > 255 || $tmp[3] > 255) {
			$area = &#39;Unkonw&#39;;
		} else {
			require_once DT_ROOT.&#39;/include/ip.func.php&#39;;
			$area = convertip($ip);
		}
	}
	$area = convert($area, &#39;gbk&#39;, DT_CHARSET);
	return $area;
}

function banip($IP) {
	global $DT_IP, $DT_TIME;
	$ban = false;
	foreach($IP as $v) {
		if($v[&#39;totime&#39;] && $v[&#39;totime&#39;] < $DT_TIME) continue;
		if($v[&#39;ip&#39;] == $DT_IP) { $ban = true; break; }
		if(preg_match("/^".str_replace(&#39;*&#39;, &#39;[0-9]{1,3}&#39;, $v[&#39;ip&#39;])."$/", $DT_IP)) { $ban = true; break; }
	}
	if($ban) message(lang(&#39;include->msg_ip_ban&#39;, array($DT_IP)));
}

function banword($WORD, $string, $extend = true) {
	$string = stripslashes($string);
	foreach($WORD as $v) {
		$v[0] = preg_quote($v[0]);
		$v[0] = str_replace(&#39;/&#39;, &#39;\/&#39;, $v[0]);
		$v[0] = str_replace("\*", ".*", $v[0]);
		if($v[2] && $extend) {
			if(preg_match("/".$v[0]."/i", $string)) dalert(lang(&#39;include->msg_word_ban&#39;));
		} else {
			if($string == &#39;&#39;) break;
			if(preg_match("/".$v[0]."/i", $string)) $string = preg_replace("/".$v[0]."/i", $v[1], $string);
		}
	}
	return addslashes($string);
}

function get_env($type) {
	switch($type) {
		case &#39;ip&#39;:
			isset($_SERVER[&#39;HTTP_X_FORWARDED_FOR&#39;]) or $_SERVER[&#39;HTTP_X_FORWARDED_FOR&#39;] = &#39;&#39;;
			isset($_SERVER[&#39;REMOTE_ADDR&#39;]) or $_SERVER[&#39;REMOTE_ADDR&#39;] = &#39;&#39;;
			isset($_SERVER[&#39;HTTP_CLIENT_IP&#39;]) or $_SERVER[&#39;HTTP_CLIENT_IP&#39;] = &#39;&#39;;
			if($_SERVER[&#39;HTTP_X_FORWARDED_FOR&#39;] && $_SERVER[&#39;REMOTE_ADDR&#39;]) {
				$ip = $_SERVER[&#39;HTTP_X_FORWARDED_FOR&#39;];
				if(strpos($ip, &#39;,&#39;) !== false) {
					$tmp = explode(&#39;,&#39;, $ip);
					$ip = trim(end($tmp));
				}
				if(is_ip($ip)) return $ip;
			}
			if(is_ip($_SERVER[&#39;HTTP_CLIENT_IP&#39;])) return $_SERVER[&#39;HTTP_CLIENT_IP&#39;];
			if(is_ip($_SERVER[&#39;REMOTE_ADDR&#39;])) return $_SERVER[&#39;REMOTE_ADDR&#39;];
			return &#39;unknown&#39;;
		break;
		case &#39;self&#39;:
			return isset($_SERVER[&#39;PHP_SELF&#39;]) ? $_SERVER[&#39;PHP_SELF&#39;] : (isset($_SERVER[&#39;SCRIPT_NAME&#39;]) ? $_SERVER[&#39;SCRIPT_NAME&#39;] : $_SERVER[&#39;ORIG_PATH_INFO&#39;]);
		break;
		case &#39;referer&#39;:
			return isset($_SERVER[&#39;HTTP_REFERER&#39;]) ? $_SERVER[&#39;HTTP_REFERER&#39;] : &#39;&#39;;
		break;
		case &#39;domain&#39;:
			return $_SERVER[&#39;SERVER_NAME&#39;];
		break;
		case &#39;scheme&#39;:
			return $_SERVER[&#39;SERVER_PORT&#39;] == &#39;443&#39; ? &#39;https://&#39; : &#39;http://&#39;;
		break;
		case &#39;port&#39;:
			return $_SERVER[&#39;SERVER_PORT&#39;] == &#39;80&#39; ? &#39;&#39; : &#39;:&#39;.$_SERVER[&#39;SERVER_PORT&#39;];
		break;
		case &#39;url&#39;:
			if(isset($_SERVER[&#39;REQUEST_URI&#39;])) {
				$uri = $_SERVER[&#39;REQUEST_URI&#39;];
			} else {
				$uri = $_SERVER[&#39;PHP_SELF&#39;];
				if(isset($_SERVER[&#39;argv&#39;])) {
					if(isset($_SERVER[&#39;argv&#39;][0])) $uri .= &#39;?&#39;.$_SERVER[&#39;argv&#39;][0];
				} else {
					$uri .= &#39;?&#39;.$_SERVER[&#39;QUERY_STRING&#39;];
				}
			}
			$uri = dhtmlspecialchars($uri);
			return get_env(&#39;scheme&#39;).$_SERVER[&#39;HTTP_HOST&#39;].(strpos($_SERVER[&#39;HTTP_HOST&#39;], &#39;:&#39;) === false ? get_env(&#39;port&#39;) : &#39;&#39;).$uri;
		break;
	}
}

function convert($str, $from = &#39;utf-8&#39;, $to = &#39;gb2312&#39;) {
	if(!$str) return &#39;&#39;;
	$from = strtolower($from);
	$to = strtolower($to);
	if($from == $to) return $str;
	$from = str_replace(&#39;gbk&#39;, &#39;gb2312&#39;, $from);
	$to = str_replace(&#39;gbk&#39;, &#39;gb2312&#39;, $to);
	$from = str_replace(&#39;utf8&#39;, &#39;utf-8&#39;, $from);
	$to = str_replace(&#39;utf8&#39;, &#39;utf-8&#39;, $to);
	if($from == $to) return $str;
	$tmp = array();
	if(function_exists(&#39;iconv&#39;)) {
		if(is_array($str)) {
			foreach($str as $key => $val) {
				$tmp[$key] = iconv($from, $to."//IGNORE", $val);
			}
			return $tmp;
		} else {
			return iconv($from, $to."//IGNORE", $str);
		}
	} else if(function_exists(&#39;mb_convert_encoding&#39;)) {
		if(is_array($str)) {
			foreach($str as $key => $val) {
				$tmp[$key] = mb_convert_encoding($val, $to, $from);
			}
			return $tmp;
		} else {
			return mb_convert_encoding($str, $to, $from);
		}	
	} else {
		require_once DT_ROOT.&#39;/include/convert.func.php&#39;;
		return dconvert($str, $to, $from);
	}
}

function get_type($item, $cache = 0) {
	$types = array();
	if($cache) {
		$types = cache_read(&#39;type-&#39;.$item.&#39;.php&#39;);
	} else {
		global $db;
		$result = $db->query("SELECT * FROM {$db->pre}type WHERE item=&#39;$item&#39; ORDER BY listorder ASC,typeid DESC ");
		while($r = $db->fetch_array($result)) {
			$types[$r[&#39;typeid&#39;]] = $r;
		}
	}
	return $types;
}

function get_cat($catid) {
	global $db;
	$catid = intval($catid);
	return $catid ? $db->get_one("SELECT * FROM {$db->pre}category WHERE catid=$catid") : array();
}

function cat_pos($CAT, $str = &#39; &raquo; &#39;, $target = &#39;&#39;) {
	global $MODULE, $db;
	if(!$CAT) return &#39;&#39;;
	$arrparentids = $CAT[&#39;arrparentid&#39;].&#39;,&#39;.$CAT[&#39;catid&#39;];
	$arrparentid = explode(&#39;,&#39;, $arrparentids);
	$pos = &#39;&#39;;
	$target = $target ? &#39; target="_blank"&#39; : &#39;&#39;;	
	$CATEGORY = array();
	$result = $db->query("SELECT catid,moduleid,catname,linkurl FROM {$db->pre}category WHERE catid IN ($arrparentids)");
	while($r = $db->fetch_array($result)) {
		$CATEGORY[$r[&#39;catid&#39;]] = $r;
	}
	foreach($arrparentid as $catid) {
		if(!$catid || !isset($CATEGORY[$catid])) continue;
		$pos .= &#39;<a href="&#39;.$MODULE[$CATEGORY[$catid][&#39;moduleid&#39;]][&#39;linkurl&#39;].$CATEGORY[$catid][&#39;linkurl&#39;].&#39;"&#39;.$target.&#39;>&#39;.$CATEGORY[$catid][&#39;catname&#39;].&#39;</a>&#39;.$str;
	}
	$_len = strlen($str);
	if($str && substr($pos, -$_len, $_len) === $str) $pos = substr($pos, 0, strlen($pos)-$_len);
	return $pos;
}

function cat_url($catid) {
	global $MODULE, $db;
	$r = $db->get_one("SELECT moduleid,linkurl FROM {$db->pre}category WHERE catid=$catid");
	return $r ? $MODULE[$r[&#39;moduleid&#39;]][&#39;linkurl&#39;].$r[&#39;linkurl&#39;] : &#39;&#39;;
}

function get_area($areaid) {
	global $db;
	$areaid = intval($areaid);
	return $db->get_one("SELECT * FROM {$db->pre}area WHERE areaid=$areaid");
}

function area_pos($areaid, $str = &#39; &raquo; &#39;, $deep = 0) {
	if($areaid) {
		global $AREA;
	} else {
		global $L;
		return $L[&#39;allcity&#39;];
	}
	$AREA or $AREA = cache_read(&#39;area.php&#39;);
	$arrparentid = $AREA[$areaid][&#39;arrparentid&#39;] ? explode(&#39;,&#39;, $AREA[$areaid][&#39;arrparentid&#39;]) : array();
	$arrparentid[] = $areaid;
	$pos = &#39;&#39;;
	if($deep) $i = 1;
	foreach($arrparentid as $areaid) {
		if(!$areaid || !isset($AREA[$areaid])) continue;
		if($deep) {
			if($i > $deep) continue;
			$i++;
		}
		$pos .= $AREA[$areaid][&#39;areaname&#39;].$str;
	}
	$_len = strlen($str);
	if($str && substr($pos, -$_len, $_len) === $str) $pos = substr($pos, 0, strlen($pos)-$_len);
	return $pos;
}

function get_maincat($catid, $moduleid, $level = -1) {
	global $db;
	$condition = $catid ? "parentid=$catid" : "moduleid=$moduleid AND parentid=0";
	if($level >= 0) $condition .= " AND level=$level";
	$cat = array();
	$result = $db->query("SELECT catid,catname,child,style,linkurl,item FROM {$db->pre}category WHERE $condition ORDER BY listorder,catid ASC", &#39;CACHE&#39;);
	while($r = $db->fetch_array($result)) {
		$cat[] = $r;
	}
	return $cat;
}

function get_mainarea($areaid) {
	global $db;
	$areaid = intval($areaid);
	$are = array();
	$result = $db->query("SELECT areaid,areaname FROM {$db->pre}area WHERE parentid=$areaid ORDER BY listorder,areaid ASC", &#39;CACHE&#39;);
	while($r = $db->fetch_array($result)) {
		$are[] = $r;
	}
	return $are;
}

function get_user($value, $key = &#39;username&#39;, $from = &#39;userid&#39;) {
	global $db;
	$r = $db->get_one("SELECT `$from` FROM {$db->pre}member WHERE `$key`=&#39;$value&#39;");
	return $r[$from];
}

function check_group($groupid, $groupids) {
	if(!$groupids || $groupid == 1) return true;
	if($groupid == 4) $groupid = 3;
	return in_array($groupid, explode(&#39;,&#39;, $groupids));
}

function tohtml($htmlfile, $module = &#39;&#39;, $parameter = &#39;&#39;) {
	defined(&#39;TOHTML&#39;) or define(&#39;TOHTML&#39;, true);
    extract($GLOBALS, EXTR_SKIP);
	if($parameter) parse_str($parameter);
    include $module ? DT_ROOT.&#39;/module/&#39;.$module.&#39;/&#39;.$htmlfile.&#39;.htm.php&#39; : DT_ROOT.&#39;/include/&#39;.$htmlfile.&#39;.htm.php&#39;;
}

function set_style($string, $style = &#39;&#39;, $tag = &#39;span&#39;) {
	if(preg_match("/^#[0-9a-zA-Z]{6}$/", $style)) $style = &#39;color:&#39;.$style;
	return $style ? &#39;<&#39;.$tag.&#39; style="&#39;.$style.&#39;">&#39;.$string.&#39;</&#39;.$tag.&#39;>&#39; : $string;
}

function crypt_action($action) {
	global $DT_IP;
	return md5(md5($action.DT_KEY.$DT_IP));
}

function captcha($captcha, $enable = 1, $return = false) {
	global $DT_IP, $DT, $session;
	if($enable) {
		if($DT[&#39;captcha_cn&#39;]) {
			if(strlen($captcha) < 4) {
				$msg = lang(&#39;include->captcha_missed&#39;);
				return $return ? $msg : message($msg);
			}
		} else {
			if(!preg_match("/^[0-9a-z]{4,}$/i", $captcha)) {
				$msg = lang(&#39;include->captcha_missed&#39;);
				return $return ? $msg : message($msg);
			}
		}
		if(!is_object($session)) $session = new dsession();
		if(!isset($_SESSION[&#39;captchastr&#39;])) {
			$msg = lang(&#39;include->captcha_expired&#39;);
			return $return ? $msg : message($msg);
		}
		if($_SESSION[&#39;captchastr&#39;] != md5(md5(strtoupper($captcha).DT_KEY.$DT_IP))) {
			$msg = lang(&#39;include->captcha_error&#39;);
			return $return ? $msg : message($msg);
		}
		unset($_SESSION[&#39;captchastr&#39;]);
	} else {
		return &#39;&#39;;
	}
}

function question($answer, $enable = 1, $return = false) {
	global $DT_IP, $session;
	if($enable) {
		if(!$answer) {
			$msg = lang(&#39;include->answer_missed&#39;);
			return $return ? $msg : message($msg);
		}
		$answer = stripslashes($answer);
		if(!is_object($session)) $session = new dsession();
		if(!isset($_SESSION[&#39;answerstr&#39;])) {
			$msg = lang(&#39;include->question_expired&#39;);
			return $return ? $msg : message($msg);
		}
		if($_SESSION[&#39;answerstr&#39;] != md5(md5($answer.DT_KEY.$DT_IP))) {
			$msg = lang(&#39;include->answer_error&#39;);
			return $return ? $msg : message($msg);
		}
		unset($_SESSION[&#39;answerstr&#39;]);
	} else {
		return &#39;&#39;;
	}
}

function pages($total, $page = 1, $perpage = 20, $demo = &#39;&#39;, $step = 2) {
	global $DT_URL, $DT, $L;
	if($total <= $perpage) return &#39;&#39;;
	$items = $total;
	$total = ceil($total/$perpage);
	if($page < 1 || $page > $total) $page = 1;
	if($demo) {
		$demo_url = $demo;
		$home_url = str_replace(&#39;{destoon_page}&#39;, &#39;1&#39;, $demo_url);
	} else {
		if(defined(&#39;DT_REWRITE&#39;) && $DT[&#39;rewrite&#39;] && $_SERVER["SCRIPT_NAME"]) {
			$demo_url = $_SERVER["SCRIPT_NAME"];
			$demo_url = str_replace(&#39;//&#39;, &#39;/&#39;, $demo_url);//Fix Nginx
			$mark = false;
			if(substr($demo_url, -4) == &#39;.php&#39;) {
				if(strpos($_SERVER[&#39;QUERY_STRING&#39;], &#39;.html&#39;) === false) {
					$qstr = &#39;&#39;;
					if($_SERVER[&#39;QUERY_STRING&#39;]) {					
						if(substr($_SERVER[&#39;QUERY_STRING&#39;], -5) == &#39;.html&#39;) {
							$qstr = &#39;-&#39;.substr($_SERVER[&#39;QUERY_STRING&#39;], 0, -5);
						} else {
							parse_str($_SERVER[&#39;QUERY_STRING&#39;], $qs);
							foreach($qs as $k=>$v) {
								$qstr .= &#39;-&#39;.$k.&#39;-&#39;.rawurlencode($v);
							}
						}
					}
					$demo_url = substr($demo_url, 0, -4).&#39;-htm-page-{destoon_page}&#39;.$qstr.&#39;.html&#39;;
				} else {
					$demo_url = substr($demo_url, 0, -4).&#39;-htm-&#39;.$_SERVER[&#39;QUERY_STRING&#39;];
					$mark = true;
				}
			} else {
				$mark = true;
			}
			if($mark) {
				if(strpos($demo_url, &#39;%&#39;) === false) $demo_url =  rawurlencode($demo_url);
				$demo_url = str_replace(array(&#39;%2F&#39;, &#39;%3A&#39;), array(&#39;/&#39;, &#39;:&#39;), $demo_url);
				if(strpos($demo_url, &#39;-page-&#39;) !== false) {
					$demo_url = preg_replace("/page-([0-9]+)/", &#39;page-{destoon_page}&#39;, $demo_url);
				} else {
					$demo_url = str_replace(&#39;.html&#39;, &#39;-page-{destoon_page}.html&#39;, $demo_url);
				}
			}
			$home_url = str_replace(&#39;-page-{destoon_page}&#39;, &#39;-page-1&#39;, $demo_url);
		} else {
			$DT_URL = str_replace(&#39;&amp;&#39;, &#39;&&#39;, $DT_URL);
			$demo_url = $home_url = preg_replace("/(.*)([&?]page=[0-9]*)(.*)/i", "\\1\\3", $DT_URL);
			$s = strpos($demo_url, &#39;?&#39;) === false ? &#39;?&#39; : &#39;&&#39;;
			$demo_url = $demo_url.$s.&#39;page={des&#39;.&#39;toon_page}&#39;;
		}
	}
	$pages = &#39;&#39;;
	include DT_ROOT.&#39;/api/pages.&#39;.($DT[&#39;pages_mode&#39;] ? &#39;sample&#39; : &#39;default&#39;).&#39;.php&#39;;
	return $pages;
}

function listpages($CAT, $total, $page = 1, $perpage = 20, $step = 2) {
	global $DT, $MOD, $L;
	if($total <= $perpage) return &#39;&#39;;
	$items = $total;
	$total = ceil($total/$perpage);
	if($page < 1 || $page > $total) $page = 1;
	$home_url = $MOD[&#39;linkurl&#39;].$CAT[&#39;linkurl&#39;];
	$demo_url = $MOD[&#39;linkurl&#39;].listurl($CAT, &#39;{destoon_page}&#39;);
	$pages = &#39;&#39;;
	include DT_ROOT.&#39;/api/pages.&#39;.($DT[&#39;pages_mode&#39;] ? &#39;sample&#39; : &#39;default&#39;).&#39;.php&#39;;
	return $pages;
}

function showpages($item, $total, $page = 1) {
	global $MOD, $L;
	$pages = &#39;&#39;;
	$home_url = $MOD[&#39;linkurl&#39;].itemurl($item);
	$demo_url = $MOD[&#39;linkurl&#39;].itemurl($item, &#39;{destoon_page}&#39;);
	$_page = $page <= 1 ? $total : ($page - 1);
	$url = $_page == 1 ? $home_url : str_replace(&#39;{destoon_page}&#39;, $_page, $demo_url);
	$pages .= &#39;<input type="hidden" id="des&#39;.&#39;toon_previous" value="&#39;.$url.&#39;"/><a href="&#39;.$url.&#39;" title="&#39;.$L[&#39;prev_page&#39;].&#39;"> &#171; </a> &#39;;
	for($_page = 1; $_page <= $total; $_page++) {
		$url = $_page == 1 ? $home_url : str_replace(&#39;{destoon_page}&#39;, $_page, $demo_url);
		$pages .= $page == $_page ? &#39;<strong> &#39;.$_page.&#39; </strong> &#39; : &#39; <a href="&#39;.$url.&#39;"> &#39;.$_page.&#39; </a>  &#39;;
	}
	$_page = $page >= $total ? 1 : $page + 1;
	$url = $_page == 1 ? $home_url : str_replace(&#39;{destoon_page}&#39;, $_page, $demo_url);
	$pages .= &#39;<a href="&#39;.$url.&#39;" title="&#39;.$L[&#39;next_page&#39;].&#39;"> &#187; </a> <input type="hidden" id="des&#39;.&#39;toon_next" value="&#39;.$url.&#39;"/>&#39;;
	return $pages;
}

function linkurl($linkurl, $absurl = 1) {
	global $CFG;
	if($absurl) {
		if(strpos($linkurl, &#39;://&#39;) !== false) return $linkurl;
		return strpos($linkurl, $CFG[&#39;path&#39;]) === 0 ? $CFG[&#39;url&#39;].substr($linkurl, strlen($CFG[&#39;path&#39;])) : $CFG[&#39;url&#39;].$linkurl;
	} else {
		if(strpos($linkurl, &#39;://&#39;) !== false) return strpos($linkurl, $CFG[&#39;url&#39;]) === 0 ? $CFG[&#39;path&#39;].substr($linkurl, strlen($CFG[&#39;url&#39;])) : $linkurl;
		return strpos($linkurl, $CFG[&#39;path&#39;]) === 0 ? $linkurl : $CFG[&#39;path&#39;].$linkurl;
	}
}

function imgurl($imgurl = &#39;&#39;, $absurl = 1) {
	return $imgurl ? $imgurl : DT_SKIN.&#39;image/nopic.gif&#39;;
}

function userurl($username, $qstring = &#39;&#39;, $domain = &#39;&#39;) {
	global $CFG, $DT, $MODULE;
	$URL = &#39;&#39;;
	$subdomain = 0;
	if($CFG[&#39;com_domain&#39;]) $subdomain = substr($CFG[&#39;com_domain&#39;], 0, 1) == &#39;.&#39; ? 1 : 2;
	if($username) {
		if($subdomain || $domain) {
			$URL = $domain ? &#39;http://&#39;.$domain.&#39;/&#39; : ($subdomain == 1 ? &#39;http://&#39;.($DT[&#39;com_www&#39;] ? &#39;www.&#39; : &#39;&#39;).$username.$CFG[&#39;com_domain&#39;].&#39;/&#39; : &#39;http://&#39;.$CFG[&#39;com_domain&#39;].&#39;/&#39;.$username.&#39;/&#39;);
			if($qstring) {
				parse_str($qstring, $q);
				if(isset($q[&#39;file&#39;])) {
					$URL .= $CFG[&#39;com_dir&#39;] ? $q[&#39;file&#39;].&#39;/&#39; : &#39;company/&#39;.$q[&#39;file&#39;].&#39;/&#39;;
					unset($q[&#39;file&#39;]);
				}
				if($q) {
					if($DT[&#39;rewrite&#39;]) {
						foreach($q as $k=>$v) {
							$v = rawurlencode($v);
							$URL .= $k.&#39;-&#39;.$v.&#39;-&#39;;
						}
						$URL = substr($URL, 0, -1).&#39;.shtml&#39;;
					} else {
						$URL .= &#39;index.php?&#39;;
						$i = 0;
						foreach($q as $k=>$v) {
							$v = rawurlencode($v);
							$URL .= ($i++ == 0 ? &#39;&#39; : &#39;&&#39;).$k.&#39;=&#39;.$v;
						}
					}
				}
			}
		} else if($DT[&#39;rewrite&#39;]) {
			$URL = DT_PATH.&#39;com/&#39;.$username.&#39;/&#39;;
			if($qstring) {
				parse_str($qstring, $q);
				if(isset($q[&#39;file&#39;])) {
					$URL .= $CFG[&#39;com_dir&#39;] ? $q[&#39;file&#39;].&#39;/&#39; : &#39;company/&#39;.$q[&#39;file&#39;].&#39;/&#39;;
					unset($q[&#39;file&#39;]);
				}
				if($q) {
					foreach($q as $k=>$v) {
						$v = rawurlencode($v);
						$URL .= $k.&#39;-&#39;.$v.&#39;-&#39;;
					}
					$URL = substr($URL, 0, -1).&#39;.html&#39;;
				}
			}
		} else {
			$URL = DT_PATH.&#39;index.php?homepage=&#39;.$username;
			if($qstring) $URL = $URL.&#39;&&#39;.$qstring;
		}
	} else {
		$URL = linkurl($MODULE[4][&#39;linkurl&#39;], 1).&#39;guest.php&#39;;
	}
	return $URL;
}

function userinfo($username, $cache = &#39;&#39;, $fields = &#39;*&#39;) {
	global $db;
	return $db->get_one("SELECT $fields FROM {$db->pre}member m, {$db->pre}company c WHERE m.userid=c.userid AND m.username=&#39;$username&#39;", $cache);
}

function memberinfo($username, $cache = &#39;&#39;, $fields = &#39;*&#39;) {
	global $db;
	return $db->get_one("SELECT $fields FROM {$db->pre}member WHERE username=&#39;$username&#39;", $cache);
}

function listurl($CAT, $page = 0) {
	global $DT, $MOD, $L;
	include DT_ROOT.&#39;/api/url.inc.php&#39;;
	$catid = $CAT[&#39;catid&#39;];
	$file_ext = $DT[&#39;file_ext&#39;];
	$index = $DT[&#39;index&#39;];
	$catdir = $CAT[&#39;catdir&#39;];
	$catname = file_vname($CAT[&#39;catname&#39;]);
	$prefix = $MOD[&#39;htm_list_prefix&#39;];
	$urlid = $MOD[&#39;list_html&#39;] ? $MOD[&#39;htm_list_urlid&#39;] : $MOD[&#39;php_list_urlid&#39;];
	$ext = $MOD[&#39;list_html&#39;] ? &#39;htm&#39; : &#39;php&#39;;
	isset($urls[$ext][&#39;list&#39;][$urlid]) or $urlid = 0;
	$url = $urls[$ext][&#39;list&#39;][$urlid];
	$url = $page ? $url[&#39;page&#39;] : $url[&#39;index&#39;];
    eval("\$listurl = \"$url\";");
	if(substr($listurl, 0, 1) == &#39;/&#39;) $listurl = substr($listurl, 1);
	return $listurl;
}

function itemurl($item, $page = 0) {
	global $DT, $MOD, $L;
	if($MOD[&#39;show_html&#39;] && $item[&#39;filepath&#39;]) {
		if($page === 0) return $item[&#39;filepath&#39;];
		$ext = file_ext($item[&#39;filepath&#39;]);
		return str_replace(&#39;.&#39;.$ext, &#39;_&#39;.$page.&#39;.&#39;.$ext, $item[&#39;filepath&#39;]);
	}
	include DT_ROOT.&#39;/api/url.inc.php&#39;;
	$file_ext = $DT[&#39;file_ext&#39;];
	$index = $DT[&#39;index&#39;];
	$itemid = $item[&#39;itemid&#39;];
	$title = file_vname($item[&#39;title&#39;]);
	$addtime = $item[&#39;addtime&#39;];
	$catid = $item[&#39;catid&#39;];
	$year = date(&#39;Y&#39;, $addtime);
	$month = date(&#39;m&#39;, $addtime);
	$day = date(&#39;d&#39;, $addtime);
	$prefix = $MOD[&#39;htm_item_prefix&#39;];
	$urlid = $MOD[&#39;show_html&#39;] ? $MOD[&#39;htm_item_urlid&#39;] : $MOD[&#39;php_item_urlid&#39;];
	$ext = $MOD[&#39;show_html&#39;] ? &#39;htm&#39; : &#39;php&#39;;
	$alloc = dalloc($itemid);
	$url = $urls[$ext][&#39;item&#39;][$urlid];
	$url = $page ? $url[&#39;page&#39;] : $url[&#39;index&#39;];
	if(strpos($url, &#39;cat&#39;) !== false && $catid) {
		$cate = get_cat($catid);
		$catdir = $cate[&#39;catdir&#39;];
		$catname = $cate[&#39;catname&#39;];
	}
    eval("\$itemurl = \"$url\";");
	if(substr($itemurl, 0, 1) == &#39;/&#39;) $itemurl = substr($itemurl, 1);
	return $itemurl;
}

function rewrite($url, $encode = 0) {
	global $DT, $CFG;
	if(!$DT[&#39;rewrite&#39;]) return $url;
	if(strpos($url, &#39;.php?&#39;) === false || strpos($url, &#39;=&#39;) === false) return $url;
	$url = str_replace(array(&#39;+&#39;, &#39;-&#39;), array(&#39;%20&#39;, &#39;%20&#39;), $url);
	$url = str_replace(array(&#39;.php?&#39;, &#39;&&#39;, &#39;=&#39;), array(&#39;-htm-&#39;, &#39;-&#39;, &#39;-&#39;), $url).&#39;.html&#39;;
	return $url;
}

function timetodate($time = 0, $type = 6) {
	if(!$time) {global $DT_TIME; $time = $DT_TIME;}
	$types = array(&#39;Y-m-d&#39;, &#39;Y&#39;, &#39;m-d&#39;, &#39;Y-m-d&#39;, &#39;m-d H:i&#39;, &#39;Y-m-d H:i&#39;, &#39;Y-m-d H:i:s&#39;);
	if(isset($types[$type])) $type = $types[$type];
	return date($type, $time);
}

function log_write($message, $type = &#39;php&#39;) {
	global $DT_IP, $DT_TIME, $_username;
	if(!DT_DEBUG) return;
	$DT_IP or $DT_IP = get_env(&#39;ip&#39;);
	$DT_TIME or $DT_TIME = time();
	$user = $_username ? $_username : &#39;guest&#39;;
	$log = "<$type>\n";
	$log .= "\t<time>".date(&#39;Y-m-d H:i:s&#39;, $DT_TIME)."</time>\n";
	$log .= "\t<ip>".$DT_IP."</ip>\n";
	$log .= "\t<user>".$user."</user>\n";
	$log .= "\t<file>".$_SERVER[&#39;SCRIPT_NAME&#39;]."</file>\n";
	$log .= "\t<querystring>".str_replace(&#39;&&#39;, &#39;&amp;&#39;, $_SERVER[&#39;QUERY_STRING&#39;])."</querystring>\n";
	$log .= "\t<message>".$message."\t</message>\n";
	$log .= "</$type>";
	file_put(DT_ROOT.&#39;/file/log/&#39;.date(&#39;Ym&#39;, $DT_TIME).&#39;/&#39;.$type.&#39;-&#39;.date(&#39;Y.m.d H.i.s&#39;, $DT_TIME).&#39;-&#39;.strtolower(random(10)).&#39;.xml&#39;, $log);
}

function load($file) {
	$ext = file_ext($file);
	if($ext == &#39;css&#39;) {
		echo &#39;<link rel="stylesheet" type="text/css" href="&#39;.DT_SKIN.$file.&#39;" />&#39;;
	} else if($ext == &#39;js&#39;) {
		echo &#39;<script type="text/javascript" src="&#39;.DT_PATH.&#39;file/script/&#39;.$file.&#39;"></script>&#39;;
	} else if($ext == &#39;htm&#39;) {
		$file = str_replace(&#39;ad_m&#39;, &#39;ad_t6_m&#39;, $file);
		if(is_file(DT_CACHE.&#39;/htm/&#39;.$file)) {
			$content = file_get(DT_CACHE.&#39;/htm/&#39;.$file);
			if(substr($content, 0, 4) == &#39;<!--&#39;) $content = substr($content, 17);
			echo $content;
		} else {
			echo &#39;&#39;;
		}
	} else if($ext == &#39;lang&#39;) {
		$file = str_replace(&#39;.lang&#39;, &#39;.inc.php&#39;, $file);
		return DT_ROOT.&#39;/lang/&#39;.DT_LANG.&#39;/&#39;.$file;
	}
}

function ad($id, $cid = 0, $kw = &#39;&#39;, $tid = 0) {
	global $cityid;
	if($tid) {
		if($kw) {
			$file = &#39;ad_t&#39;.$tid.&#39;_m&#39;.$id.&#39;_k&#39;.urlencode($kw);
		} else if($cid) {
			$file = &#39;ad_t&#39;.$tid.&#39;_m&#39;.$id.&#39;_c&#39;.$cid;
		} else {
			$file = &#39;ad_t&#39;.$tid.&#39;_m&#39;.$id;
		}
		$a3 = &#39;ad_&#39;.$id.&#39;_d&#39;.$tid.&#39;.htm&#39;;
	} else {
		$file = &#39;ad_&#39;.$id;
		$a3 = &#39;ad_&#39;.$id.&#39;_d0.htm&#39;;
	}
	$a1 = $file.&#39;_&#39;.$cityid.&#39;.htm&#39;;
	if(is_file(DT_CACHE.&#39;/htm/&#39;.$a1)) return load($a1);
	$a2 = $file.&#39;_0.htm&#39;;
	if(is_file(DT_CACHE.&#39;/htm/&#39;.$a2)) return load($a2);
	if(is_file(DT_CACHE.&#39;/htm/&#39;.$a3)) return load($a3);
}

function lang($str, $arr = array()) {
	if(strpos($str, &#39;->&#39;) !== false) {
		$t = explode(&#39;->&#39;, $str);
		include load($t[0].&#39;.lang&#39;);
		$str = $L[$t[1]];
	}
	if($arr) {
		foreach($arr as $k=>$v) {
			$str = str_replace(&#39;{V&#39;.$k.&#39;}&#39;, $v, $str);
		}
	}
	return $str;
}

function check_name($username) {
	if(strpos($username, &#39;__&#39;) !== false || strpos($username, &#39;--&#39;) !== false) return false; 
	return preg_match("/^[a-z0-9]{1}[a-z0-9_\-]{0,}[a-z0-9]{1}$/", $username);
}

function check_post() {
	if(strtoupper($_SERVER[&#39;REQUEST_METHOD&#39;]) != &#39;POST&#39;) return false;
	return check_referer();
}

function check_referer() {
	global $DT_REF, $CFG, $DT;
	if($DT[&#39;check_referer&#39;]) {
		if(!$DT_REF) return false;
		$R = parse_url($DT_REF);
		if($CFG[&#39;cookie_domain&#39;] && strpos($R[&#39;host&#39;], $CFG[&#39;cookie_domain&#39;]) !== false) return true;
		if($CFG[&#39;com_domain&#39;] && strpos($R[&#39;host&#39;], $CFG[&#39;com_domain&#39;]) !== false) return true;
		if($DT[&#39;safe_domain&#39;]) {
			$tmp = explode(&#39;|&#39;, $DT[&#39;safe_domain&#39;]);
			foreach($tmp as $v) {
				if(strpos($R[&#39;host&#39;], $v) !== false) return true;
			}
		}		
		$U = parse_url(DT_PATH);
		if(strpos($R[&#39;host&#39;], str_replace(&#39;www.&#39;, &#39;.&#39;, $U[&#39;host&#39;])) !== false) return true;
		return false;
	} else {
		return true;
	}
}

function is_robot() {
	if(strpos($_SERVER[&#39;HTTP_USER_AGENT&#39;], &#39;://&#39;) === false && preg_match("/(MSIE|Netscape|Opera|Konqueror|Mozilla)/i", $_SERVER[&#39;HTTP_USER_AGENT&#39;])) {
		return false;
	} else if(preg_match("/(Spider|Bot|Crawl|Slurp|lycos|robozilla)/i", $_SERVER[&#39;HTTP_USER_AGENT&#39;])) {
		return true;
	} else {
		return false;
	}
}

function is_ip($ip) {
	return preg_match("/^([0-9]{1,3}\.){3}[0-9]{1,3}$/", $ip);
}

function is_md5($password) {
	return preg_match("/^[a-z0-9]{32}$/", $password);
}

function debug() {
	global $db, $debug_starttime;
	$mtime = explode(&#39; &#39;, microtime());
	$s = number_format(($mtime[1] + $mtime[0] - $debug_starttime), 3);
	echo &#39;Processed in &#39;.$s.&#39; second(s), &#39;.$db->querynum.&#39; queries&#39;;
    if(function_exists(&#39;memory_get_usage&#39;)) echo &#39;, Memory &#39;.round(memory_get_usage()/1024/1024, 2).&#39; M&#39;;
}

//For 3.x
function extendurl($func) {
	global $MODULE, $EXT;
	$key = $func.&#39;_url&#39;;
	return $EXT[$key] ? $EXT[$key] : $MODULE[1][&#39;linkurl&#39;].$func.&#39;/&#39;;
}

function extend_setting($key = &#39;&#39;) {
	global $EXT;
	return $key ? $EXT[$key] : $EXT;
}
?>

                   

                   

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

PhpStorm Mac バージョン

PhpStorm Mac バージョン

最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

AtomエディタMac版ダウンロード

AtomエディタMac版ダウンロード

最も人気のあるオープンソースエディター

WebStorm Mac版

WebStorm Mac版

便利なJavaScript開発ツール

SecLists

SecLists

SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません