kyo*_*kyo 2 javascript php sftp laravel
单击时我有一个下载按钮,下载文件大约需要 15 秒,因为它必须通过 SFTP 进入服务器,找到正确的路径/文件,然后返回响应。
<a class="btn btn-primary btn-sm text-primary btn-download-1" onclick="startDownload('1')"><i class="fa fa-download "></i></a>
Run Code Online (Sandbox Code Playgroud)
这是 startDownload 函数:
function startDownload(interfaceId) {
window.location = "/nodes/interface/capture/download?port=" + interfaceId;
}
Run Code Online (Sandbox Code Playgroud)
中的后端代码/nodes/interface/capture/download:
public function download_files()
{
$dir = '';
$portNumber = Request::get('port');
$zipMe = false;
$remotePath = "/home/john/logs/".$dir."/";
if (!isset($dir) || $dir == null) {
return redirect()->back()->withInput()->withFlashDanger('SFTP Could not connect.');
}
$acsIp = explode('://', env('ACS_URL'));
$acsIp = explode(':',$acsIp[1])[0];
$sftp = new SFTP($acsIp.':22');
if (!$sftp->login('john', '***')) {
return redirect()->back()->withInput()->withFlashDanger('SFTP Could not connect.');
}
// Get into the Specified Directory
$sftpConn = Storage::disk('sftp');
$SFTPFiles = $sftpConn->allFiles('/'.$dir);
if ( count($SFTPFiles) > 0 ) {
foreach ($SFTPFiles as $file) {
$fileName = $file;
break;
}
} else {
\Log::info('Files Not found in the Remote!');
return redirect()->back()->withInput()->withFlashDanger('Files Not found in the Remote!');
}
// Create and give 777 permission to remote-files directory
if (!is_dir(public_path('remote-files/'.$dir))) {
mkdir(public_path('remote-files/'.$dir), 0777, true);
}
$filesToZip = [];
foreach ( $SFTPFiles as $fileName ) {
if ( $fileName == '..' || $fileName == '.' ) {
continue;
} else if ( $fileName == '' ) {
\Log::info('File not found');
continue;
}
$fileName = explode("/", $fileName);
$onlyFileName = (!empty($fileName) && isset($fileName[1])) ? $fileName[1] : "";
$filepath = $remotePath.$onlyFileName;
if (strpos($onlyFileName , $portNumber) !== false) {
// Download the remote file at specified location in Local
if (!$sftp->get($filepath, 'remote-files/'.$dir.'/'.$onlyFileName))
{
die("Error downloading file ".$filepath);
}
$file = public_path('remote-files/'.$dir.'/').$onlyFileName;
$headers = array(
'Content-Description: File Transfer',
'Content-Type: application/octet-stream',
'Content-Disposition: attachment; filename="'.basename($file).'"',
'Cache-Control: must-revalidate',
'Pragma: public',
'Content-Length: ' . filesize($file)
);
return Response::download($file, $onlyFileName, $headers);
}
// IF File is exists in Directory
if ( file_exists( public_path('remote-files/'.$dir.'/').$onlyFileName ) ) {
$filesToZip[] = public_path('remote-files/'.$dir.'/').$onlyFileName;
\Log::info('File Generated '.'remote-files/'.$dir.'/'.$onlyFileName);
// Remove Files from public/remote-files
$this->removeDirAndFiles('', public_path('remote-files/'.$dir));
exit;
} else {
\Log::info('File not Generated '.'remote-files/'.$dir.'/'.$onlyFileName);
}
}
}
Run Code Online (Sandbox Code Playgroud)
这段代码确实有效,但需要大约 15 秒,这对于用例来说太长了。
有没有办法加快这个速度?我的代码有问题还是可以预料?我应该考虑切换到 SCP 吗?我应该重新考虑身份验证吗?
小智 5
我更改了您的函数以测量不同部分的时间,因此您可以通过查看此字符串“### [TIME] --”的日志来了解哪个部分正在减慢您的应用程序
public function download_files()
{
$start = time();
$dir = '';
$portNumber = Request::get('port');
$zipMe = false;
\Log::info("### [TIME] -- t1 = " . (time() - $start));
$remotePath = "/home/john/logs/".$dir."/";
if (!isset($dir) || $dir == null) {
return redirect()->back()->withInput()->withFlashDanger('SFTP Could not connect.');
}
$acsIp = explode('://', env('ACS_URL'));
$acsIp = explode(':',$acsIp[1])[0];
$t1 = time();
$sftp = new SFTP($acsIp.':22');
$t2 = time();
\Log::info("### [TIME] -- SFTP Instantiation took " . ($t2 - $t1) . " secs");
if (!$sftp->login('john', '***')) {
return redirect()->back()->withInput()->withFlashDanger('SFTP Could not connect.');
}
$t1 = time();
// Get into the Specified Directory
$sftpConn = Storage::disk('sftp');
$SFTPFiles = $sftpConn->allFiles('/'.$dir);
$t2 = time();
\Log::info("### [TIME] -- SFTPFiles list took " . ($t2 - $t1) . " secs");
// this loop is not clear to me, you basically take the first element and
// exit the loop
if ( count($SFTPFiles) > 0 ) {
foreach ($SFTPFiles as $file) {
$fileName = $file;
break;
}
} else {
\Log::info('Files Not found in the Remote!');
return redirect()->back()->withInput()->withFlashDanger('Files Not found in the Remote!');
}
$t1 = time();
// Create and give 777 permission to remote-files directory
if (!is_dir(public_path('remote-files/'.$dir))) {
mkdir(public_path('remote-files/'.$dir), 0777, true);
}
$t2 = time();
\Log::info("### [TIME] -- Directory creation took " . ($t2 - $t1) . " secs");
$filesToZip = [];
$t1 = time();
foreach ( $SFTPFiles as $fileName )
{
$start_loop_time = time();
\Log::info("### [TIME] -- Loop for $fileName took " . (time() - $t1) . " secs");
if ( $fileName == '..' || $fileName == '.' ) {
continue;
} else if ( $fileName == '' ) {
\Log::info('File not found');
continue;
}
$fileName = explode("/", $fileName);
$onlyFileName = (!empty($fileName) && isset($fileName[1])) ? $fileName[1] : "";
$filepath = $remotePath.$onlyFileName;
if (strpos($onlyFileName , $portNumber) !== false) {
$responseCreationStart = time();
// Download the remote file at specified location in Local
if (!$sftp->get($filepath, 'remote-files/'.$dir.'/'.$onlyFileName))
{
die("Error downloading file ".$filepath);
}
$file = public_path('remote-files/'.$dir.'/').$onlyFileName;
$headers = array(
'Content-Description: File Transfer',
'Content-Type: application/octet-stream',
'Content-Disposition: attachment; filename="'.basename($file).'"',
'Cache-Control: must-revalidate',
'Pragma: public',
'Content-Length: ' . filesize($file)
);
$responseCreationEnd = time();
\Log::info("### [TIME] -- Response creation took " . ($responseCreationEnd - $responseCreationStart ) . " secs");
return Response::download($file, $onlyFileName, $headers);
}
// IF File is exists in Directory
if ( file_exists( public_path('remote-files/'.$dir.'/').$onlyFileName ) ) {
$t3 = time();
$filesToZip[] = public_path('remote-files/'.$dir.'/').$onlyFileName;
\Log::info('File Generated '.'remote-files/'.$dir.'/'.$onlyFileName);
// Remove Files from public/remote-files
$this->removeDirAndFiles('', public_path('remote-files/'.$dir));
$t4 = time();
\Log::info("### [TIME] -- Deletion took " . ($t4 - $t3) . " secs");
exit;
} else {
\Log::info('File not Generated '.'remote-files/'.$dir.'/'.$onlyFileName);
}
\Log::info("### [TIME] -- Loop end reached in " . (time() - $start_loop_time ) . " secs");
}
}
Run Code Online (Sandbox Code Playgroud)