更新 index.php

加入多用户管理。
This commit is contained in:
sunson 2024-12-03 12:45:32 +08:00
parent d831c5c0de
commit d948a693ba

234
index.php
View File

@ -1,17 +1,20 @@
<?php <?php
$base_dir='/o/';//以/即结束即可 $base_dir = '/o/';//以/即结束即可
$user="chate.store";// 用户名 $user = array("admin1","admin2");// 用户名,可多个
$pwd="123456";// 密码,请记得频繁更换 $pwd = array("chate.store1","chate.store2");// 密码,跟用户一一对应,请记得更换
$authorization = false; $authorization = false;
if ($_SERVER['PHP_AUTH_USER'] == $user && $_SERVER['PHP_AUTH_PW'] == $pwd){ $key = array_search($_SERVER['PHP_AUTH_USER'], $user);
if($key !== false){
if($_SERVER['PHP_AUTH_PW'] ==$pwd[$key]){
$authorization = true; $authorization = true;
}
} }
if(!$authorization){ if(!$authorization){
// 没登录成功,弹出要求输入用户名和密码窗口 // 没登录成功,弹出要求输入用户名和密码窗口
header("WWW-Authenticate:Basic realm='Private'"); header("WWW-Authenticate:Basic realm='Private'");
header('HTTP/1.0 401 Unauthorized'); header('HTTP/1.0 401 Unauthorized');
exit; exit;
} }
// 处理文件上传 // 处理文件上传
@ -22,8 +25,8 @@ if ($_SERVER['REQUEST_METHOD'] === 'POST' && isset($_FILES['file'])) {
// 检查上传错误,直接提示错误代码 // 检查上传错误,直接提示错误代码
if ($error !== UPLOAD_ERR_OK) { if ($error !== UPLOAD_ERR_OK) {
echo '{"error":"上传失败,错误代码:'.$error.'"}'; echo '{"error":"上传失败,错误代码:'.$error.'"}';
exit; exit;
} }
// 兼容跨平台路径 // 兼容跨平台路径
@ -71,18 +74,18 @@ if ($_SERVER['REQUEST_METHOD'] === 'POST' && isset($_FILES['file'])) {
align-items: center; align-items: center;
flex-direction: column; flex-direction: column;
} }
.background { .background {
position: absolute; position: absolute;
top: 0; top: 0;
left: 0; left: 0;
width: 100%; width: 100%;
height: 100%; height: 100%;
background-size: cover; background-size: cover;
z-index: -1; z-index: -1;
transition: opacity 1s ease-in-out; transition: opacity 1s ease-in-out;
opacity: 1; opacity: 1;
} }
.container { .container {
width: 600px; width: 600px;
overflow: hidden; overflow: hidden;
} }
@ -171,61 +174,66 @@ if ($_SERVER['REQUEST_METHOD'] === 'POST' && isset($_FILES['file'])) {
</style> </style>
</head> </head>
<body> <body>
<div class="background" id="background"></div> <div class="background" id="background"></div>
<div class="container"> <div class="container">
<div class="card"> <div class="card">
<div class="card-body"> <div class="card-body">
<h4 class="card-title text-center" style="font-weight: bold;">SIWSimple Image Web</h4> <h4 class="card-title text-center" style="font-weight: bold;">SIWSimple Image Web</h4>
<h6 class="card-title text-center" style="font-weight: bold;">简单就是美。</h6> <h6 class="card-title text-center" style="font-weight: bold;">简单就是美。</h6>
<form id="uploadForm" enctype="multipart/form-data"> <form id="uploadForm" enctype="multipart/form-data">
<div class="mb-3"> <div class="mb-3">
<label for="files" class="form-label"></label> <label for="files" class="form-label"></label>
<input type="file" class="form-control" id="files" name="files[]" multiple accept="image/jpeg, image/png, image/gif, image/webp, image/avif" required> <input type="file" class="form-control" id="files" name="files[]" multiple accept="image/jpeg, image/png, image/gif, image/webp, image/avif" required>
</div> </div>
<button type="submit" class="btn btn-primary w-100" style="font-weight: bold;">开始上传</button> <button type="submit" class="btn btn-primary w-100" style="font-weight: bold;">开始上传</button>
</form> </form>
<div id="fileList" class="file-list mt-3"></div> <div id="fileList" class="file-list mt-3"></div>
<div id="statusOutput" class="status-output"></div> <div id="statusOutput" class="status-output"></div>
<div class="link-output"> <div class="link-output">
<button class="btn btn-info" id="directLinkBtn">直连</button> <button class="btn btn-info" id="directLinkBtn">直连</button>
<button class="btn btn-info" id="htmlCodeBtn">网页</button> <button class="btn btn-info" id="htmlCodeBtn">网页</button>
<button class="btn btn-info" id="forumCodeBtn">论坛</button> <button class="btn btn-info" id="forumCodeBtn">论坛</button>
<button class="btn btn-info" id="markDownCodeBtn">Markdown</button> <button class="btn btn-info" id="markDownCodeBtn">Markdown</button>
<button class="btn btn-success" id="copyAllBtn">复制所有链接</button> <button class="btn btn-success" id="copyAllBtn">复制所有链接</button>
<textarea id="linkText" readonly></textarea> <textarea id="linkText" readonly></textarea>
</div> </div>
<h6 id="formatHint" class="card-title text-center">支持格式: JPEG, PNG, GIF, WEBP, AVIF 最大上传:<?php echo ini_get('upload_max_filesize');?></h6> <h6 id="formatHint" class="card-title text-center">支持格式: JPEG, PNG, GIF, WEBP, AVIF 最大上传:<?php echo ini_get('upload_max_filesize');?></h6>
</div> </div>
</div> </div>
</div> </div>
</div> </div>
<script> <script>
async function setBackgroundImages() { async function setBackgroundImages() {
const images = ['https://cn.bing.com/th?id=OHR.SnowMoose_EN-US6949674639_1920x1080.jpg','https://cn.bing.com/th?id=OHR.IcebergsAntarctica_EN-US6829804691_1920x1080.jpg','https://cn.bing.com/th?id=OHR.KilchurnAutumn_EN-US6737063910_1920x1080.jpg','https://cn.bing.com/th?id=OHR.MtStMichel_EN-US6641012356_1920x1080.jpg','https://cn.bing.com/th?id=OHR.TomTurkeys_EN-US6212893518_1920x1080.jpg']; // 取必应每天的壁纸做背景
const backgroundDiv = document.getElementById('background'); var response = await fetch('https://raw.onmicrosoft.cn/Bing-Wallpaper-Action/main/data/zh-CN_all.json');
var data = await response.json();
var images = data.data.map(image => image.url);
var backgroundDiv = document.getElementById('background');
if (images.length > 0) { if (images.length > 0) {
backgroundDiv.style.backgroundImage = 'url(' + images[0] + ')'; backgroundDiv.style.backgroundImage = 'url(https://www.bing.com/' + images[0] + ')';
} }
let index = 0; let index = 0;
let currentBackgroundDiv = backgroundDiv; let currentBackgroundDiv = backgroundDiv;
setInterval(() => { setInterval(() => {
const nextIndex = (index + 1) % images.length; const nextIndex = (index + 1) % images.length;
const nextBackgroundDiv = document.createElement('div'); const nextBackgroundDiv = document.createElement('div');
nextBackgroundDiv.className = 'background next'; nextBackgroundDiv.className = 'background next';
nextBackgroundDiv.style.backgroundImage = 'url(' + images[nextIndex] + ')'; nextBackgroundDiv.style.backgroundImage = 'url(https://www.bing.com/' + images[nextIndex] + ')';
document.body.appendChild(nextBackgroundDiv); document.body.appendChild(nextBackgroundDiv);
nextBackgroundDiv.style.opacity = 0; nextBackgroundDiv.style.opacity = 0;
setTimeout(() => { setTimeout(() => {
nextBackgroundDiv.style.opacity = 1; nextBackgroundDiv.style.opacity = 1;
}, 50); }, 50);
setTimeout(() => { setTimeout(() => {
document.body.removeChild(currentBackgroundDiv); document.body.removeChild(currentBackgroundDiv);
currentBackgroundDiv = nextBackgroundDiv; currentBackgroundDiv = nextBackgroundDiv;
index = nextIndex; index = nextIndex;
}, 1000); if(index>10)index=0;// 只取前十张
}, 1000);
}, 5000); }, 5000);
} }
$(document).ready(function() { $(document).ready(function() {
setBackgroundImages();// 设置背景 setBackgroundImages();// 设置背景
// 初始化时显示格式提示 // 初始化时显示格式提示
@ -286,44 +294,44 @@ $(document).ready(function () {
var fileIndex = 0; var fileIndex = 0;
function uploadNextFile() { function uploadNextFile() {
if (fileIndex < files.length) { if (fileIndex < files.length) {
var formData = new FormData(); var formData = new FormData();
formData.append('file', files[fileIndex]); formData.append('file', files[fileIndex]);
var xhr = new XMLHttpRequest(); var xhr = new XMLHttpRequest();
xhr.open("POST", '', true); xhr.open("POST", '', true);
var startTime; var startTime;
xhr.upload.addEventListener('progress', function (evt) { xhr.upload.addEventListener('progress', function (evt) {
if (evt.lengthComputable) { if (evt.lengthComputable) {
if (!startTime) startTime = new Date(); if (!startTime) startTime = new Date();
var percentComplete = Math.round((evt.loaded / evt.total) * 100); var percentComplete = Math.round((evt.loaded / evt.total) * 100);
var elapsedTime = (new Date() - startTime) / 1000; var elapsedTime = (new Date() - startTime) / 1000;
var speed = (evt.loaded / 1024 / 1024) / elapsedTime; var speed = (evt.loaded / 1024 / 1024) / elapsedTime;
var fileRow = $('#file-row-' + fileIndex); var fileRow = $('#file-row-' + fileIndex);
fileRow.find('.progress-status').text(` ${speed.toFixed(2)} MB/s`); fileRow.find('.progress-status').text(` ${speed.toFixed(2)} MB/s`);
fileRow.find('.progress').show(); fileRow.find('.progress').show();
fileRow.find('.progress-bar').css('width', percentComplete + '%').text(percentComplete + '%'); fileRow.find('.progress-bar').css('width', percentComplete + '%').text(percentComplete + '%');
var container = $('#fileList'); var container = $('#fileList');
var targetRow = $('#file-row-' + fileIndex); var targetRow = $('#file-row-' + fileIndex);
var targetTop = targetRow[0].offsetTop; var targetTop = targetRow[0].offsetTop;
var containerHeight = container.height(); var containerHeight = container.height();
var rowHeight = targetRow.outerHeight(); var rowHeight = targetRow.outerHeight();
var scrollTo = targetTop - (containerHeight / 1) + (rowHeight / 2); var scrollTo = targetTop - (containerHeight / 1) + (rowHeight / 2);
scrollTo = Math.max(0, Math.min(scrollTo, container[0].scrollHeight - containerHeight)); scrollTo = Math.max(0, Math.min(scrollTo, container[0].scrollHeight - containerHeight));
container.stop().animate({ scrollTop: scrollTo }, 200); container.stop().animate({ scrollTop: scrollTo }, 200);
if (percentComplete === 100) { if (percentComplete === 100) {
setTimeout(function () { setTimeout(function () {
if (xhr.readyState !== XMLHttpRequest.DONE) { if (xhr.readyState !== XMLHttpRequest.DONE) {
fileRow.find('.progress-status').text('处理中请稍等'); fileRow.find('.progress-status').text('处理中请稍等');
} }
}, 100); }, 100);
} }
} }
}, false); }, false);
xhr.onreadystatechange = function () { xhr.onreadystatechange = function () {
if (xhr.readyState === XMLHttpRequest.DONE) { if (xhr.readyState === XMLHttpRequest.DONE) {
var fileRow = $('#file-row-' + fileIndex); var fileRow = $('#file-row-' + fileIndex);
if (xhr.status === 200) { if (xhr.status === 200) {
var result = JSON.parse(xhr.responseText); var result = JSON.parse(xhr.responseText);
if (result.upload_url) { if (result.upload_url) {
uploadedLinks.push(result.upload_url); uploadedLinks.push(result.upload_url);
fileRow.find('.progress-status').text('处理完成'); fileRow.find('.progress-status').text('处理完成');
fileRow.find('.progress').hide(); fileRow.find('.progress').hide();
@ -336,33 +344,33 @@ if (xhr.status === 200) {
fileRow.find('.progress-status').text('成功上传'); fileRow.find('.progress-status').text('成功上传');
}, 100); }, 100);
showLinkOutput(); showLinkOutput();
} else if (result.error) { } else if (result.error) {
fileRow.find('.progress-status').text('上传失败: ' + result.error); fileRow.find('.progress-status').text('上传失败: ' + result.error);
$('#statusOutput').text('上传中断: ' + result.error); $('#statusOutput').text('上传中断: ' + result.error);
return; return;
} }
} else { } else {
fileRow.find('.progress-status').text('错误信息: ' + xhr.statusText); fileRow.find('.progress-status').text('错误信息: ' + xhr.statusText);
$('#statusOutput').text('上传中断: ' + xhr.statusText); $('#statusOutput').text('上传中断: ' + xhr.statusText);
return; return;
} }
fileIndex++; fileIndex++;
uploadNextFile(); uploadNextFile();
} }
}; };
xhr.send(formData); xhr.send(formData);
} else { } else {
$('#statusOutput').text('上传任务操作完成'); $('#statusOutput').text('上传任务操作完成');
$('#files').val(''); // 清空文件选择 $('#files').val(''); // 清空文件选择
} }
$('#statusOutput').text(`当前状态: 正在上传 ${files[fileIndex].name}`); $('#statusOutput').text(`当前状态: 正在上传 ${files[fileIndex].name}`);
} }
uploadNextFile(); uploadNextFile();
}); });
function showLinkOutput() { function showLinkOutput() {
$('.link-output').show(); $('.link-output').show();
$('#linkText').val(uploadedLinks.join('\n')); // 显示所有链接 $('#linkText').val(uploadedLinks.join('\n')); // 显示所有链接
$('#linkText').scrollTop($('#linkText')[0].scrollHeight); $('#linkText').scrollTop($('#linkText')[0].scrollHeight);
} }
function showAlert(message) { function showAlert(message) {
var tooltip = document.createElement('div'); var tooltip = document.createElement('div');