Jquery+AJAX實(shí)現(xiàn)無刷新上傳并重命名文件操作示例【PHP后臺(tái)接收】
本文實(shí)例講述了Jquery+AJAX實(shí)現(xiàn)無刷新上傳并重命名文件操作。分享給大家供大家參考,具體如下:
index.html
<!DOCTYPE html> <html> <head> <title>Ajax上傳圖片</title> <meta charset="utf-8"> <script src="https://www.jq22.com/jquery/jquery-3.3.1.js"></script> </head> <body> <h1>Ajax上傳圖片</h1> <!-- 表單 --> <form id="form" enctype="multipart/form-data"> <input type="file" id="fileAttach" name="file"/> <input type="button" onclick="upload()" value="上傳"/> </form> <!-- 顯示結(jié)果 --> <h2 id="upload-result"></h2> <!-- 顯示圖片 --> <div id="imgdiv"></div> <!-- Ajax上傳 --> <script> function upload(){ var form = new FormData(document.getElementById("form")); $.ajax({ url:"upload.php", type:"post", data:form, cache: false, processData: false, contentType: false, success:function(data){ if (data.res == "400") { $("#upload-result").text("上傳成功"); $("#imgdiv").html("<img src=\"upload/"+data.path+"\"/>"); }else if (data.res == "403") { $("#upload-result").text("格式不對(duì)"); }else if (data.res == "404") { $("#upload-result").text("上傳錯(cuò)誤"); } }, error:function(data){ alert("上傳失敗") } }) } </script> </body> </html>
upload.php
<?php header("Content-type:application/json"); //獲取原始文件名 $filename = $_FILES["file"]["name"]; //獲取文件后綴名 $hzm = substr($filename,strpos($filename,".")); //設(shè)置新文件名 $newfilename = substr(str_shuffle("QWERTYUIOPASDFGHJKLZXCVBNMqwertyuiopasdfghjklzxcvbnm"),26,10); // 允許上傳的圖片后綴 $allowedExts = array("gif", "jpeg", "jpg", "png"); $temp = explode(".", $filename); $extension = end($temp); if ((($_FILES["file"]["type"] == "image/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"]["size"] < 2048000) // 小于 2000 kb && in_array($extension, $allowedExts)) { if ($_FILES["file"]["error"] > 0) { echo "{\"res\":\"404\"}"; } else { // 此處可以輸出文件的詳細(xì)信息 if (file_exists("upload/" . $newfilename.$hzm)) { // } else { move_uploaded_file($_FILES["file"]["tmp_name"], "upload/" . $newfilename.$hzm); echo "{\"path\":\"$newfilename$hzm\",\"res\":\"400\"}"; } } } else { echo "{\"res\":\"403\"}"; } ?>
請(qǐng)?jiān)诋?dāng)前目錄建立upload文件夾用于存放上傳后的圖片
GiF Demo
更多關(guān)于jQuery相關(guān)內(nèi)容可查看本站專題:《jquery中Ajax用法總結(jié)》、《jQuery擴(kuò)展技巧總結(jié)》、《jQuery常用插件及用法總結(jié)》、《jQuery常見經(jīng)典特效匯總》及《jquery選擇器用法總結(jié)》
希望本文所述對(duì)大家jQuery程序設(shè)計(jì)有所幫助。
- PHP下ajax跨域的解決方案之window.name實(shí)例分析
- PHP ajax跨子域的解決方案之document.domain+iframe實(shí)例分析
- PHP下ajax跨域的解決方案之jsonp實(shí)例分析
- PHP處理Ajax請(qǐng)求與Ajax跨域問題
- jquery ajax結(jié)合thinkphp的getjson實(shí)現(xiàn)跨域的方法
- PHP中運(yùn)用jQuery的Ajax跨域調(diào)用實(shí)現(xiàn)代碼
- php+mysql+ajax 局部刷新點(diǎn)贊/取消點(diǎn)贊功能(每個(gè)賬號(hào)只點(diǎn)贊一次)
- PHP使用ajax的post方式下載excel文件簡(jiǎn)單示例
- PHP Ajax跨域問題解決方案代碼實(shí)例
相關(guān)文章
Jquery ajaxsubmit上傳圖片實(shí)現(xiàn)代碼
這是數(shù)月前的事情了,場(chǎng)景是這樣的: 在進(jìn)行圖片上傳的時(shí),我發(fā)現(xiàn)開發(fā)人員使用的上傳圖片方式是Iframe + 傳統(tǒng)的 http post 來處理的。2010-11-11jquery操作checkbox火狐下第二次無法勾選的解決方法
這篇文章主要介紹了jquery操作checkbox火狐下第二次無法勾選問題的解決方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-10-10通過jquery的ajax請(qǐng)求本地的json文件方法
今天小編就為大家分享一篇通過jquery的ajax請(qǐng)求本地的json文件方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-08-08jquery獲取table中的某行全部td的內(nèi)容方法
jquery獲取table中的某行全部td的內(nèi)容方法,需要的朋友可以參考一下2013-03-03