這篇文章主要介紹了關於php檔案上傳及uploadifive的基本使用,有著一定的參考價值,現在分享給大家,有需要的朋友可以參考一下
本對不使用框架實作php上傳和使用uploadifive框架進行了小結
不使用框架實作檔上傳
簡單看了下菜鳥教學上的demo
檔案結構如下圖
form.html
<form action="upload_file.php" method="post" enctype="multipart/form-data"> <label for="file">文件名:</label> <input type="file" name="file" id="file"><br> <input type="submit" name="submit" value="提交"></form>
最基本的表單,不多說
upload_file.php
//允许上传的图片后缀 $allowedExts = array("gif","jpeg","jpg","png","doc"); $temp = explode(".",$_FILES["file"]["name"]); echo $_FILES["file"]["size"]; $extension = end($temp); if((($_FILES["file"]["type"] == "images/gif") ||($_FILES["file"]["type"] == "image/jpeg") ||($_FILES["file"]["type"] == "image/jpg") ||($_FILES["file"]["type"] == "image/pjpeg") ||($_FILES["file"]["type"] == "image/x-png") ||($_FILES["file"]["type"] == "image/png") ||($_FILES["file"]["type"] == "application/msword")) &&($_FILES["file"]["size"] < 204800) && in_array($extension,$allowedExts)){ if($_FILES["file"]["error"] > 0){ echo "错误:: ".$_FILES["file"]["error"]."<br>"; }else{ echo "上传文件名: ".$_FILES["file"]["name"]."<br>"; echo "文件类型: ".$_FILES["file"]["type"]."<br>"; echo "文件大小: ".($_FILES["file"]["size"]/1024)."kB<br>"; echo "文件临时存储的位置: ".$_FILES["file"]["tmp_name"]."<br>"; //判断当前目录下的upload目录是否存在 //如果没有upload目录, 你需要创建它,upload目录权限为 777 if(file_exists("upload/".$_FILES["file"]["name"])){ echo $_FILES["file"]["name"]."文件已经存在。"; }else{ //如果upload 目录不存在该文件则将文件上传到upload目录上s move_uploaded_file($_FILES["file"]["tmp_name"],"upload/".$_FILES["file"]["name"]); echo "文件存储在: "."upload/".$_FILES["file"]["name"]; } } }else{ echo "非法的文件格式"; }
也很好理解,核心函數只有一個move_uploaded_file(),而且它的程式碼都是些為篩選做準備的語句,也很容易理解。
方法介紹
bool move_uploaded_file ( string $filename , string $destination )
作用:
將上傳檔案移到新的位置。本函數檢查並確保由 filename 指定的檔案是合法的上傳檔案(即透過 PHP 的 HTTP POST 上傳機制所上傳的)。如果文件合法,則將其移至由 destination 指定的文件。
參數介紹:
$filename:上传文件的文件名
$destination:移动文件到这个位置
#使用uploadifive框架實作檔案上傳
引入所需的框架文件
<script src="../js/jquery-3.3.1.min.js" type="text/javascript"></script> <script src="jquery.uploadifive.min.js" type="text/javascript"></script> <link rel="stylesheet" type="text/css" href="uploadifive.css">
jquery和uploadifive的相關文件,沒有可去官網下載或找demo中文件。
建立表單
<form> <p id="queue"></p> <input id="file_upload" name="file_upload" type="file" multiple="true"> </form>
#在js中使用框架
<script type="text/javascript"> <?php $timestamp = time();?> $(function () { $('#file_upload').uploadifive({ 'auto' : true, //是否自动上传,默认true 'checkScript' : '\.\/js\/uploadify\/check-exists.php', //检查文件路径 'formData' : { 'timestamp' : '<?php echo $timestamp;?>', 'token' : '<?php echo md5('unique_salt'.$timestamp);?>', }, 'onInit' : function(){ $('p.uploadifive-button').show(); }, 'queueID' : 'queue', //进度条的显示位置 'uploadScript' : 'demo\/uploadifive.php', //上传路径脚本 'onUploadComplete' : function(file,data){ //文件上传成功后执 // console.log(file); }, 'onError' : function(errorType) { console.log(errorType); var msg = '文件上传有误'; switch(errorType) { case 'FORBIDDEN_FILE_TYPE': msg = '错误的上传文件类型'; break; } alert('错误提示: ' + msg); } }); }); </script>
本範例只使用了最基本一些屬性,實作了基本的上傳功能
相關推薦:
php檔案上傳類別及PHP封裝的多檔案上傳類別分享
以上是php檔案上傳及uploadifive的基本使用的詳細內容。更多資訊請關注PHP中文網其他相關文章!

PHP是一種服務器端腳本語言,用於動態網頁開發和服務器端應用程序。 1.PHP是一種解釋型語言,無需編譯,適合快速開發。 2.PHP代碼嵌入HTML中,易於網頁開發。 3.PHP處理服務器端邏輯,生成HTML輸出,支持用戶交互和數據處理。 4.PHP可與數據庫交互,處理表單提交,執行服務器端任務。

PHP在過去幾十年中塑造了網絡,並將繼續在Web開發中扮演重要角色。 1)PHP起源於1994年,因其易用性和與MySQL的無縫集成成為開發者首選。 2)其核心功能包括生成動態內容和與數據庫的集成,使得網站能夠實時更新和個性化展示。 3)PHP的廣泛應用和生態系統推動了其長期影響,但也面臨版本更新和安全性挑戰。 4)近年來的性能改進,如PHP7的發布,使其能與現代語言競爭。 5)未來,PHP需應對容器化、微服務等新挑戰,但其靈活性和活躍社區使其具備適應能力。

PHP的核心優勢包括易於學習、強大的web開發支持、豐富的庫和框架、高性能和可擴展性、跨平台兼容性以及成本效益高。 1)易於學習和使用,適合初學者;2)與web服務器集成好,支持多種數據庫;3)擁有如Laravel等強大框架;4)通過優化可實現高性能;5)支持多種操作系統;6)開源,降低開發成本。

PHP沒有死。 1)PHP社區積極解決性能和安全問題,PHP7.x提升了性能。 2)PHP適合現代Web開發,廣泛用於大型網站。 3)PHP易學且服務器表現出色,但類型系統不如靜態語言嚴格。 4)PHP在內容管理和電商領域仍重要,生態系統不斷進化。 5)通過OPcache和APC等優化性能,使用OOP和設計模式提升代碼質量。

PHP和Python各有優劣,選擇取決於項目需求。 1)PHP適合Web開發,易學,社區資源豐富,但語法不夠現代,性能和安全性需注意。 2)Python適用於數據科學和機器學習,語法簡潔,易學,但執行速度和內存管理有瓶頸。

PHP用於構建動態網站,其核心功能包括:1.生成動態內容,通過與數據庫對接實時生成網頁;2.處理用戶交互和表單提交,驗證輸入並響應操作;3.管理會話和用戶認證,提供個性化體驗;4.優化性能和遵循最佳實踐,提升網站效率和安全性。

PHP在數據庫操作和服務器端邏輯處理中使用MySQLi和PDO擴展進行數據庫交互,並通過會話管理等功能處理服務器端邏輯。 1)使用MySQLi或PDO連接數據庫,執行SQL查詢。 2)通過會話管理等功能處理HTTP請求和用戶狀態。 3)使用事務確保數據庫操作的原子性。 4)防止SQL注入,使用異常處理和關閉連接來調試。 5)通過索引和緩存優化性能,編寫可讀性高的代碼並進行錯誤處理。

在PHP中使用預處理語句和PDO可以有效防範SQL注入攻擊。 1)使用PDO連接數據庫並設置錯誤模式。 2)通過prepare方法創建預處理語句,使用佔位符和execute方法傳遞數據。 3)處理查詢結果並確保代碼的安全性和性能。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

記事本++7.3.1
好用且免費的程式碼編輯器

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。