php下载文件 强制任意文件格式下载_PHP教程
用php下载一些文件,一般就是为了隐藏文件的真实下载地址才需要这样,否则这样会增加服务器负担,不如直接提供软件的地址。
一个简单的php文件下载源代码,虽不支持断点续传等,但是可以满足一些常用的需求了。php下载文件其实用一个a标签就能实现,比如 magento-1.8.1.0.zip 。但是遇到一些浏览器能识别的格式,比如.txt,.html,.pdf等,再用abc.txt 想必也知道会发生什么了。
<?<span>php </span><span>/*</span><span>* * 文件下载 * *</span><span>*/</span> <span>header</span>("Content-type:text/html;charset=utf-8"<span>); download(</span>'web/magento-1.8.1.0.zip', 'magento下载'<span>); </span><span>function</span> download(<span>$file</span>, <span>$down_name</span><span>){ </span><span>$suffix</span> = <span>substr</span>(<span>$file</span>,<span>strrpos</span>(<span>$file</span>,'.')); <span>//</span><span>获取文件后缀</span> <span>$down_name</span> = <span>$down_name</span>.<span>$suffix</span>; <span>//</span><span>新文件名,就是下载后的名字 //判断给定的文件存在与否 </span> <span>if</span>(!<span>file_exists</span>(<span>$file</span><span>)){ </span><span>die</span>("您要下载的文件已不存在,可能是被删除"<span>); } </span><span>$fp</span> = <span>fopen</span>(<span>$file</span>,"r"<span>); </span><span>$file_size</span> = <span>filesize</span>(<span>$file</span><span>); </span><span>//</span><span>下载文件需要用到的头</span> <span>header</span>("Content-type: application/octet-stream"<span>); </span><span>header</span>("Accept-Ranges: bytes"<span>); </span><span>header</span>("Accept-Length:".<span>$file_size</span><span>); </span><span>header</span>("Content-Disposition: attachment; filename=".<span>$down_name</span><span>); </span><span>$buffer</span> = 1024<span>; </span><span>$file_count</span> = 0<span>; </span><span>//</span><span>向浏览器返回数据 </span> <span>while</span>(!<span>feof</span>(<span>$fp</span>) && <span>$file_count</span> < <span>$file_size</span><span>){ </span><span>$file_con</span> = <span>fread</span>(<span>$fp</span>,<span>$buffer</span><span>); </span><span>$file_count</span> += <span>$buffer</span><span>; </span><span>echo</span> <span>$file_con</span><span>; } www.jbxue.com </span><span>fclose</span>(<span>$fp</span><span>); } </span>?>
PHP强制性文件下载的源代码
为用户提供强制性的文件下载功能。
<span>/*</span><span>******************* *@file - path to file </span><span>*/</span> <span>function</span> force_download(<span>$file</span><span>) { </span><span>if</span> ((<span>isset</span>(<span>$file</span>))&&(<span>file_exists</span>(<span>$file</span><span>))) { </span><span>header</span>("Content-length: ".<span>filesize</span>(<span>$file</span><span>)); </span><span>header</span>('Content-Type: application/octet-stream'<span>); </span><span>header</span>('Content-Disposition: attachment; filename="' . <span>$file</span> . '"'<span>); </span><span>readfile</span>("<span>$file</span>"<span>); } </span><span>else</span><span> { </span><span>echo</span> "No file selected"<span>; } }</span>
你一定会笑我"下载文件"如此简单都值得说?当然并不是想象那么简单。例如你希望客户要填完一份表格,才可以下载某一文件,你第一个想法一定是用 "Redirect"的方法,先检查表格是否已经填写完毕和完整,然后就将网址指到该文件,这样客户才能下载,但如果你想做一个关于"网上购物"的电子商务网站,考虑安全问题,你不想用户直接复制网址下载该文件,笔者建议你使用PHP直接读取该实际文件然后下载的方法去做。程序如下:
<span>$file_name</span> = "info_check.exe"<span>; </span><span>$file_dir</span> = "/public/www/download/"<span>; </span><span>if</span> (!<span>file_exists</span>(<span>$file_dir</span> . <span>$file_name</span>)) { <span>//</span><span>检查文件是否存在</span> <span>echo</span> "文件找不到"<span>; </span><span>exit</span><span>; } </span><span>else</span><span> { </span><span>$file</span> = <span>fopen</span>(<span>$file_dir</span> . <span>$file_name</span>,"r"); <span>//</span><span> 打开文件 // 输入文件标签 www.jbxue.com</span> <span>Header</span>("Content-type: application/octet-stream"<span>); </span><span>Header</span>("Accept-Ranges: bytes"<span>); </span><span>Header</span>("Accept-Length: ".<span>filesize</span>(<span>$file_dir</span> . <span>$file_name</span><span>)); </span><span>Header</span>("Content-Disposition: attachment; filename=" . <span>$file_name</span><span>); </span><span>//</span><span> 输出文件内容</span> <span>echo</span> <span>fread</span>(<span>$file</span>,<span>filesize</span>(<span>$file_dir</span> . <span>$file_name</span><span>)); </span><span>fclose</span>(<span>$file</span><span>); </span><span>exit</span><span>; } </span>
而如果文件路径是"http" 或者 "ftp" 网址的话,则源代码会有少许改变,程序如下:
<span>$file_name</span> = "info_check.exe"<span>; </span><span>$file_dir</span> = "http://www.jbxue.com/"<span>; </span><span>$file</span> = @ <span>fopen</span>(<span>$file_dir</span> . <span>$file_name</span>,"r"<span>); </span><span>if</span> (!<span>$file</span><span>) { </span><span>echo</span> "文件找不到"<span>; } </span><span>else</span><span> { </span><span>Header</span>("Content-type: application/octet-stream"<span>); </span><span>Header</span>("Content-Disposition: attachment; filename=" . <span>$file_name</span><span>); </span><span>while</span> (!<span>feof</span> (<span>$file</span><span>)) { </span><span>echo</span> <span>fread</span>(<span>$file</span>,50000<span>); } </span><span>fclose</span> (<span>$file</span><span>); } </span>
这样就可以用PHP直接输出文件了。
但,一定要注意:Header信息相当于先将文件信息高速浏览器,然后,再把浏览器上的信息下载到附件中。所以,如果在MVC模式的应用程序中,view页一定不要有任何内容,否则,view页的相关内容会随着文件的内容一同被下载,导致下载后的文件不能使用。
下面是我的程序:
<span>public</span> <span>function</span><span> downloadAction() { </span><span>if</span> (<span>isset</span>(<span>$_GET</span>['mriID'<span>])) { </span><span>$this</span>->view->mriID=(<span>get_magic_quotes_gpc</span>())?<span>$_GET</span>['mriID']:<span>addslashes</span>(<span>$_GET</span>['mriID'<span>]); } </span><span>if</span> (<span>isset</span>(<span>$_GET</span>['dicomID'<span>])) { </span><span>$this</span>->view->dicomID=(<span>get_magic_quotes_gpc</span>())?<span>$_GET</span>['dicomID']:<span>addslashes</span>(<span>$_GET</span>['dicomID'<span>]); } </span><span>if</span> (<span>isset</span>(<span>$_GET</span>['JPGID'<span>])) { </span><span>$this</span>->view->JPGID=(<span>get_magic_quotes_gpc</span>())?<span>$_GET</span>['JPGID']:<span>addslashes</span>(<span>$_GET</span>['JPGID'<span>]); } www.jbxue.com </span><span>$dicomfile</span>=<span>new</span><span> dicomfile(); </span><span>$jpgfile</span>=<span>new</span><span> jpgfile(); </span><span>$mri</span>=<span>new</span><span> mri(); </span><span>if</span>(<span>$this</span>->view-><span>dicomID) { </span><span>$filename</span>=<span>$dicomfile</span>->find(<span>$this</span>->view->dicomID)-><span>toArray(); </span><span>$filename</span>=<span>$filename</span>[0]['filename'<span>]; } </span><span>else</span> <span>if</span>(<span>$this</span>->view-><span>JPGID) { </span><span>$filename</span>=<span>$jpgfile</span>->find(<span>$this</span>->view->JPGID)-><span>toArray(); </span><span>$filename</span>=<span>$filename</span>[0]['JPGname'<span>]; } </span><span>$dir</span>=<span>$mri</span>->find(<span>$this</span>->view->mriID)-><span>toArray(); </span><span>$dir</span>=<span>$dir</span>[0]['dicom_path'<span>]; </span><span>$file</span>=<span>$dir</span>.'/'.<span>$filename</span><span>; </span><span>if</span> (!<span>file_exists</span>(<span>$file</span><span>)) { </span><span>echo</span> "the file does not exist!"<span>; </span><span>exit</span><span>(); } </span><span>$file_size</span>=<span>filesize</span>(<span>$file</span><span>); </span><span>header</span>("Content-type: application/octet-stream"<span>); </span><span>header</span>("Accept-Ranges: bytes"<span>); </span><span>header</span>("Accept-Length:". <span>$file_size</span><span>); </span><span>header</span>("Content-Disposition: attachment; filename=".<span>$filename</span><span>); </span><span>$fp</span>=<span>fopen</span>(<span>$file</span>,"r"<span>); </span><span>if</span> (!<span>$fp</span><span>) </span><span>echo</span> "can't open file!"<span>; </span><span>$buffer_size</span>=1024<span>; </span><span>$cur_pos</span>=0<span>; </span><span>while</span> (!<span>feof</span>(<span>$fp</span>)&&<span>$file_size</span>-<span>$cur_pos</span>><span>$buffer_size</span><span>) { </span><span>$buffer</span>=<span>fread</span>(<span>$fp</span>,<span>$buffer_size</span><span>); </span><span>echo</span> <span>$buffer</span><span>; </span><span>$cur_pos</span>+=<span>$buffer_size</span><span>; } </span><span>$buffer</span>=<span>fread</span>(<span>$fp</span>,<span>$file_size</span>-<span>$cur_pos</span><span>); </span><span>echo</span> <span>$buffer</span><span>; </span><span>fclose</span>(<span>$fp</span><span>); }</span>
此时,download.phtml页面一定要是完全空白的。千万不要有任何内容(包括如下的固定信息:
<!DOCTYPE html <span>PUBLIC</span> "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>无标题文档</title>)否则,这些信息都将被下载到下载文件中,导致文件不能使用。

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

PHP에서 Password_hash 및 Password_Verify 기능을 사용하여 보안 비밀번호 해싱을 구현해야하며 MD5 또는 SHA1을 사용해서는 안됩니다. 1) Password_hash는 보안을 향상시키기 위해 소금 값이 포함 된 해시를 생성합니다. 2) Password_verify 암호를 확인하고 해시 값을 비교하여 보안을 보장합니다. 3) MD5 및 SHA1은 취약하고 소금 값이 부족하며 현대 암호 보안에는 적합하지 않습니다.

PHP 유형은 코드 품질과 가독성을 향상시키기위한 프롬프트입니다. 1) 스칼라 유형 팁 : PHP7.0이므로 int, float 등과 같은 기능 매개 변수에 기본 데이터 유형을 지정할 수 있습니다. 2) 반환 유형 프롬프트 : 기능 반환 값 유형의 일관성을 확인하십시오. 3) Union 유형 프롬프트 : PHP8.0이므로 기능 매개 변수 또는 반환 값에 여러 유형을 지정할 수 있습니다. 4) Nullable 유형 프롬프트 : NULL 값을 포함하고 널 값을 반환 할 수있는 기능을 포함 할 수 있습니다.

PHP는 주로 절차 적 프로그래밍이지만 객체 지향 프로그래밍 (OOP)도 지원합니다. Python은 OOP, 기능 및 절차 프로그래밍을 포함한 다양한 패러다임을 지원합니다. PHP는 웹 개발에 적합하며 Python은 데이터 분석 및 기계 학습과 같은 다양한 응용 프로그램에 적합합니다.

PHP는 웹 개발 및 빠른 프로토 타이핑에 적합하며 Python은 데이터 과학 및 기계 학습에 적합합니다. 1.PHP는 간단한 구문과 함께 동적 웹 개발에 사용되며 빠른 개발에 적합합니다. 2. Python은 간결한 구문을 가지고 있으며 여러 분야에 적합하며 강력한 라이브러리 생태계가 있습니다.

PHP는 1994 년에 시작되었으며 Rasmuslerdorf에 의해 개발되었습니다. 원래 웹 사이트 방문자를 추적하는 데 사용되었으며 점차 서버 측 스크립팅 언어로 진화했으며 웹 개발에 널리 사용되었습니다. Python은 1980 년대 후반 Guidovan Rossum에 의해 개발되었으며 1991 년에 처음 출시되었습니다. 코드 가독성과 단순성을 강조하며 과학 컴퓨팅, 데이터 분석 및 기타 분야에 적합합니다.

PHP는 현대화 프로세스에서 많은 웹 사이트 및 응용 프로그램을 지원하고 프레임 워크를 통해 개발 요구에 적응하기 때문에 여전히 중요합니다. 1.PHP7은 성능을 향상시키고 새로운 기능을 소개합니다. 2. Laravel, Symfony 및 Codeigniter와 같은 현대 프레임 워크는 개발을 단순화하고 코드 품질을 향상시킵니다. 3. 성능 최적화 및 모범 사례는 응용 프로그램 효율성을 더욱 향상시킵니다.

PHP의 핵심 이점에는 학습 용이성, 강력한 웹 개발 지원, 풍부한 라이브러리 및 프레임 워크, 고성능 및 확장 성, 크로스 플랫폼 호환성 및 비용 효율성이 포함됩니다. 1) 배우고 사용하기 쉽고 초보자에게 적합합니다. 2) 웹 서버와 우수한 통합 및 여러 데이터베이스를 지원합니다. 3) Laravel과 같은 강력한 프레임 워크가 있습니다. 4) 최적화를 통해 고성능을 달성 할 수 있습니다. 5) 여러 운영 체제 지원; 6) 개발 비용을 줄이기위한 오픈 소스.

phphassignificallyimpactedwebdevelopmentandextendsbeyondit
