网站首页 > 基础教程 正文
我们做外贸独立站通常网站搬家,要从服务器上下载到本地,然后又从本地上传到新的服务器,如果是2台在外国的服务器,这样操作这实在是太慢了。
我们直接利用新旧服务器互传。
在这个例子中,我添加了一个进度条的HTML和CSS部分,以及一个JavaScript函数 updateProgressBar,该函数用于更新进度条的状态。progressCallback 函数在下载过程中通过调用该JavaScript函数来更新进度条的状态。这样,你就可以在页面上看到一个动态的进度条。但由于PHP是服务器端语言,而浏览器是在收到完整响应后才开始渲染页面的,因此在文件下载过程中动态显示进度条可能会有些困难。
直接创建一个PHP文件,如download.php 写入以下代码,上传到新服务器,运行https://域名/download.php 打开
<?php
if ($_SERVER["REQUEST_METHOD"] == "POST") {
// 获取用户输入的下载地址
$fileUrl = $_POST["fileUrl"];
// 检查下载地址是否为空
if (empty($fileUrl)) {
echo "请提供文件下载地址。";
} else {
// 获取文件名
$fileName = basename($fileUrl);
// 保存文件到当前目录
$savedFilePath = __DIR__ . '/' . $fileName;
// 初始化cURL会话
$ch = curl_init($fileUrl);
// 打开文件句柄用于保存文件
$fileHandle = fopen($savedFilePath, 'w');
// 设置cURL参数
curl_setopt($ch, CURLOPT_RETURNTRANSFER, false);
curl_setopt($ch, CURLOPT_NOPROGRESS, false);
curl_setopt($ch, CURLOPT_PROGRESSFUNCTION, 'progressCallback');
curl_setopt($ch, CURLOPT_FILE, $fileHandle);
// 执行cURL会话
curl_exec($ch);
// 关闭文件句柄
fclose($fileHandle);
// 关闭cURL会话
curl_close($ch);
// 检查文件是否成功保存
if (file_exists($savedFilePath)) {
echo "文件下载成功。";
} else {
echo "文件下载失败。";
}
}
}
function progressCallback($resource, $download_size, $downloaded, $upload_size, $uploaded) {
if ($download_size > 0) {
$progress = round(($downloaded / $download_size) * 100, 2);
echo "<script>updateProgressBar({$progress})</script>";
ob_flush();
flush();
}
}
?>
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>远程文件下载</title>
<style>
#progress-container {
width: 300px;
border: 1px solid #ccc;
margin-top: 10px;
display: none;
}
#progress-bar {
width: 0;
height: 20px;
background-color: #4CAF50;
text-align: center;
line-height: 20px;
color: white;
}
</style>
</head>
<body>
<h1>远程文件下载</h1>
<form method="post" action="<?php echo $_SERVER['PHP_SELF']; ?>">
<label for="fileUrl">文件下载地址:</label>
<input type="text" name="fileUrl" id="fileUrl" required>
<button type="submit">下载文件</button>
</form>
<div id="progress-container">
<div id="progress-bar">0%</div>
</div>
<script>
function updateProgressBar(progress) {
var progressBar = document.getElementById("progress-bar");
progressBar.style.width = progress + "%";
progressBar.innerHTML = progress + "%";
if (progress === 100) {
document.getElementById("progress-container").style.display = "none";
} else {
document.getElementById("progress-container").style.display = "block";
}
}
</script>
</body>
</html>
填写远程下载的备份文件包,然后点击下载,下载完成后,提示“文件下载成功”。
最后,新服务器会多出你下载的文件包。
独立站-外贸独立站-跨境电商独立站-外贸独立建站-平台自建站-佛山美络云科技有限公司
猜你喜欢
- 2024-10-12 纯JS手写轮播图(代码逻辑清晰,通俗易懂)
- 2024-10-12 谷歌浏览器任意文件访问漏洞(CVE-2023-4357)复现
- 2024-10-12 Dom节点优化方案 dom节点树例题
- 2024-10-12 自动化测试工程师的学习方法和逻辑
- 2024-10-12 Web Components 系列(八)——自定义组件的样式设置
- 2024-10-12 JavaScript,自制弹窗(练习) js弹出自定义窗口
- 2024-10-12 掌握 onmouseover 事件:打造动态 HTML 体验
- 2024-10-12 Vue 自定义指令详解-按钮级权限示例(干货)
- 2024-10-12 windows本地程序调用与selenium的简单应用
- 2024-10-12 中高级渗透测试员都必须掌握的Web安全测试知识库,速收藏!
- 最近发表
- 标签列表
-
- gitpush (61)
- pythonif (68)
- location.href (57)
- tail-f (57)
- pythonifelse (59)
- deletesql (62)
- c++模板 (62)
- css3动画 (57)
- c#event (59)
- linuxgzip (68)
- 字符串连接 (73)
- nginx配置文件详解 (61)
- html标签 (69)
- c++初始化列表 (64)
- exec命令 (59)
- canvasfilltext (58)
- mysqlinnodbmyisam区别 (63)
- arraylistadd (66)
- node教程 (59)
- console.table (62)
- c++time_t (58)
- phpcookie (58)
- mysqldatesub函数 (63)
- window10java环境变量设置 (66)
- c++虚函数和纯虚函数的区别 (66)