$val) { $string[$key] = daddslashes($val); } } else { $string = addslashes($string); } return $string; } function authcode($string, $operation = 'DECODE', $key = '', $expiry = 0) { $ckey_length = 4; $key = md5($key ? $key : ENCRYPT_KEY); $keya = md5(substr($key, 0, 16)); $keyb = md5(substr($key, 16, 16)); $keyc = $ckey_length ? ($operation == 'DECODE' ? substr($string, 0, $ckey_length) : substr(md5(microtime()) , -$ckey_length)) : ''; $cryptkey = $keya . md5($keya . $keyc); $key_length = strlen($cryptkey); $string = $operation == 'DECODE' ? base64_decode(substr($string, $ckey_length)) : sprintf('%010d', $expiry ? $expiry + time() : 0) . substr(md5($string . $keyb) , 0, 16) . $string; $string_length = strlen($string); $result = ''; $box = range(0, 255); $rndkey = array(); for ($i = 0; $i <= 255; $i++) { $rndkey[$i] = ord($cryptkey[$i % $key_length]); } for ($j = $i = 0; $i < 256; $i++) { $j = ($j + $box[$i] + $rndkey[$i]) % 256; $tmp = $box[$i]; $box[$i] = $box[$j]; $box[$j] = $tmp; } for ($a = $j = $i = 0; $i < $string_length; $i++) { $a = ($a + 1) % 256; $j = ($j + $box[$a]) % 256; $tmp = $box[$a]; $box[$a] = $box[$j]; $box[$j] = $tmp; $result.= chr(ord($string[$i]) ^ ($box[($box[$a] + $box[$j]) % 256])); } if ($operation == 'DECODE') { if ((substr($result, 0, 10) == 0 || substr($result, 0, 10) - time() > 0) && substr($result, 10, 16) == substr(md5(substr($result, 26) . $keyb) , 0, 16)) { return substr($result, 26); } else { return ''; } } else { return $keyc . str_replace('=', '', base64_encode($result)); } } //CDN function cdnpublic($cdnpublic) { if(empty($cdnpublic)) { return '.'; } else { return $cdnpublic.$conf['version']; } } //获取协议和域名 function siteurl() { $protocol = (!empty($_SERVER['HTTPS']) && $_SERVER['HTTPS'] !== 'off' || $_SERVER['SERVER_PORT'] == 443) ? "https://" : "http://"; $domainName = $_SERVER['HTTP_HOST']; return $protocol . $domainName; } $background = $conf["background"]; //网站背景 function background() { return $GLOBALS['background_img']; } //程序更新 function update() { $update_host = 'cdn.lylme.com'; //程序更新服务器,请勿删除和修改,否则将导致无法接收版本更新和程序报错 @$update = json_decode(file_get_contents('https://' . $update_host . '/lylmes_page/update.json') , true); return $update; } function getver($ver) { $vn = explode('.', str_replace('v', '', $ver)); return $vn[0] . sprintf("%02d", $vn[1]) . sprintf("%02d", $vn[2]); } //更新设置 function saveSetting($k, $v) { global $DB; $v = daddslashes($v); return $DB->query("UPDATE `lylme_config` SET `v` = '$v' WHERE `lylme_config`.`k` = '$k';"); } //获取相对路径 function get_urlpath($srcurl,$baseurl) { if(empty($srcurl))return ''; $srcinfo = parse_url($srcurl); if(isset($srcinfo['scheme'])) { return $srcurl; } $baseinfo = parse_url($baseurl); $url = $baseinfo['scheme'].'://'.$baseinfo['host']; if(substr($srcinfo['path'], 0, 1) == '/') { $path = $srcinfo['path']; } else { $path = dirname($baseinfo['path']).'/'.$srcinfo['path']; } $rst = array(); $path_array = explode('/', $path); if(!$path_array[0]) { $rst[] = ''; } foreach ($path_array AS $key => $dir) { if ($dir == '..') { if (end($rst) == '..') { $rst[] = '..'; } elseif(!array_pop($rst)) { $rst[] = '..'; } } elseif($dir && $dir != '.') { $rst[] = $dir; } } if(!end($path_array)) { $rst[] = ''; } $url .= implode('/', $rst); if( !empty($srcinfo['query']) ) $url .= '?'.$srcinfo['query']; return str_replace('\\', '/', $url); } //获取客户端IP function get_real_ip() { $ip=FALSE; //客户端IP 或 NONE if(!empty($_SERVER["HTTP_CLIENT_IP"])) { $ip = $_SERVER["HTTP_CLIENT_IP"]; } //多重代理服务器下的客户端真实IP地址(可能伪造),如果没有使用代理,此字段为空 if (!empty($_SERVER['HTTP_X_FORWARDED_FOR'])) { $ips = explode (", ", $_SERVER['HTTP_X_FORWARDED_FOR']); if ($ip) { array_unshift($ips, $ip); $ip = FALSE; } for ($i = 0; $i < count($ips); $i++) { if (!eregi ("^(10│172.16│192.168).", $ips[$i])) { $ip = $ips[$i]; break; } } } //客户端IP 或 (最后一个)代理服务器 IP return ($ip ? $ip : $_SERVER['REMOTE_ADDR']); } function yan(){ $filename = ROOT.'/assets/data/data.dat'; //随机一言文件路径 if (file_exists($filename)) { $data = explode(PHP_EOL, file_get_contents($filename)); $result = str_replace(array( "\r", "\n", "\r\n" ) , '', $data[array_rand($data) ]); return $result; } } function rearr($data,$arr){ $arr = str_replace('{group_id}', $data['group_id'],$arr); $arr = str_replace('{group_name}', $data['group_name'],$arr); $arr = str_replace('{group_icon}', $data['group_icon'],$arr); $arr = str_replace('{link_id}', $data['id'],$arr); $arr = str_replace('{link_name}', $data['name'],$arr); $arr = str_replace('{link_url}', $data['url'],$arr); if (empty($data["icon"])) { $icon = '' . $data['; } else if (!preg_match("/^'; } else { $icon = $data["icon"]; } $arr = str_replace('{link_icon}', $icon,$arr); return $arr; } //获取head function get_head($url) { ini_set("user_agent","Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/101.0.4951.54 Safari/537.36 Edg/101.0.1210.39 Lylme/11.24"); $opts = array( 'http'=>array( 'method'=>"GET", 'timeout'=>4 ) ); $contents = @file_get_contents("compress.zlib://".$url, false, stream_context_create($opts)); preg_match('/(.*?)<\/title>/is',$contents,$title); // 获取网站标题 preg_match('/<link rel=".*?icon" * href="(.*?)".*?>/is', $contents,$icon); // 获取网站icon preg_match('/<meta.+?charset=[^\w]?([-\w]+)/i', $contents,$charset); //获取网站编码 $get_heads = array(); $get_heads['charset']=$charset[1]; $get_heads['title'] = str_replace("'","\"",preg_replace("/\s/","",$title[1])); $get_heads['icon'] = get_urlpath(preg_replace("/\s/","",$icon[1]),$url); if(strtolower($get_heads['charset'])!="uft-8"){ // 将非UTF-8编码转换 $get_heads['title'] = iconv($get_heads['charset'], "UTF-8",$get_heads['title']); $get_heads['icon'] = iconv($get_heads['charset'], "UTF-8",$get_heads['icon']); } return $get_heads; if(empty($get_heads['title'])&&empty($get_heads['icon']))exit('Unable to access'); return $get_heads; } //长度判断 function strlens($str) { if(strlen($str) > 255) { return true; } else { return false; } } //apply($name, $url, $icon, $group_id); function apply($name, $url, $icon, $group_id, $status){ $name=strip_tags(daddslashes($name)); $url=strip_tags(daddslashes($url)); $icon=strip_tags(daddslashes($icon)); $group_id=strip_tags(daddslashes($group_id)); $userip = get_real_ip(); $date = date("Y-m-d H:i:s"); if(empty($name) || empty($url) || empty($group_id)) { //|| empty($icon) return('{"code": "-1", "msg": "必填项不能为空"}'); } else if(!preg_match('/^http*/i', $url)) { return('{"code": "-2", "msg": "链接不符合要求"}'); } else if(strlens($name)||strlens($url)||strlens($icon)||strlens($group_id)||strlens($userip)) { return('{"code": "500", "msg": "非法参数"}'); } else { global $DB; if($DB->num_rows($DB->query("SELECT * FROM `lylme_apply` WHERE `apply_url` LIKE '".$url."';"))>0) { return('{"code": "-3", "msg": "链接已存在,请勿重复提交"}'); } $sql = "INSERT INTO `lylme_apply` (`apply_id`, `apply_name`, `apply_url`, `apply_group`, `apply_icon`, `apply_mail`, `apply_time`, `apply_status`) VALUES (NULL, '".$name."', '".$url."', '".$group_id."', '".$icon."', '".$userip."', '".$date."', '".$status."');"; if($DB->query($sql)) { switch ($status) { case 0: return('{"code": "200", "msg": "请等待管理员审核"}'); break; case 1: if(ins_link($name, $url, $icon, $group_id, $status,$userip)){ return('{"code": "200", "msg": "网站已收录"}'); } else{ return('{"code": "-5", "msg": "请联系网站管理员"}'); } break; } } else { return('{"code": "-4", "msg": "未知错误,请联系网站管理员"}'); } } } function ins_link($name, $url, $icon, $group_id, $status){ global $DB; $name=strip_tags(daddslashes($name)); $url=strip_tags(daddslashes($url)); $icon=strip_tags(daddslashes($icon)); $group_id=strip_tags(daddslashes($group_id)); $userip = get_real_ip(); $date = date("Y-m-d H:i:s"); $link_order = $DB->count('select MAX(id) from `lylme_links`')+1; $sql1 = "INSERT INTO `lylme_links` (`id`, `name`, `group_id`, `url`, `icon`, `PS`,`link_order`) VALUES (NULL, '" . $name . "', '" . $group_id . "', '" . $url . "', '" . $icon . "', '" . $userip . "的提交 ', '" . $link_order . "');"; if($DB->query($sql1)) { return true; } else { return false; } } ?>