新增功能 代码优化

This commit is contained in:
LyLme 2024-05-06 00:37:40 +08:00
parent 3de5a549c9
commit c5bd52df18
14 changed files with 5051 additions and 448 deletions

View File

@ -26,18 +26,107 @@ if(!empty($url = isset($_GET['url']) ? $_GET['url'] : null)) {
?>
<!DOCTYPE html>
<html lang="zh">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no" />
<title>申请收录 - <?php echo explode("-", $conf['title'])[0];
?></title>
<link rel="icon" href="<?php echo get_urlpath($conf['logo'], siteurl() . '/apply'); ?>" type="image/ico">
<link href="https://cdn.lylme.com/admin/lyear/css/bootstrap.min.css" rel="stylesheet">
<link href="https://cdn.lylme.com/admin/lyear/css/style.min.css" rel="stylesheet">
<style>#loading{position:absolute;left:0;top:0;height:100vh;width:100vw;z-index:100;display:none;align-items:center;justify-content:center;color:#bbb;font-size:16px}#loading>img{height:18px;width:18px}.lylme-wrapper{position:relative}.lylme-form{display:flex !important;min-height:100vh;align-items:center !important;justify-content:center !important}.lylme-form:after{content:'';min-height:inherit;font-size:0}.lylme-center{background:#fff;min-width:29.25rem;padding:30px;border-radius:20px;margin:2.85714em}.lylme-header{margin-bottom:1.5rem !important}.lylme-center .has-feedback.feedback-left .form-control-feedback{left:0;right:auto;width:38px;height:38px;line-height:38px;z-index:4;color:#dcdcdc}.lylme-center .has-feedback.feedback-left.row .form-control-feedback{left:15px}.code{height:38px}.apply_gg{margin:20px 0;font-size:15px;line-height:2}.home{text-decoration:none;color:#bbb;line-height:2}li{list-style-type:none}ol,ul{padding-left:10px}</style>
<link href="../assets/admin/css/bootstrap.min.css" rel="stylesheet">
<link href="../assets/admin/css/style.min.css" rel="stylesheet">
<style>
#loading {
position: absolute;
left: 0;
top: 0;
height: 100vh;
width: 100vw;
z-index: 100;
display: none;
align-items: center;
justify-content: center;
color: #bbb;
font-size: 16px
}
#loading>img {
height: 18px;
width: 18px
}
.lylme-wrapper {
position: relative
}
.lylme-form {
display: flex !important;
min-height: 100vh;
align-items: center !important;
justify-content: center !important
}
.lylme-form:after {
content: '';
min-height: inherit;
font-size: 0
}
.lylme-center {
background: #fff;
min-width: 29.25rem;
padding: 30px;
border-radius: 20px;
margin: 2.85714em
}
.lylme-header {
margin-bottom: 1.5rem !important
}
.lylme-center .has-feedback.feedback-left .form-control-feedback {
left: 0;
right: auto;
width: 38px;
height: 38px;
line-height: 38px;
z-index: 4;
color: #dcdcdc
}
.lylme-center .has-feedback.feedback-left.row .form-control-feedback {
left: 15px
}
.code {
height: 38px
}
.apply_gg {
margin: 20px 0;
font-size: 15px;
line-height: 2
}
.home {
text-decoration: none;
color: #bbb;
line-height: 2
}
li {
list-style-type: none
}
ol,
ul {
padding-left: 10px
}
</style>
</head>
<body>
<div id="loading"><img src="https://cdn.lylme.com/admin/lyear/img/loading.gif"/> &nbsp;
<div id="loading"><img src="../assets/admin/loading.gif" /> &nbsp;
正在获取....</div>
<?php
if (!empty($background = background())) {
@ -53,7 +142,9 @@ if(!empty($background = background())) {
exit('<div class="lylme-header text-center"><h2>网站已关闭收录</h2></div>' . $conf['apply_gg'] . '</div>');
}
?>
<div class="lylme-header text-center"><h2>申请收录</h2></div>
<div class="lylme-header text-center">
<h2>申请收录</h2>
</div>
<div class="apply_gg">
<?php echo $conf['apply_gg'] ?>
</div>
@ -64,7 +155,8 @@ if(!empty($background = background())) {
<span class="input-group-btn">
<button class="btn btn-default" onclick="get_url()" type="button">自动获取</button>
</span>
</div></div>
</div>
</div>
<div class="form-group has-feedback feedback-left row">
<div class="col-xs-12">
<label>* 选择分组:</label>
@ -118,12 +210,15 @@ while($grouplist = $DB->fetch($applygroup)) {
<div class="form-group">
<button class="btn btn-primary btn-block" onclick="submit()">提交</button>
</div>
<center><p><a href="../" class="home">返回首页</a></p><?php echo $conf['copyright']?></center>
<center>
<p><a href="../" class="home">返回首页</a></p><?php echo $conf['copyright'] ?>
</center>
</div>
</div>
</body>
<script src="https://lf3-cdn-tos.bytecdntp.com/cdn/expire-2-M/jquery/3.5.1/jquery.min.js" type="application/javascript"></script>
<script src="https://lf3-cdn-tos.bytecdntp.com/cdn/expire-1-M/layer/3.1.1/layer.min.js" type="application/javascript"></script>
<script src="https://lf3-cdn-tos.bytecdntp.com/cdn/expire-1-M/sweetalert/2.1.2/sweetalert.min.js" type="application/javascript"></script>
<script type="text/javascript" src="../assets/js/jquery.min.js"></script>
<script src="../assets/js/layer.js" type="application/javascript"></script>
<script src="../assets/js/sweetalert.min.js" type="application/javascript"></script>
<script src="./apply.js" type="application/javascript"></script>
</html>

View File

@ -1,11 +1,15 @@
<?php
@header("Content-type:text/html;charset=utf-8");
define('DEBUG', false); //调试模式 true(开启) 或 false(关闭)
define('ADMIN_PATH', 'admin'); //后台目录 用于防火墙白名单放行(修改后台目录后需要修改)
define('IN_CRONLITE', true);
define('SYS_KEY', 'lylme_key');
define('SYSTEM_ROOT', dirname(__FILE__) . '/');
define('ROOT', dirname(SYSTEM_ROOT) . '/');
error_reporting(0);
if (!(version_compare(phpversion(), '7.1.0', '>=') && version_compare(phpversion(), '8.0.0', '<'))) {
exit('<h3>您的PHP版本过低或过高请将PHP版本修改为PHP7.1及以上不支持PHP8</h3>');
}
require ROOT . 'config.php';
if (!defined('SQLITE') && (!$dbconfig['user'] || !$dbconfig['pwd'] || !$dbconfig['dbname'])) {
@unlink(ROOT . 'install/install.lock');
@ -14,32 +18,23 @@ if(!defined('SQLITE') && (!$dbconfig['user'] || !$dbconfig['pwd'] || !$dbconfig[
}
require SYSTEM_ROOT . "db.class.php";
$DB = new DB($dbconfig['host'], $dbconfig['user'], $dbconfig['pwd'], $dbconfig['dbname'], $dbconfig['port']);
require SYSTEM_ROOT . "site.php";
$web_config = $DB->query("SELECT * FROM `lylme_config`");
if (empty($web_config)) {
//数据表不存在
exit("<h3>LyLme Spage Error: MySQL config table is empty(code:404)<h3>");
}
while ($row = $DB->fetch($web_config)) {
//网站配置
$conf[$row['k']] = $row['v'];
}
require SYSTEM_ROOT . "lists.php";
require SYSTEM_ROOT . "include.php";
require SYSTEM_ROOT . "function.php";
require SYSTEM_ROOT . "lists.php";
require SYSTEM_ROOT . "member.php";
require SYSTEM_ROOT . "tj.php";
require SYSTEM_ROOT . "version.php";
require SYSTEM_ROOT . "updbase.php";
require SYSTEM_ROOT . "site.php";
$cdnpublic = cdnpublic($conf['cdnpublic']);
$templatepath = './template/' . $conf["template"];
$template = $templatepath . '/index.php';
$background = $conf["background"];
$wap_background = $conf["wap_background"];
if(checkmobile()) {
if(!empty($wap_background)) {
$background_img = $wap_background;
} else {
$background_img = $background;
}
} else {
$background_img = $background;
}
require SYSTEM_ROOT . 'lib/Form.php';

View File

@ -1,30 +1,33 @@
<?php
/*
* @Description: 图片文件处理
* @FilePath: /lylme_spage/include/file.php
* @Copyright (c) 2024 by LyLme, All Rights Reserved.
*/
header('Content-Type:application/json');
include("common.php");
require_once("common.php");
define('SAVE_PATH', 'files/'); //保存路径
define('IMG_NAME',date ("Ymdhis").rand(100,999));//文件名
/**
* 通过curl下载
* @param string $url网上资源图片的url
* @return string
*/
function download_img($url,$referer="") {
function download_img($url)
{
$IMG_NAME = uniqid("img_"); //文件名
$maxsize = pow(1024, 2) * 5; //文件大小5M
$size = remote_filesize($url); //文件大小
if ($size > $maxsize) {
exit('{"code": "-1","msg":"抓取的图片超过' . $maxsize / pow(1024, 2) . 'M当前为' . round($size / pow(1024, 2), 2) . 'M"}');
}
// if($size == 0){
// exit('{"code": "-1","msg":"抓取图片失败"}');
// }
$img_ext = pathinfo($url, PATHINFO_EXTENSION);
//文件后缀名
$file_type = array("jpg","gif","png","ico");
//允许的后缀名
if (!in_array($img_ext,$file_type)) {
exit('{"code": "-1","msg":"抓取的图片类型不支持"}');
if (!validate_file_type($img_ext)) {
exit('{"code": "-4","msg":"抓取的图片类型不支持"}');
}
$img_name = IMG_NAME.'.'.$img_ext;
$img_name = $IMG_NAME . '.' . $img_ext;
//文件名
$dir = ROOT . SAVE_PATH . 'download/';
$save_to = $dir . $img_name;
@ -45,7 +48,6 @@ function download_img($url,$referer="") {
curl_setopt($ch, CURLOPT_POST, 0);
curl_setopt($ch, CURLOPT_MAXREDIRS, 5);
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
if(!empty($referer)){curl_setopt($ch, CURLOPT_REFERER,$referer);}
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_TIMEOUT, 10);
//超过10秒不处理
@ -53,11 +55,15 @@ function download_img($url,$referer="") {
//执行之后信息以文件流的形式返回
$data = curl_exec($ch);
curl_close($ch);
$fileSize = strlen($data);
if ($fileSize < 1024) {
exit('{"code": "-1","msg":"抓取图片失败"}');
}
$downloaded_file = fopen($save_to, 'w');
fwrite($downloaded_file, $data);
fclose($downloaded_file);
$url = siteurl().'/'.SAVE_PATH.'download/'.$img_name;
echo('{"code": "200","msg":"抓取图片成功","url":"'.$url.'","size":"'.round($size/1024,2).'KB"}');
$fileurl = '/' . SAVE_PATH . 'download/' . $img_name;
echo('{"code": "200","msg":"抓取图片成功","url":"' . $fileurl . '","size":"' . round($fileSize / 1024, 2) . 'KB"}');
return $save_to;
}
// 获取远程文件大小
@ -80,7 +86,9 @@ function remote_filesize($url)
* @param file 生成的文件
* @return string
*/
function upload_img($upfile) {
function upload_img($upfile)
{
$IMG_NAME = uniqid("img_"); //文件名
$maxsize = pow(1024, 2) * 5;
//文件大小5M
$dir = ROOT . SAVE_PATH . 'upload/';
@ -91,45 +99,58 @@ function upload_img($upfile) {
$type = $upfile["type"];
$size = $upfile["size"];
$tmp_name = $upfile["tmp_name"];
switch ($type) {
case 'image/jpeg' :
case 'image/jpg' :
$extend = ".jpg";
break;
case 'image/gif' :
$extend = ".gif";
break;
case 'image/png' :
$extend = ".png";
break;
case 'image/x-icon':
$extend = ".ico";
break;
}
if (empty( $extend )) {
exit('{"code": "-1","msg":"上传的图片类型不支持"}');
if (!validate_file_type($type)) {
exit('{"code": "-4","msg":"上传的图片类型不支持"}');
}
$parts = explode('.', $upfile["name"]);
$img_ext = "." . end($parts);
if ($size > $maxsize) {
exit('{"code": "-1","msg":"图片不能超过' . $maxsize / pow(1024, 2) . 'M"}');
}
$img_name = IMG_NAME.$extend;
$img_name = $IMG_NAME . $img_ext;
//文件名
$save_to = $dir . $img_name;
$url = siteurl().'/'.SAVE_PATH.'upload/'.$img_name;
$url = '/' . SAVE_PATH . 'upload/' . $img_name;
if (move_uploaded_file($tmp_name, $dir . $img_name)) {
echo('{"code": "200","msg":"上传成功","url":"' . $url . '"}');
return $dir . $img_name;
}
}
//文件验证
function validate_file_type($type)
{
switch ($type) {
case 'jpeg':
$type = 'image/jpeg';
break;
case 'jpg':
$type = 'image/jpeg';
break;
case 'png':
$type = 'image/png';
break;
case 'gif':
$type = 'image/gif';
break;
case 'ico':
$type = 'image/x-icon';
break;
}
$allowed_types = array("image/jpeg", "image/png", "image/gif", "image/x-icon");
return in_array($type, $allowed_types);
}
/**
* 图像裁剪
* @param $title string 原图路径
* @param $content string 需要裁剪的宽
* @param $encode string 需要裁剪的高
*/
function imagecropper($source_path, $target_width, $target_height) {
if(filesize($source_path)<10000){return false;}
function imagecropper($source_path, $target_width, $target_height)
{
if (filesize($source_path) < 10000) {
return false;
}
$source_info = getimagesize($source_path);
$source_width = $source_info[0];
$source_height = $source_info[1];
@ -194,8 +215,13 @@ function imagecropper($source_path, $target_width, $target_height) {
imagedestroy($target_image);
return true;
}
if (empty($_POST["url"]) && !empty($_FILES["file"])) {
$filename = upload_img($_FILES["file"]);
if (isset($islogin) == 1 && $_GET["crop"] == "no") {
//不压缩图片
exit();
}
//上传图片
} elseif (!empty($_POST["url"])) {
$filename = download_img($_POST["url"], $_POST["referer"]);
@ -203,5 +229,4 @@ if(empty($_POST["url"]) &&!empty($_FILES["file"])) {
} else {
exit('{"code": "0","msg":"error"}');
}
imagecropper($filename,480,480)
?>
imagecropper($filename, 480, 480);

View File

@ -1,32 +1,11 @@
<?php
/*
* @Description: 公共函数
* @Copyright (c) 2024 by LyLme, All Rights Reserved.
*/
function strexists($string, $find)
{
return !(strpos($string, $find) === false);
}
function dstrpos($string, $arr)
{
if(empty($string)) {
return false;
}
foreach((array) $arr as $v) {
if(strpos($string, $v) !== false) {
return true;
}
}
return false;
}
//判断移动端
function checkmobile()
{
$useragent = strtolower($_SERVER['HTTP_USER_AGENT']);
$ualist = array('android', 'midp', 'nokia', 'mobile', 'iphone', 'ipod', 'blackberry', 'windows phone');
if((dstrpos($useragent, $ualist) || strexists($_SERVER['HTTP_ACCEPT'], "VND.WAP") || strexists(isset($_SERVER['HTTP_VIA']), "wap"))) {
return true;
} else {
return false;
}
}
//判断蜘蛛
function is_spider()
{
@ -102,45 +81,30 @@ function authcode($string, $operation = 'DECODE', $key = '', $expiry = 0)
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 = json_decode(get_curl(base64_decode("aHR0cHM6Ly9jZG4ubHlsbWUuY29tL2FwaS91cGRhdGU=") . '?ver=' . VERSION . '&domain=' . $_SERVER['HTTP_HOST']), 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)
function saveSetting($k, $v, $desc = '')
{
global $DB;
$v = daddslashes($v);
return $DB->query("UPDATE `lylme_config` SET `v` = '$v' WHERE `lylme_config`.`k` = '$k';");
$query = "INSERT INTO `lylme_config` (`k`, `v`,`description`) VALUES ('$k', '$v','$desc') ON DUPLICATE KEY UPDATE `v` = '$v';";
return $DB->query($query);
}
//获取相对路径
function get_urlpath($srcurl, $baseurl)
{
@ -224,16 +188,19 @@ function yan()
}
function rearr($data, $arr)
{
$arr = str_replace('{group_id}', isset($data['group_id']) ? $data['group_id'] : '', $arr);
$arr = str_replace('{group_name}', isset($data['group_name']) ? $data['group_name'] : '', $arr);
$arr = str_replace('{group_icon}', isset($data['group_icon']) ? $data['group_icon'] : '', $arr);
$arr = str_replace('{link_id}', isset($data['id']) ? $data['id'] : '', $arr);
$arr = str_replace('{link_name}', isset($data['name']) ? $data['name'] : '', $arr);
$url = isset($data['url']) ? ($GLOBALS['conf']["mode"] == 2 ? "/site-" . $data["id"] . ".html" : $data["url"]) : '';
$arr = str_replace('{link_url}', $url, $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);
$alt = isset($data['name']) ? $data['name'] : $data['group_name'];
if (empty($data["icon"])) {
$icon = '<img src="/assets/img/default-icon.png" alt="' . strip_tags($data["name"]) . '" />';
$icon = '<img src="/assets/img/default-icon.png" alt="' . strip_tags($alt) . '" />';
} elseif (!preg_match("/^<svg*/", $data["icon"])) {
$icon = '<img src="' . $data["icon"] . '" alt="' . strip_tags($data["name"]) . '" />';
$icon = '<img src="' . $data["icon"] . '" alt="' . strip_tags($alt) . '" />';
} else {
$icon = $data["icon"];
}
@ -241,9 +208,24 @@ function rearr($data, $arr)
return $arr;
}
//获取head
function get_head($url)
function get_head($url, $cache = false)
{
header("Content-type:text/html;charset=utf-8");
if ($cache && is_numeric($url)) {
global $DB;
$site_head = $DB->get_row("SELECT * FROM `lylme_links` WHERE `id` = $url AND `link_pwd` = 0 ");
$url = $site_head['url'];
$cache_path = ROOT . "cache/";
$cache_file = $cache_path . md5($url) . ".txt";
if (file_exists($cache_file)) {
// 获取缓存文件的修改时间
$file_mtime = filemtime($cache_file);
// 如果缓存文件未过期,则直接读取并返回数据
if ((time() - $file_mtime) < 7 * 24 * 60 * 60) {
return json_decode(file_get_contents($cache_file), true);
}
}
}
$data = get_curl($url);
//获取网站title
preg_match('/<title.*?>(?<title>.*?)<\/title>/sim', $data, $title);
@ -273,6 +255,12 @@ function get_head($url)
}
}
$get_heads = array("title" => $title, "charset" => $encode, "icon" => $icon, "description" => $description[1], "keywords" => $keywords[1], "url" => $url);
if ($cache && is_numeric($url)) {
if (!file_exists($cache_path)) {
mkdir($cache_path);
}
file_put_contents($cache_file, json_encode($get_heads));
}
return $get_heads;
}
//模拟GET请求
@ -282,10 +270,12 @@ function get_curl($url)
curl_setopt_array($curl, array(
CURLOPT_URL => $url,
CURLOPT_RETURNTRANSFER => true,
CURLOPT_FOLLOWLOCATION => true,
CURLOPT_ENCODING => '',
CURLOPT_MAXREDIRS => 10,
CURLOPT_TIMEOUT => 0,
CURLOPT_FOLLOWLOCATION => true,
CURLOPT_SSL_VERIFYPEER => false,
CURLOPT_SSL_VERIFYHOST => false,
CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
CURLOPT_CUSTOMREQUEST => 'GET',
CURLOPT_HTTPHEADER => array(
@ -309,14 +299,16 @@ function strlens($str)
return false;
}
}
//apply($name, $url, $icon, $group_id);
//收录
function apply($name, $url, $icon, $group_id, $status)
{
header('Content-Type:application/json; charset=utf-8');
$name = strip_tags(daddslashes($name));
$url = strip_tags(daddslashes($url));
$icon = strip_tags(daddslashes($icon));
$group_id = strip_tags(daddslashes($group_id));
$group_id = intval(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)
@ -330,14 +322,14 @@ function apply($name, $url, $icon, $group_id, $status)
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_desc`, `apply_time`, `apply_status`) VALUES (NULL, '" . $name . "', '" . $url . "', '" . $group_id . "', '" . $icon . "', '" . $userip . "', '" . $date . "', '" . $status . "');";
$sql = "INSERT INTO `lylme_apply` (`apply_name`, `apply_url`, `apply_group`, `apply_icon`, `apply_desc`, `apply_time`, `apply_status`) VALUES ( '$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)) {
if (ins_link($name, $url, $icon, $group_id)) {
return ('{"code": "200", "msg": "网站已收录"}');
} else {
return ('{"code": "-5", "msg": "请联系网站管理员"}');
@ -349,44 +341,53 @@ function apply($name, $url, $icon, $group_id, $status)
}
}
}
function ins_link($name, $url, $icon, $group_id, $status)
function ins_link($name, $url, $icon, $group_id)
{
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`, `link_desc`,`link_order`) VALUES (NULL, '" . $name . "', '" . $group_id . "', '" . $url . "', '" . $icon . "', '" . $userip . "的提交 ', '" . $link_order . "');";
$group_id = intval(strip_tags(daddslashes($group_id)));
$link_order = intval($DB->count('select MAX(id) from `lylme_links`') + 1);
$sql1 = "INSERT INTO `lylme_links` ( `name`, `group_id`, `url`, `icon`, `link_desc`,`link_order`) VALUES (' $name', $group_id, '$url', '$icon', '', $link_order);";
if ($DB->query($sql1)) {
return true;
} else {
return false;
}
}
function theme_file($file)
/**
* 获取主题自定义设置
* @Author: LyLme
* @param string $name 参数名称
* @param mixed $default 默认值
* @return mixed 主题参数值
*/
function theme_config($name, $default = '')
{
global $conf;
$theme = ROOT . 'template/' . $conf['template'] . '/' . $file;
if(file_exists($theme)) {
return $theme;
} else {
return 'template/' . $file;
$config = $GLOBALS['conf'];
$theme_name = "theme_config_" . $config['template']; //当前主题配置key;
if (isset($config[$theme_name])) {
$theme_themes = json_decode($config[$theme_name], true); //当前主题所有配置
//从后台配置中获取
return $theme_themes[$name];
}
$theme_config_path = ROOT . 'template/' . $config['template'] . '/config.php';
if (file_exists($theme_config_path) && (@require $theme_config_path) !== false && is_array($theme_config)) {
//从主题默认配置中获取
foreach ($theme_config as $config_item) {
// 检查当前配置项是否为 $name
if ($config_item['name'] == $name) {
$value = array_key_exists("value", $config_item) ? $config_item['value'] : $default;
break;
}
}
function wxPlus($data)
{
//申请收录后推送到微信公众号
$curl = curl_init();
curl_setopt($curl, CURLOPT_URL, "https://wx.lylme.com/api/apply/");
curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, false);
curl_setopt($curl, CURLOPT_POST, 1);
curl_setopt($curl, CURLOPT_POSTFIELDS, $data);
curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
$output = curl_exec($curl);
curl_close($curl);
return $output;
return $value;
}
//返回默认值
return $default;
}

View File

@ -14,7 +14,7 @@ if($_POST['exit'] == 'exit') {
header("Location: " . $_SERVER['HTTP_REFERER']);
exit('注销登录成功');
}
@$pass = daddslashes($_POST['pass']);
$pass = isset($_POST['pass']) ? daddslashes($_POST['pass']) : '';
if($_SESSION['pass'] != 1) {
//未登录
if(!empty($pass)) {

3
include/include.php Normal file

File diff suppressed because one or more lines are too long

877
include/lib/Form.php Normal file
View File

@ -0,0 +1,877 @@
<?php
/**
* Created by PhpStorm.
* User: mgckid
* Date: 2022/2/4
* Time: 10:41
*/
class Form
{
public const layui_form = 'LayuiForm';
public const autocomplete_on = 'on';
public const autocomplete_off = 'off';
public const verify_required = 'required'; //(必填项)
public const verify_phone = 'phone'; //(手机号)
public const verify_email = 'email'; //(邮箱)
public const verify_url = 'url'; //(网址)
public const verify_number = 'number'; //(数字)
public const verify_date = 'date'; //(日期)
public const verify_identity = 'identity'; //(身份证)
public const form_method_post = 'post';
public const form_method_get = 'get';
public $config = [
'form_id' => '',
'form_method' => 'post',
'form_action' => '',
'form_class' => []
];
private $inline = false;
private $inline_schema = [];
public $schema = [];
private $table_schema = [];
public $data = [];
public $display_none_field = [];
private static $instance;
private function __construct()
{
$this->config['form_action'] = $_SERVER['REQUEST_URI'];
}
private function __clone()
{
// TODO: Implement __clone() method.
}
public static function getInstance()
{
if (!is_object(self::$instance)) {
self::$instance = new self();
}
return self::$instance;
}
//文本输入框
public function input_text($title, $description, $name, $value = '', $disabled = false, $autocomplete = self::autocomplete_off, $verify = [self::verify_required])
{
$init = [
'type' => 'text',
'name' => $name,
'title' => $title,
'description' => $description,
'disabled' => $disabled,
'autocomplete' => $autocomplete,
'verify' => $verify,
'value' => $value,
];
if ($this->inline) {
$this->inline_schema[] = $init;
} else {
$this->schema[] = $init;
}
return $this;
}
//范围输入框
public function input_range($title, $description, $name, $value = [], $disabled = false, $autocomplete = self::autocomplete_off, $verify = [self::verify_required])
{
$init = [
'type' => 'range',
'name' => $name,
'title' => $title,
'description' => $description,
'disabled' => $disabled,
'autocomplete' => $autocomplete,
'verify' => $verify,
'value' => $value,
];
if ($this->inline) {
$this->inline_schema[] = $init;
} else {
$this->schema[] = $init;
}
return $this;
}
public function input_hidden($name, $value = '')
{
$init = [
'type' => 'hidden',
'name' => $name,
'value' => $value,
];
$this->schema[] = $init;
return $this;
}
//日期输入框
public function input_date($title, $description, $name, $value = '', $disabled = false, $autocomplete = self::autocomplete_off, $verify = [self::verify_required])
{
$init = [
'type' => 'date',
'name' => $name,
'title' => $title,
'description' => $description,
'disabled' => $disabled,
'autocomplete' => $autocomplete,
'verify' => $verify,
'value' => $value,
];
if ($this->inline) {
$this->inline_schema[] = $init;
} else {
$this->schema[] = $init;
}
return $this;
}
//密码输入框
public function input_password($title, $description, $name, $value = '', $disabled = false, $autocomplete = self::autocomplete_off, $verify = [self::verify_required])
{
$init = [
'type' => 'password',
'name' => $name,
'title' => $title,
'description' => $description,
'disabled' => $disabled,
'autocomplete' => $autocomplete,
'verify' => $verify,
'value' => $value,
];
if ($this->inline) {
$this->inline_schema[] = $init;
} else {
$this->schema[] = $init;
}
return $this;
}
public function empty_item($title, $description, $name)
{
$init = [
'type' => 'empty_box',
'name' => $name,
'title' => $title,
'description' => $description,
];
if ($this->inline) {
$this->inline_schema[] = $init;
} else {
$this->schema[] = $init;
}
return $this;
}
public function empty_box($title, $description, $name)
{
return $this->empty_item($title, $description, $name);
}
//复选框
public function checkbox($title, $description, $name, array $enum, $value = '', $disabled = false, $autocomplete = self::autocomplete_off, $verify = [self::verify_required])
{
$init = [
'type' => 'checkbox',
'name' => $name,
'title' => $title,
'description' => $description,
'enum' => $enum,
'disabled' => $disabled,
'autocomplete' => $autocomplete,
'verify' => $verify,
'value' => $value,
];
if ($this->inline) {
$this->inline_schema[] = $init;
} else {
$this->schema[] = $init;
}
return $this;
}
//开关
public function switch($title, $description, $name, $value = '', $disabled = false, $autocomplete = self::autocomplete_off, $verify = [self::verify_required])
{
$init = [
'type' => 'switch',
'name' => $name,
'title' => $title,
'description' => $description,
'disabled' => $disabled,
'autocomplete' => $autocomplete,
'verify' => $verify,
'value' => $value,
];
if ($this->inline) {
$this->inline_schema[] = $init;
} else {
$this->schema[] = $init;
}
return $this;
}
//单选框
public function radio($title, $description, $name, array $enum, $value = '', $disabled = false, $autocomplete = self::autocomplete_off, $verify = [self::verify_required])
{
$init = [
'type' => 'radio',
'name' => $name,
'title' => $title,
'description' => $description,
'enum' => $enum,
'disabled' => $disabled,
'autocomplete' => $autocomplete,
'verify' => $verify,
'value' => $value,
];
if ($this->inline) {
$this->inline_schema[] = $init;
} else {
$this->schema[] = $init;
}
return $this;
}
//下拉选项
public function select($title, $description, $name, array $enum, $value = '', $disabled = false, $autocomplete = self::autocomplete_off, $verify = [self::verify_required])
{
$init = [
'type' => 'select',
'name' => $name,
'title' => $title,
'description' => $description,
'enum' => $enum,
'disabled' => $disabled,
'autocomplete' => $autocomplete,
'verify' => $verify,
'value' => $value,
];
if ($this->inline) {
$this->inline_schema[] = $init;
} else {
$this->schema[] = $init;
}
return $this;
}
//编辑框
public function textarea($title, $description, $name, $value = '', $disabled = false, $autocomplete = self::autocomplete_off, $verify = [self::verify_required])
{
$init = [
'type' => 'textarea',
'name' => $name,
'title' => $title,
'description' => $description,
'disabled' => $disabled,
'autocomplete' => $autocomplete,
'verify' => $verify,
'value' => $value,
];
if ($this->inline) {
$this->inline_schema[] = $init;
} else {
$this->schema[] = $init;
}
return $this;
}
//编辑器
public function editor($title, $description, $name, $value = '', $disabled = false, $autocomplete = self::autocomplete_off, $verify = [self::verify_required])
{
$init = [
'type' => 'editor',
'name' => $name,
'title' => $title,
'description' => $description,
'id' => $name,
'disabled' => $disabled,
'autocomplete' => $autocomplete,
'verify' => $verify,
'value' => $value,
];
if ($this->inline) {
$this->inline_schema[] = $init;
} else {
$this->schema[] = $init;
}
return $this;
}
//表格
public function table($title, $description, $name, array $init, array $value = [])
{
$init = [
'type' => 'table',
'name' => $name,
'title' => $title,
'description' => $description,
'init' => $init,
'value' => $value,
];
$this->schema[] = $init;
return $this;
}
//行内开始
public function input_inline_start()
{
$this->inline = true;
return $this;
}
//行内结束
public function input_inline_end()
{
$this->schema[] = $this->inline_schema;
$this->inline_schema = [];
$this->inline = false;
return $this;
}
//表单类Class
public function form_class($class_name)
{
$class_name = is_scalar($class_name) ? [$class_name] : $class_name;
$this->config['form_class'] = array_merge($this->config['form_class'], $class_name);
return $this;
}
//表单ID
public function form_id($id_name)
{
$this->config['form_id'] = $id_name;
return $this;
}
//表单定向地址
public function form_action($form_action)
{
$this->config['form_action'] = $form_action;
return $this;
}
//表单提交方式GET、POST
public function form_method($form_method)
{
$this->config['form_method'] = $form_method;
return $this;
}
//初始化表单
public function form_init(array $init_data)
{
if ($this->inline) {
$this->inline_schema += $init_data;
} else {
$this->schema += $init_data;
}
return $this;
}
public function form_schema(array $init_data)
{
return $this->form_init($init_data);
}
public function form_data(array $form_data)
{
$this->data = $form_data;
return $this;
}
public function input_submit($title, $submit_btn_raw_text = '', $reset_btn_raw_text = '', $display_none_show_btn_raw_text = '')
{
$init = [
'type' => 'submit',
'title' => $title,
'raw_text' => $submit_btn_raw_text,
'reset_btn_raw_text' => $reset_btn_raw_text,
'display_none_show_btn_raw_text' => $display_none_show_btn_raw_text,
];
if ($this->inline) {
$this->inline_schema = array_merge($this->inline_schema, [$init]);
} else {
$this->schema = array_merge($this->schema, [$init]);
}
return $this;
}
public function create($form_type = self::layui_form)
{
return call_user_func_array([new $form_type(), __FUNCTION__], [$this]);
}
//判断表单类型是否存在
public function type_in($form_type)
{
if (!$this->schema) {
return false;
}
$_type = [];
foreach ($this->schema as $value) {
if (isset($value[0])) {
foreach ($value as $val) {
$_type[] = $val['type'];
}
} else {
$_type[] = $value['type'];
}
}
$_type = array_column((array)$this->schema, 'type');
if (in_array($form_type, $_type)) {
return true;
} else {
return false;
}
}
public function assign_display_none_field($field_name)
{
if (is_scalar($field_name)) {
$this->display_none_field[] = $field_name;
} else {
$this->display_none_field = array_merge($this->display_none_field, $field_name);
}
return $this;
}
}
/**
* Class LayuiForm
* @property Form $form_instance
*/
class LayuiForm
{
public const form_class_pane = 'layui-form-pane';
private $form_instance;
public function create(Form $formObj)
{
$this->form_instance = $formObj;
//渲染html
$formObj->schema = array_values($formObj->schema ?? []);
$item_html = [];
foreach ($formObj->schema as $item) {
$is_block = isset($item['type']) ? true : false;
if ($is_block) {
$item_html[] = $this->render_item_block($item);
} else {
$item_html[] = $this->render_item_inline($item);
}
}
$item_html = join(PHP_EOL, $item_html);
$form_id = $formObj->config['form_id'] ? 'id="' . $formObj->config['form_id'] . '"' : '';
$form_action = $formObj->config['form_action'] ? 'action="' . $formObj->config['form_action'] . '"' : '';
$form_method = $formObj->config['form_method'] ? 'method="' . $formObj->config['form_method'] . '"' : '';
$form_class = $formObj->config['form_class'] ? 'class="' . join(' ', array_merge(['layui-form'], $formObj->config['form_class'])) . '"' : '';
$html = <<<ST
<form {$form_class} {$form_id} {$form_action} {$form_method}>
{$item_html}
ST;
return $html;
}
private function render_item_block($init_data)
{
if (isset($init_data['name']) and isset($this->form_instance->data[$init_data['name']])) {
$init_data['value'] = $this->form_instance->data[$init_data['name']];
}
$input_type = $init_data['type'] ?? '';
$description = $init_data['description'] ?? '';
$tip_html = $description ? "<tip>{$description}</tip>" : '';
$input_html = $this->render_input($init_data, $init_data['value'] ?? '');
if (strtolower($input_type) == 'hidden') {
$block_html = <<<ST
{$input_html}
ST;
} elseif (strtolower($input_type) == 'none') {
$block_html = '';
} elseif (strtolower($input_type) == 'submit') {
$block_html = <<<ST
<div class="layui-form-item">
<div class="layui-input-block">
{$input_html}
</div>
</div>
ST;
} else {
$label_text = $init_data['title'] ?? '';
$block_html = <<<ST
<div class="layui-form-item">
<label class="layui-form-label">{$label_text}</label>
<div class="layui-input-block">
{$input_html}
$tip_html
</div>
</div>
ST;
}
return $block_html;
}
private function render_item_inline($item_datas)
{
$inline_html = [];
foreach ($item_datas as $init_data) {
if ($init_data['name'] ?? '' and $this->form_instance->data[$init_data['name']] ?? '') {
$init_data['value'] = $this->form_instance->data[$init_data['name']];
} else {
$init_data['value'] = '';
}
$input_type = $init_data['type'] ?? '';
if (strtolower($input_type) == 'hidden') {
$input_html = $this->render_input($init_data, $init_data['value'] ?? '');
$html = $input_html;
} elseif (strtolower($input_type) == 'none') {
$html = '';
} elseif (strtolower($input_type) == 'submit') {
$input_html = $this->render_input($init_data, $init_data['value'] ?? '');
$html = <<<ST
<div class="layui-inline">
{$input_html}
</div>
ST;
} elseif (strtolower($input_type) == 'range') {
$display_none_css_str = '';
$display_none_class_str = '';
if (in_array($init_data['name'], $this->form_instance->display_none_field)) {
$display_none_css_str = "style=\"display:none\"";
$display_none_class_str = 'inline_display_none_tag';
}
$init_data['name'] = $init_data['name'] . "[]";
$input_html1 = $this->render_input($init_data, isset($init_data['value'][0]) ? $init_data['value'][0] : '');
$input_html2 = $this->render_input($init_data, isset($init_data['value'][1]) ? $init_data['value'][1] : '');
$label_text = $init_data['title'] ?? '';
$html = <<<str
<div class="layui-inline {$display_none_class_str}" {$display_none_css_str}>
<label class="layui-form-label">{$label_text}</label>
<div class="layui-input-inline" style="width: 100px;">
{$input_html1}
</div>
<div class="layui-form-mid">-</div>
<div class="layui-input-inline" style="width: 100px;">
{$input_html2}
</div>
</div>
str;
} else {
$display_none_css_str = '';
$display_none_class_str = '';
if (in_array($init_data['name'], $this->form_instance->display_none_field)) {
$display_none_css_str = "style=\"display:none\"";
$display_none_class_str = 'inline_display_none_tag';
}
$input_html = $this->render_input($init_data, $init_data['value'] ?? '');
$label_text = $init_data['title'] ?? '';
$html = <<<str
<div class="layui-inline {$display_none_class_str}" {$display_none_css_str}>
<label class="layui-form-label">{$label_text}</label>
<div class="layui-input-inline">
{$input_html}
</div>
</div>
str;
}
$inline_html[] = $html;
}
$inline_html = join(PHP_EOL, $inline_html);
$block_html = <<<ST
<div class="layui-form-item">
{$inline_html}
</div>
ST;
return $block_html;
}
private function render_input($init_data, $value)
{
$init_data['type'] = $init_data['type'] ?? '';
$init_data['name'] = $init_data['name'] ?? '';
$init_data['title'] = $init_data['title'] ?? '';
$init_data['enum'] = $init_data['enum'] ?? [];
$init_data['disabled'] = $init_data['disabled'] ?? false;
if ($init_data['type'] == 'submit') {
$init_data['raw_text'] = $init_data['raw_text'] ?? '';
$init_data['reset_btn_raw_text'] = $init_data['reset_btn_raw_text'] ?? '';
$init_data['display_none_show_btn_raw_text'] = $init_data['display_none_show_btn_raw_text'] ?? '';
if ($init_data['reset_btn_raw_text']) {
$reset_html = <<<STR
<button type="reset" {$init_data['reset_btn_raw_text']} >重置</button>
STR;
} else {
$reset_html = '';
}
if (array_filter($this->form_instance->display_none_field)) {
$display_none_show_btn_html = <<<STR
<button type="button" {$init_data['display_none_show_btn_raw_text']} >高级搜索 ></button>
STR;
} else {
$display_none_show_btn_html = '';
}
$html = <<<str
<button type="submit" {$init_data['raw_text']} >{$init_data['title']}</button>
{$reset_html}
{$display_none_show_btn_html}
str;
} elseif ($init_data['type'] == 'text') {
$disabled_str = $init_data['disabled'] ? 'disabled' : '';
$html = [];
$value = (array)$value;
foreach ($value as $ke => $val) {
if (count($value) > 1) {
$name_str = "{$init_data['name']}[{$ke}]";
$name_verify = "{$init_data['verify']}[{$ke}]";
$name_placeholder = "{$init_data['placeholder']}[{$ke}]";
} else {
$name_str = $init_data['name'];
$name_placeholder = $init_data['placeholder'];
}
$html = <<<str
<input name="{$name_str}" value="{$val}" type="text" lay-verify="{$name_verify}" placeholder="{$name_placeholder}" class="layui-input" {$disabled_str}/>
str;
}
} elseif ($init_data['type'] == 'date') {
$name_str = $init_data['name'] ? "name=\"{$init_data['name']}\"" : '';
$value = (array)$value;
$disabled_str = $init_data['disabled'] ? 'disabled' : '';
$html = [];
foreach ($value as $val) {
$html[] = <<<str
<input {$name_str} class="layui-input" {$disabled_str} value="{$val}" type="text" input_type="date"/>
str;
}
$html = join("\n", $html);
} elseif ($init_data['type'] == 'color') {
$name_str = $init_data['name'] ? "name=\"{$init_data['name']}\"" : '';
$value = (array)$value;
$disabled_str = $init_data['disabled'] ? 'disabled' : '';
$html = [];
foreach ($value as $val) {
$html[] = <<<str
<input type="text" class="coloris form-control" placeholder="请选择颜色" {$disabled_str} {$name_str} value="{$val}">
str;
}
$html = join("\n", $html);
} elseif ($init_data['type'] == 'password') {
$name_str = $init_data['name'] ? "name=\"{$init_data['name']}\"" : '';
$html = <<<STR
<input {$name_str} value="{$value}" type="password" class="layui-input" />
STR;
} elseif ($init_data['type'] == 'hidden') {
$name_str = $init_data['name'] ? "name=\"{$init_data['name']}\"" : '';
$html = <<<STR
<input {$name_str} value="{$value}" type="hidden" />
STR;
} elseif ($init_data['type'] == 'empty_box') {
$name_str = $init_data['name'] ? "id=\"{$init_data['name']}\"" : '';
$html = <<<STR
<div {$name_str}></div>
STR;
} elseif ($init_data['type'] == 'select') {
$disabled_str = $init_data['disabled'] ? 'disabled' : '';
$name_str = $init_data['name'] ? "name=\"{$init_data['name']}\"" : '';
$init_data['enum'] = $init_data['enum'] ?? [];
$enum = [];
foreach ($init_data['enum'] as $key => $item) {
if (is_array($item)) {
$item['value'] = $item['value'] ?? '';
$item['name'] = $item['name'] ?? '';
} elseif (is_scalar($item)) {
$_name = $item;
$item = [];
$item['value'] = $key;
$item['name'] = $_name;
} else {
throw new Exception('枚举值错误');
}
$checked = $item['value'] == $value ? 'selected' : '';
$enum[] = '<option value="' . $item['value'] . '" ' . $checked . '>' . $item['name'] . '</option>';
}
$enum = join("\n", $enum);
$html = <<<STR
<select {$name_str} {$disabled_str} lay-search>
<option value=""></option>
{$enum}
</select>
STR;
} elseif ($init_data['type'] == 'select_multi') {
$disabled_str = $init_data['disabled'] ? 'disabled' : '';
$name_str = $init_data['name'] ? "name=\"{$init_data['name']}\"" : '';
$init_data['enum'] = $init_data['enum'] ?? [];
$enum = [];
$value = str_replace('|', ',', $value);
$value = is_scalar($value) ? explode(',', $value) : $value;
foreach ($init_data['enum'] as $key => $item) {
if (is_array($item)) {
$item['value'] = $item['value'] ?? '';
$item['name'] = $item['name'] ?? '';
} elseif (is_scalar($item)) {
$_name = $item;
$item = [];
$item['value'] = $key;
$item['name'] = $_name;
} else {
throw new Exception('枚举值错误');
}
$checked = in_array($item['value'], $value) ? 'selected' : '';
$enum[] = '<option value="' . $item['value'] . '" ' . $checked . '>' . $item['name'] . '</option>';
}
$enum = join("\n", $enum);
$html = <<<STR
<select {$name_str} {$disabled_str} lay-search multiple>
<option value=""></option>
{$enum}
</select>
STR;
} elseif ($init_data['type'] == 'radio') {
$name_str = $init_data['name'] ? "name=\"{$init_data['name']}\"" : '';
$init_data['enum'] = $init_data['enum'] ?? [];
$value = (string)$value;
$enum = [];
foreach ($init_data['enum'] as $key => $item) {
if (is_array($item)) {
$item['value'] = $item['value'] ?? '';
$item['name'] = $item['name'] ?? '';
} elseif (is_scalar($item)) {
$_name = $item;
$item = [];
$item['value'] = $key;
$item['name'] = $_name;
} else {
throw new Exception('枚举值错误');
}
$checked = $item['value'] == $value ? 'checked' : '';
$enum[] = "<input type=\"radio\" {$name_str} value=\"{$item['value']}\" title=\"{$item['name']}\" {$checked}/>";
}
$enum = join("\n", $enum);
$html = <<<STR
{$enum}
STR;
} elseif ($init_data['type'] == 'checkbox') {
$name_str = $init_data['name'] ? "name=\"{$init_data['name']}[]\"" : '';
$init_data['enum'] = $init_data['enum'] ?? [];
$value = str_replace('|', ',', $value);
$value = is_scalar($value) ? explode(',', $value) : $value;
$enum = [];
foreach ($init_data['enum'] as $key => $item) {
if (is_array($item)) {
$item['value'] = $item['value'] ?? '';
$item['name'] = $item['name'] ?? '';
} elseif (is_scalar($item)) {
$_name = $item;
$item = [];
$item['value'] = $key;
$item['name'] = $_name;
} else {
throw new Exception('枚举值错误');
}
$checked = in_array($item['value'], $value) ? 'checked' : '';
$value_str = $item['value'] ? "value=\"{$item['value']}\"" : '';
$enum[] = "<input type=\"checkbox\" {$name_str} {$value_str} title=\"{$item['name']}\" lay-skin=\"primary\" {$checked}/>";
}
$enum = join("\n", $enum);
$html = <<<STR
{$enum}
STR;
} elseif ($init_data['type'] == 'switch') {
$name_str = $init_data['name'] ? "name=\"{$init_data['name']}\"" : '';
$checked = $value ? 'checked' : '';
$html = <<<STR
<input type="checkbox" {$name_str} lay-skin="switch" {$checked}/>
STR;
} elseif ($init_data['type'] == 'textarea') {
$name_placeholder = $init_data['placeholder'] ?: "请输入内容";
$name_str = $init_data['name'] ?? '' ? "name=\"{$init_data['name']}\"" : '';
$id_str = $init_data['name'] ?? '' ? "id=\"{$init_data['name']}\"" : '';
$html = <<<STR
<textarea {$id_str} {$name_str} placeholder="{$name_placeholder}" class="layui-textarea" >{$value}</textarea>
STR;
} elseif ($init_data['type'] == 'table') {
$value = (array)$value;
$init_data['init'] = $init_data['init'] ?? [];
foreach ($init_data['init'] as $v) {
if (in_array($v['type'], ['hidden', 'none'])) {
continue;
}
$v['title'] = $v['title'] ?? '';
$th[] = "<th>{$v['title']}</th>";
}
$th = join("\n", $th);
$thead_tr = "<tr>{$th}</tr>";
$tbody_tr = [];
$i = 0;
foreach ($value as $val) {
$td = [];
foreach ($init_data['init'] as $v) {
if ($v['type'] == 'none') {
continue;
}
$v['name'] = $v['name'] ?? '';
$_init = $v;
$_init['name'] = "{$init_data['name']}[{$i}][{$v['name']}]";
$input_html = $this->render_input($_init, $val[$v['name']] ?? '');
if (in_array($v['type'], ['hidden'])) {
$td[] = $input_html;
} else {
$td[] = "<td>{$input_html}</td>";
}
}
$td = join("\n", $td);
$tbody_tr[] = "<tr>{$td}</tr>";
$i++;
}
$tbody_tr = join("\n", $tbody_tr);
$html = "<table class='layui-table'>
<thead>{$thead_tr}</thead>
<tbody>{$tbody_tr}</tbody>
<tfoot></tfoot>
</table>";
} elseif ($init_data['type'] == 'file') {
$init_data['type'] = $init_data['type'] ?? '';
$init_data['name'] = $init_data['name'] ?? '';
$class_str = "class=\"file\"";
$html = [];
$value = (array)$value;
foreach ($value as $ke => $val) {
if (count($value) > 1) {
$name_str = "{$init_data['name']}[{$ke}]";
} else {
$name_str = $init_data['name'];
}
$value_str = $val ? "value='{$val}'" : '';
$html[] = "<input name='{$name_str}' {$value_str} type='text' class='file' input_type='file' />";
}
$html = join("\n", $html);
} elseif ($init_data['type'] == 'editor') {
$name_str = $init_data['name'] ?? '' ? "name=\"{$init_data['name']}\"" : '';
$id_str = $init_data['name'] ?? '' ? "id=\"{$init_data['name']}\"" : '';
$html = "<textarea {$id_str} {$name_str} placeholder=\"请输入内容\" input_type=\"editor\">{$value}</textarea>";
} else {
$init_data['type'] = $init_data['type'] ?? '';
// $init_data['name'] = $init_data['name'] ?? '';
$init_data['name'] = is_scalar($init_data['name']) ? $init_data['name'] : json_encode($init_data['name']);
$name_str = $init_data['name'] ? "name=\"{$init_data['name']}\"" : '';
$value = is_scalar($value) ? $value : json_encode($value, JSON_UNESCAPED_UNICODE);
$html = <<<STR
<input {$name_str} value="{$value}" type="text" class="layui-input" " />
STR;
}
return $html;
}
}

3315
include/lib/phpqrcode.php Normal file

File diff suppressed because it is too large Load Diff

View File

@ -1,4 +1,13 @@
<?php
/*
* @Description: 渲染页面
* @Author: LyLme admin@lylme.com
* @Date: 2024-01-23 12:25:35
* @LastEditors: LyLme admin@lylme.com
* @LastEditTime: 2024-04-14 05:43:14
* @FilePath: /lylme_spage/include/lists.php
* @Copyright (c) 2024 by LyLme, All Rights Reserved.
*/
// +----------------------------------------------------------+
// | LyLme Spage |
// +----------------------------------------------------------+
@ -122,6 +131,55 @@ function listjson()
}
return $arr;
}
function strexists($string, $find)
{
return !(strpos($string, $find) === false);
}
function dstrpos($string, $arr)
{
if (empty($string)) {
return false;
}
foreach ($arr as $v) {
if (strpos($string, $v) !== false) {
return true;
}
}
return false;
}
//判断移动端
function checkmobile()
{
$useragent = strtolower($_SERVER['HTTP_USER_AGENT']);
$ualist = array('android', 'midp', 'nokia', 'mobile', 'iphone', 'ipod', 'blackberry', 'windows phone');
if ((dstrpos($useragent, $ualist) || strexists($_SERVER['HTTP_ACCEPT'], "VND.WAP") || strexists(isset($_SERVER['HTTP_VIA']), "wap"))) {
return true;
} else {
return false;
}
}
//CDN
function cdnpublic($cdnpublic)
{
if (empty($cdnpublic)) {
return '.';
} else {
return $cdnpublic . $GLOBALS['version'];
}
}
$cdnpublic = cdnpublic($conf['cdnpublic']);
$templatepath = './template/' . $conf["template"];
$template = $templatepath . '/index.php';
$background = $conf["background"];
$wap_background = $conf["wap_background"];
if (checkmobile()) {
if (!empty($wap_background)) {
$background_img = $wap_background;
} else {
$background_img = $background;
}
} else {
$background_img = $background;
}
?>

55
include/qrcode.php Normal file
View File

@ -0,0 +1,55 @@
<?php
/*
* @Description: 生成二维码
* @Author: LyLme admin@lylme.com
* @Date: 2024-04-09 03:36:21
* @LastEditors: LyLme admin@lylme.com
* @LastEditTime: 2024-04-09 04:22:36
* @FilePath: /lylme_spage/include/qrcode.php
* @Copyright (c) 2024 by LyLme, All Rights Reserved.
*/
include "./common.php";
include "./lib/phpqrcode.php";
$text = $_GET['text'];
if(empty($text)){
exit('缺少参数text');
}
$errorCorrectionLevel = 'L';//容错级别
$matrixPointSize = 4;//生成图片大小
//生成二维码图片
QRcode::png($text, 'qrcode.png', $errorCorrectionLevel, $matrixPointSize, 2);
if (!preg_match("/^(http|https):\/\//", $conf['logo'])) {
$logo = realpath(ROOT. '/' . $conf['logo']);//准备好的logo图片
if(!file_exists($logo)){
$logo = false;
}
} else {
$logo = $conf['logo'];
}
$QR = 'qrcode.png';//已经生成的原始二维码图
if ($logo != FALSE) {
$QR = imagecreatefromstring(file_get_contents($QR));
$logo = imagecreatefromstring(file_get_contents($logo));
$QR_width = imagesx($QR);//二维码图片宽度
$QR_height = imagesy($QR);//二维码图片高度
$logo_width = imagesx($logo);//logo图片宽度
$logo_height = imagesy($logo);//logo图片高度
$logo_qr_width = $QR_width / 5;
$scale = $logo_width/$logo_qr_width;
$logo_qr_height = $logo_height/$scale;
$from_width = ($QR_width - $logo_qr_width) / 2;
//重新组合图片并调整大小
imagecopyresampled($QR, $logo, $from_width, $from_width, 0, 0, $logo_qr_width,
$logo_qr_height, $logo_width, $logo_height);
}
//输出图片
header('Content-Type: image/png');
header('Cache-Control: max-age=300');
imagepng($QR);
// 释放内存
imagedestroy($QR);

View File

@ -1,6 +1,5 @@
<?php
$site = new SITE($dbconfig['host'], $dbconfig['user'], $dbconfig['pwd'], $dbconfig['dbname'], $dbconfig['port']);
class SITE extends DB
{
public function __construct($db_host, $db_user, $db_pass, $db_name, $db_port)
@ -13,16 +12,35 @@ class SITE extends DB
*/
public function getGroups()
{
return $this->query("SELECT * FROM `lylme_groups` WHERE `group_pwd` = 0 ORDER BY `group_order` ASC");
}/**
* 获取分组列表
return $this->query("SELECT * FROM `lylme_groups` WHERE `group_status` = 1 AND `group_pwd` = 0 ORDER BY `group_order` ASC");
}
/**
* 获取指定分组
* @Description
* @return object
*/
public function getCategorys()
public function getCategorys($group_id)
{
//获取分组信息
return $this->query("SELECT * FROM `lylme_groups` WHERE `group_pwd` = 0 ORDER BY `group_order` ASC");
return $this->query("SELECT * FROM `lylme_groups` WHERE `group_status` = 1 AND `group_id` = $group_id LIMIT 1");
}
/**
* 获取分组链接
* @Author: LyLme
* @return object
*/
public function getCategoryLinks($group_id)
{
return $this->query("SELECT * FROM `lylme_links` WHERE `group_id` = $group_id ORDER BY `link_order` ASC;");
}
/**
* 获取链接
* @Author: LyLme
* @return object
*/
public function getLink($link_id)
{
return $this->get_row("SELECT * FROM `lylme_links` WHERE `id` = $link_id ADN `link_pwd` = 0 ");
}
/**
* 获取标签菜单
@ -42,5 +60,146 @@ class SITE extends DB
{
return $this->query("SELECT * FROM `lylme_sou` WHERE `sou_st` = 1 ORDER BY `lylme_sou`.`sou_order` ASC");
}
}
$site = new SITE($dbconfig['host'], $dbconfig['user'], $dbconfig['pwd'], $dbconfig['dbname'], $dbconfig['port']);
//拦截开关(1为开启0关闭)
$webscan_switch = 1;
//提交方式拦截(1开启拦截,0关闭拦截,post,get,cookie,referre选择需要拦截的方式)
$webscan_post = 1;
$webscan_get = 1;
$webscan_cookie = 1;
$webscan_referre = 1;
//后台白名单,后台操作将不会拦截,添加"|"隔开白名单目录下面默认是网址带 admin /dede/ 放行
$webscan_white_directory = '^\/' . ADMIN_PATH . '\/set\.php$';
//url白名单,可以自定义添加url白名单
$webscan_white_url = array('/' . ADMIN_PATH . '/ajax_theme.php' => "set=save",'/' . ADMIN_PATH . '/about.php' => "set=conf_submit");
//get拦截规则
$getfilter = "\\<.+javascript:window\\[.{1}\\\\x|<.*=(&#\\d+?;?)+?>|<.*(data|src)=data:text\\/html.*>|\\b(alert\\(|confirm\\(|expression\\(|prompt\\(|benchmark\s*?\(.*\)|sleep\s*?\(.*\)|\\b(group_)?concat[\\s\\/\\*]*?\\([^\\)]+?\\)|\bcase[\s\/\*]*?when[\s\/\*]*?\([^\)]+?\)|load_file\s*?\\()|<[a-z]+?\\b[^>]*?\\bon([a-z]{4,})\s*?=|^\\+\\/v(8|9)|\\b(and|or)\\b\\s*?([\\(\\)'\"\\d]+?=[\\(\\)'\"\\d]+?|[\\(\\)'\"a-zA-Z]+?=[\\(\\)'\"a-zA-Z]+?|>|<|\s+?[\\w]+?\\s+?\\bin\\b\\s*?\(|\\blike\\b\\s+?[\"'])|\\/\\*.*\\*\\/|<\\s*script\\b|\\bEXEC\\b|UNION.+?SELECT\s*(\(.+\)\s*|@{1,2}.+?\s*|\s+?.+?|(`|'|\").*?(`|'|\")\s*)|UPDATE\s*(\(.+\)\s*|@{1,2}.+?\s*|\s+?.+?|(`|'|\").*?(`|'|\")\s*)SET|INSERT\\s+INTO.+?VALUES|(SELECT|DELETE)@{0,2}(\\(.+\\)|\\s+?.+?\\s+?|(`|'|\").*?(`|'|\"))FROM(\\(.+\\)|\\s+?.+?|(`|'|\").*?(`|'|\"))|(CREATE|ALTER|DROP|TRUNCATE)\\s+(TABLE|DATABASE)|<.*(iframe|frame|style|embed|object|frameset|meta)";
//post拦截规则
$postfilter = "<.*=(&#\\d+?;?)+?>|<.*data=data:text\\/html.*>|\\b(alert\\(|confirm\\(|expression\\(|prompt\\(|benchmark\s*?\(.*\)|sleep\s*?\(.*\)|\\b(group_)?concat[\\s\\/\\*]*?\\([^\\)]+?\\)|\bcase[\s\/\*]*?when[\s\/\*]*?\([^\)]+?\)|load_file\s*?\\()|<[^>]*?\\b(onerror|onmousemove|onload|onclick|onmouseover)\\b|\\b(and|or)\\b\\s*?([\\(\\)'\"\\d]+?=[\\(\\)'\"\\d]+?|[\\(\\)'\"a-zA-Z]+?=[\\(\\)'\"a-zA-Z]+?|>|<|\s+?[\\w]+?\\s+?\\bin\\b\\s*?\(|\\blike\\b\\s+?[\"'])|\\/\\*.*\\*\\/|<\\s*script\\b|\\bEXEC\\b|UNION.+?SELECT\s*(\(.+\)\s*|@{1,2}.+?\s*|\s+?.+?|(`|'|\").*?(`|'|\")\s*)|UPDATE\s*(\(.+\)\s*|@{1,2}.+?\s*|\s+?.+?|(`|'|\").*?(`|'|\")\s*)SET|INSERT\\s+INTO.+?VALUES|(SELECT|DELETE)(\\(.+\\)|\\s+?.+?\\s+?|(`|'|\").*?(`|'|\"))FROM(\\(.+\\)|\\s+?.+?|(`|'|\").*?(`|'|\"))|(CREATE|ALTER|DROP|TRUNCATE)\\s+(TABLE|DATABASE)|<.*(iframe|frame|style|embed|object|frameset|meta)";
//cookie拦截规则
$cookiefilter = "benchmark\s*?\(.*\)|sleep\s*?\(.*\)|load_file\s*?\\(|\\b(and|or)\\b\\s*?([\\(\\)'\"\\d]+?=[\\(\\)'\"\\d]+?|[\\(\\)'\"a-zA-Z]+?=[\\(\\)'\"a-zA-Z]+?|>|<|\s+?[\\w]+?\\s+?\\bin\\b\\s*?\(|\\blike\\b\\s+?[\"'])|\\/\\*.*\\*\\/|<\\s*script\\b|\\bEXEC\\b|UNION.+?SELECT\s*(\(.+\)\s*|@{1,2}.+?\s*|\s+?.+?|(`|'|\").*?(`|'|\")\s*)|UPDATE\s*(\(.+\)\s*|@{1,2}.+?\s*|\s+?.+?|(`|'|\").*?(`|'|\")\s*)SET|INSERT\\s+INTO.+?VALUES|(SELECT|DELETE)@{0,2}(\\(.+\\)|\\s+?.+?\\s+?|(`|'|\").*?(`|'|\"))FROM(\\(.+\\)|\\s+?.+?|(`|'|\").*?(`|'|\"))|(CREATE|ALTER|DROP|TRUNCATE)\\s+(TABLE|DATABASE)";
//referer获取
$webscan_referer = empty($_SERVER['HTTP_REFERER']) ? array() : array('HTTP_REFERER' => $_SERVER['HTTP_REFERER']);
disable_error(DEBUG);
function disable_error($debug)
{
if (!$debug) {
error_reporting(0);
}
}
/**
* 数据统计回传
*/
function webscan_slog($logs)
{
if (DEBUG) {
//日志记录
$fh = fopen(dirname(__FILE__) . "/webscan.log", "a");
fwrite($fh, json_encode($logs) . "\n");
fclose($fh);
}
return true;
}
/**
* 参数拆分
*/
function webscan_arr_foreach($arr)
{
static $str;
static $keystr;
if (!is_array($arr)) {
return $arr;
}
foreach ($arr as $key => $val) {
$keystr = $keystr . $key;
if (is_array($val)) {
webscan_arr_foreach($val);
} else {
$str[] = $val . $keystr;
}
}
return implode($str);
}
/**
* 防护提示页
*/
function webscan_pape()
{
$pape = '<!doctype html><html><head><meta charset="utf-8"><meta name="viewport"content="width=device-width"><title>网站防火墙</title><style>*{margin:0;padding:0;color:#444}body{font-size:14px}.main{width:90%;max-width:600px;margin:10%auto}.title{background:#2c93df;color:#fff;font-size:16px;height:40px;line-height:40px;padding-left:20px;text-align:center}.content{background-color:#f3f7f9;border:1px dashed#c6d9b6;padding:20px}.t1{border-bottom:1px dashed#c6d9b6;color:#ff4000;font-weight:bold;margin:0 0 20px;padding-bottom:18px}.t2{margin-bottom:8px;font-weight:bold}ol{margin:0 0 20px 22px;padding:0}ol li{line-height:30px}</style></head><body><div class="main"><div class="title">六零导航页网站防火墙</div><div class="content"><p class="t1">您的请求带有不合法参数,已被网站防火墙拦截!</p><p class="t2">原因:</p><p>您提交的内容包含危险的攻击请求</p></div></div></body></html>';
echo $pape;
}
/**
* 攻击检查拦截
*/
function webscan_StopAttack($StrFiltKey, $StrFiltValue, $ArrFiltReq, $method)
{
$StrFiltValue = webscan_arr_foreach($StrFiltValue);
if (preg_match("/" . $ArrFiltReq . "/is", $StrFiltValue) == 1) {
webscan_slog(array('ip' => $_SERVER["REMOTE_ADDR"], 'time' => strftime("%Y-%m-%d %H:%M:%S"), 'page' => $_SERVER["PHP_SELF"], 'method' => $method, 'rkey' => $StrFiltKey, 'rdata' => $StrFiltValue, 'user_agent' => $_SERVER['HTTP_USER_AGENT'], 'request_url' => $_SERVER["REQUEST_URI"]));
exit(webscan_pape());
}
if (preg_match("/" . $ArrFiltReq . "/is", $StrFiltKey) == 1) {
webscan_slog(array('ip' => $_SERVER["REMOTE_ADDR"], 'time' => strftime("%Y-%m-%d %H:%M:%S"), 'page' => $_SERVER["PHP_SELF"], 'method' => $method, 'rkey' => $StrFiltKey, 'rdata' => $StrFiltKey, 'user_agent' => $_SERVER['HTTP_USER_AGENT'], 'request_url' => $_SERVER["REQUEST_URI"]));
exit(webscan_pape());
}
}
/**
* 拦截目录白名单
*/
function webscan_white($webscan_white_name, $webscan_white_url = array())
{
$url_path = $_SERVER['SCRIPT_NAME'];
$url_var = $_SERVER['QUERY_STRING'];
if (preg_match("/" . $webscan_white_name . "/is", $url_path) == 1 && !empty($webscan_white_name)) {
return false;
}
foreach ($webscan_white_url as $key => $value) {
if (!empty($url_var) && !empty($value)) {
if (stristr($url_path, $key) && stristr($url_var, $value)) {
return false;
}
} elseif (empty($url_var) && empty($value)) {
if (stristr($url_path, $key)) {
return false;
}
}
}
return true;
}
if ($webscan_switch && webscan_white($webscan_white_directory, $webscan_white_url)) {
if ($webscan_get) {
foreach ($_GET as $key => $value) {
webscan_StopAttack($key, $value, $getfilter, "GET");
}
}
if ($webscan_post) {
foreach ($_POST as $key => $value) {
webscan_StopAttack($key, $value, $postfilter, "POST");
}
}
if ($webscan_cookie) {
foreach ($_COOKIE as $key => $value) {
webscan_StopAttack($key, $value, $cookiefilter, "COOKIE");
}
}
if ($webscan_referre) {
foreach ($webscan_referer as $key => $value) {
webscan_StopAttack($key, $value, $postfilter, "REFERRER");
}
}
}

View File

@ -92,6 +92,12 @@ if ($sqlvn < $filevn) {
}
}
}
if ($sqlvn < 10900) {
$version = 'v1.9.0';
}
if ($sqlvn < 10905) {
$version = 'v1.9.5';
}
$sql = explode(';', $sql);
for ($i = 0; $i < count($sql); $i++) {
if (trim($sql[$i]) == '') {

View File

@ -1,4 +1,13 @@
<?php
/*
* @Description:
* @Author: LyLme admin@lylme.com
* @Date: 2024-01-23 12:25:35
* @LastEditors: LyLme admin@lylme.com
* @LastEditTime: 2024-04-06 16:08:52
* @FilePath: /lylme_spage/include/validatecode.php
* @Copyright (c) 2024 by LyLme, All Rights Reserved.
*/
session_start();
@ -8,40 +17,45 @@ $bgcolor = imagecolorallocate($image, 255, 255, 255); //#ffffff
//6>区域填充 int imagefill(int im, int x, int y, int col) (x,y) 所在的区域着色,col 表示欲涂上的颜色
imagefill($image, 0, 0, $bgcolor);
//10>设置变量
$captcha_code = "";
//9>增加干扰元素,设置横线
for ($i = 0; $i < 15; $i++) {
//设置线的颜色
$linecolor = imagecolorallocate($image, rand(70, 90),rand(70, 90), rand(70, 90));
//设置线,两点一线
imageline($image, rand(1, 38), rand(1, 99), rand(1, 99), rand(1, 38), $linecolor);
}
//7>生成随机数字
for ($i = 0; $i < 6; $i++) {
for ($i = 0; $i < 5; $i++) {
//设置字体大小
$fontsize = 8;
//设置字体颜色,随机颜色
$fontcolor = imagecolorallocate($image, rand(0, 120), rand(0, 120), rand(0, 120)); //0-120深颜色
$fontcolor = imagecolorallocate($image, rand(30, 80) ,rand(30, 80) ,rand(30, 80) );
//设置数字
$fontcontent = rand(0, 9);
//10>.=连续定义变量
$captcha_code .= $fontcontent;
//设置坐标
$x = ($i * 100 / 6) + rand(5, 10);
$y = rand(5, 10);
$x = ($i * 100 / 5) + rand(5, 10);
$y = rand(5, 20);
imagestring($image, $fontsize, $x, $y, $fontcontent, $fontcolor);
}
//10>存到session
$_SESSION['authcode'] = $captcha_code;
//8>增加干扰元素,设置雪花点
for ($i = 0; $i < 15; $i++) {
for ($i = 0; $i < 30; $i++) {
//设置点的颜色50-200颜色比数字浅不干扰阅读
$pointcolor = imagecolorallocate($image, rand(100, 200), rand(100, 200), rand(100, 200));
$pointcolor = imagecolorallocate($image, rand(80, 90) , rand(80, 90) , rand(80, 90) );
//imagesetpixel — 画一个单一像素
imagesetpixel($image, rand(1, 99), rand(1, 29), $pointcolor);
}
//9>增加干扰元素,设置横线
for ($i = 0; $i < 15; $i++) {
//设置线的颜色
$linecolor = imagecolorallocate($image, rand(120, 220), rand(120, 220), rand(120, 220));
//设置线,两点一线
imageline($image, rand(1, 99), rand(1, 29), rand(1, 99), rand(1, 29), $linecolor);
imagesetpixel($image, rand(1, 99), rand(1, 38), $pointcolor);
imagesetpixel($image, rand(1, 99), rand(1, 38), $pointcolor);
imagesetpixel($image, rand(1, 99), rand(1, 38), $pointcolor);
}
//2>设置头部image/png
header('Content-Type: image/png');
//3>imagepng() 建立png图形函数

View File

@ -1,3 +1,3 @@
<?php
define('VERSION', '1.8.5');
define('VERSION', '1.9.5');