PHP에서 파일을 웹브라우저에 보내는 방법은 readfile()함수를 사용하는것이 일반적입니다. [code]
<?php
$file = 'monkey.gif';
if (file_exists($file)) {
header('Content-Description: File Transfer');
header('Content-Type: application/octet-stream');
header('Content-Disposition: attachment; filename="'.basename($file).'"');
header('Expires: 0');
header('Cache-Control: must-revalidate');
header('Pragma: public');
header('Content-Length: ' . filesize($file));
readfile($file);
exit;
}
[/code]
그러나 이경우 readfile()은 RAM 메모리에 저장되기때문에 다운로드요청이 많아지거나 파일용량이 큰 경우 RAM 부하가 발생하는 문제가 있습니다.
이 문제를 다음과 같은 방법으로 해결할수 있습니다.
[code]
function download($path, $buf=64)
{
$fullpath = $path;
$name = pathinfo($fullpath)['basename'];
if(strstr($_SERVER['HTTP_USER_AGENT'], "MSIE")) // Browser is Internet Explorer
{
$filename = urlencode($name);
$filename = preg_replace('/\./', '%2e', $filename, substr_count($filename, '.') - 1);
$filename = basename(str_replace("+", "%20", $filename));
}
else $filename = $name;
if (!is_file($fullpath) or connection_status()!=0) return(false);
while(ob_get_level()) @ob_end_clean();
header("Cache-Control: must-revalidate, post-check=0, pre-check=0");
header("Pragma: public");
header("Expires: ".gmdate("D, d M Y H:i:s", mktime(date("H")+2, date("i"), date("s"), date("m"), date("d"), date("Y")))." GMT");
header("Last-Modified: ".gmdate("D, d M Y H:i:s")." GMT");
header("Content-Type: application/octet-stream");
header("Content-Length: ".(string)(filesize($fullpath)));
header("Content-Disposition: inline; filename=\"$filename\""); // Important the quotes \"\" for Firefox
header("Content-Transfer-Encoding: binary\n");
if($this->getUseSession() === true) session_write_close();
if ($file = fopen($fullpath, 'rb'))
{
while(!feof($file) and (connection_status()==0))
{
set_time_limit(0); // Need if use max_execution_time set with php.ini.
print(fread($file, 1024*intval($buf)));
@ob_flush();
@flush();
}
fclose($file);
}
return((connection_status()==0) and !connection_aborted());
}
[/code]
위와 같이 하면 메모리영역은 $buf크기만큼만 점유하면서 웹브라우저에 전송되게 됩니다.
물론 속도가 뜬 결함이 있을수 있으나 용량이 큰 파일들을 다운로드 할때에는 위와 같은 방법이 서버부하를 줄이면서도 안전하다고 생각합니다.
게시글 목록
| 번호 | 제목 |
|---|---|
| 17657 | |
| 17655 | |
| 17654 | |
| 17653 |
JavaScript
ThreeJS - 3D Bar and Progress Bar
1
|
| 17652 |
node.js
RAM점유크기에 의한 노드서버관리
|
| 17651 |
JavaScript
Javascript Undo, Redo 기능 구현하기
|
| 17650 | |
| 17642 |
node.js
nodejs서버가 사용중인 메모리에 대한 로그
|
| 17633 |
node.js
node.js에서 스케쥴링작성
8
|
| 17632 | |
| 17631 |
MySQL
InnoDB와 MyISAM의 우단점
|
| 17630 | |
| 17628 |
JavaScript
자바스크립트 기반으로 HTML Canvas에 이미지를 불러들여 테두리색입히기
|
| 17624 | |
| 17623 | |
| 17620 |
node.js
tcp소켓과 websocket 의 비교
2
|
| 17618 |
JavaScript
JavaScript로 이미지의 부분 영역을 따내기
|
| 17617 | |
| 17614 | |
| 17612 | |
| 17611 | |
| 17610 | |
| 17609 | |
| 17608 |
node.js
Node.js로 지속적인 핑 결과를 파일로 저장
|
| 17607 |
정규표현식
특수문자 제거, 우리글짜가 있는지 체크
|
| 17604 |
node.js
Node.js에서 PDF 파일의 페이지 수를 얻기
|
| 17603 | |
| 17602 |
node.js
Node.js로 워터마킹 기능을 구현하는 방법
|
| 17600 | |
| 17594 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기