借助FileReader實(shí)現(xiàn)將文件編碼為Base64后通過AJAX上傳
使用AJAX是無法直接上傳文件的,一般都是新建個(gè)iframe在它里面完成表單提交的過程以達(dá)到異步上傳文件的效果。
如此做可以達(dá)到比較好的瀏覽器兼容性,不過代碼量會(huì)比較大,即使是使用了文件上傳插件,例如plupload。
如何能達(dá)到靈活的程度呢,能像普通的AJAX提交表單數(shù)據(jù)那樣將文件看成是普通表單參數(shù)來對(duì)待就好了。
靈光一閃,利用javascript的FileReader對(duì)象將文件編碼成base64再傳服務(wù)器不就行了么~
開始動(dòng)手,豐衣足食。
前端對(duì)文件進(jìn)行base64編碼并通過ajax向服務(wù)器傳輸:
<head>
<meta charset="UTF-8">
</head>
<form onsubmit="return false;">
<input type="hidden" name="file_base64" id="file_base64">
<input type="file" id="fileup">
<input type="submit" value="submit" onclick="$.post('./uploader.php', $(this).parent().serialize());">
</form>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
<script>
$(document).ready(function(){
$("#fileup").change(function(){
var v = $(this).val();
var reader = new FileReader();
reader.readAsDataURL(this.files[0]);
reader.onload = function(e){
console.log(e.target.result);
$('#file_base64').val(e.target.result);
};
});
});
</script>
后端對(duì)文件數(shù)據(jù)解碼并保存:
<?php
if (isset($_POST['file_base64'])){
$file_base64 = $_POST['file_base64'];
$file_base64 = preg_replace('/data:.*;base64,/i', '', $file_base64);
$file_base64 = base64_decode($file_base64);
file_put_contents('./file.save', $file_base64);
}
javascript里的FileReader對(duì)象主流瀏覽器都支持,IE10以上支持,私認(rèn)為在為小范圍提供服務(wù)時(shí)可以考慮這個(gè)異步上傳文件的方式,省時(shí)又省力,兼容IE系列另當(dāng)別論。
- JavaSctit 利用FileReader和濾鏡上傳圖片預(yù)覽功能
- JavaScript中的FileReader圖片預(yù)覽上傳功能實(shí)現(xiàn)代碼
- JS+HTML5 FileReader實(shí)現(xiàn)文件上傳前本地預(yù)覽功能
- JavaScript html5利用FileReader實(shí)現(xiàn)上傳功能
- 基于JavaScript FileReader上傳圖片顯示本地鏈接
- javascript HTML5文件上傳FileReader API
- 談?wù)劵趇frame、FormData、FileReader三種無刷新上傳文件的方法
- javascript結(jié)合fileReader 實(shí)現(xiàn)上傳圖片
- File, FileReader 和 Ajax 文件上傳實(shí)例分析(php)
- JavaScript使用FileReader實(shí)現(xiàn)圖片上傳預(yù)覽效果
相關(guān)文章
基于javascript的無縫滾動(dòng)動(dòng)畫1
這篇文章主要介紹了基于javascript的無縫滾動(dòng)動(dòng)畫實(shí)現(xiàn),文章通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08
原生JS實(shí)現(xiàn)簡(jiǎn)單計(jì)算器功能
這篇文章主要為大家詳細(xì)介紹了原生JS實(shí)現(xiàn)簡(jiǎn)單計(jì)算器功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-04-04
基于RequireJS和JQuery的模塊化編程日常問題解析
本文是小編日常收集整理些有關(guān)RequireJS和JQuery的模塊化編程,感興趣的朋友一起學(xué)習(xí)吧2016-04-04

