JAX上傳的用戶體驗更好,HTML上傳用戶使用更方便一點,直接在網(wǎng)頁里面就能夠操作了。示例在下面提供了,是完整的源代碼,有教程,有視頻教程,基本上使用非常簡單,開發(fā)也非常簡單,有技術(shù)支持,
網(wǎng)上搜了一下,基本上講這塊的文章還是很多,但是就是一個字亂,講的很混亂。也沒有提供完整的前后端示例。
用戶上傳的文件比較大,有20G左右,直接用HTML傳的話容易失敗,服務(wù)器也容易出錯,需要分片,分塊,分割上傳。也就是將一個大的文件分成若干個小文件塊來上傳,另外就是需要實現(xiàn)秒傳功能和防重復(fù)功能,秒傳就是用戶如果上傳過這個文件,那么直接在數(shù)據(jù)庫中查找記錄就行了,不用再上傳一次,節(jié)省時間,實現(xiàn)的思路是對文件做MD5計算,將MD5值保存到數(shù)據(jù)庫,算法可以用MD5,或者CRC,或者SHA1,這個隨便哪個算法都行。
分片還需要支持?jǐn)帱c續(xù)傳,現(xiàn)在HTML5雖然提供了信息記錄功能,但是只支持到了會話級,也就是用戶不能關(guān)閉瀏覽器,也不能清空緩存。但是有的政府單位上傳大文件,傳了一半下班了,明天繼續(xù)傳,電腦一關(guān)結(jié)果進(jìn)度信息就丟失了,這個是他們的一個痛點。
切片的話還有一點就是在服務(wù)器上合并,一個文件的所有分片數(shù)據(jù)上傳完后需要在服務(wù)器端進(jìn)行合并操作。
1.下載示例
https://gitee.com/xproer/up6-vue-cli
將up6組件復(fù)制到項目中
示例中已經(jīng)包含此目錄
1.引入up6組件
2.配置接口地址
接口地址分別對應(yīng):文件初始化,文件數(shù)據(jù)上傳,文件進(jìn)度,文件上傳完畢,文件刪除,文件夾初始化,文件夾刪除,文件列表
參考:http://www.ncmem.com/doc/view.aspx?id=e1f49f3e1d4742e19135e00bd41fa3de
3.處理事件
啟動測試
啟動成功
效果
數(shù)據(jù)庫
ajax 是前后端交互的重要手段或橋梁。它不是一個技術(shù),是一組技術(shù)的組合。
ajax :a:異步;j:js;a:和;x:服務(wù)端的數(shù)據(jù)。
ajax的組成:
通過后臺與服務(wù)器進(jìn)行少量數(shù)據(jù)交換,ajax可以使網(wǎng)頁實現(xiàn)異步更新。也就是在不需要重新加載整個網(wǎng)頁的情況下,能夠更新部分網(wǎng)頁的技術(shù)。傳統(tǒng)的網(wǎng)頁不使用ajax,如果需要更新內(nèi)容,必須重新加載整個頁面。
ajax請求原理:創(chuàng)建一個網(wǎng)絡(luò)請求對象 -> 發(fā)送連接請求 -> 發(fā)送請求數(shù)據(jù) -> 檢查網(wǎng)絡(luò)請求對象的狀態(tài) -> 如果響應(yīng)成功了 -> 瀏覽器接收返回數(shù)據(jù)并更新網(wǎng)頁。接下來詳細(xì)介紹對象的創(chuàng)建以及它的方法。
XMLHttpRequest 對象,用于后臺與服務(wù)器之間的數(shù)據(jù)交換,意味著可以在不加載整個網(wǎng)頁的情況下,更新部分內(nèi)容或數(shù)據(jù)。現(xiàn)代瀏覽器基本都支持,但是低版本的IE不支持,如果我們考慮IE兼容問題創(chuàng)建對象的時候需要兼容創(chuàng)建。
考慮兼容時創(chuàng)建的對象:
var xhr ;
if( window.XMLHttpRequest ){ //檢查瀏覽器是否支持XMLHttpRequest
xhr = new XMLHttpRequest()
}else{
xhr = new ActiveXObject("Microsoft.XMLHTTP") //兼容IE6 IE5
}
3.1、open( )
設(shè)置請求的類型、請求接口、是否異步處理。
使用語法:open( method , url , async )
3.2、send( )
將請求發(fā)送到服務(wù)器。
使用語法:send( string )
使用發(fā)送方式不同的時候,傳輸數(shù)據(jù)添加方式也不同,所以我們介紹下分別為post和get時,數(shù)據(jù)是如何發(fā)送的?
3.3、提交方式
get發(fā)送請求時,需要傳給后臺的數(shù)據(jù)通過url來傳遞,多個參數(shù)之間使用 & 符號連接,使用時如下:
xhr.opn( "GET" , "1.php?name=hello&age=world" , true )
xhr.send()
使用 post 方式發(fā)送請求時,使用send來發(fā)送數(shù)據(jù),有時需要設(shè)置數(shù)據(jù)格式,類似表單那樣,此時可通過 setRequestHeader 設(shè)置發(fā)送的數(shù)據(jù)格式
xhr.setRequestHeader( "Content-type", "application/x-www-form-urlencoded")
Content-type常見類型:
readyState 存有 XMLHttpRequest 的狀態(tài),它的值從 0-4 發(fā)生變化,分別代表的意義:
每當(dāng) readyState 狀態(tài)值發(fā)生改變時會,就會觸發(fā) onreadystatechange 事件,對應(yīng)著每個狀態(tài)值就會被觸發(fā)五次。當(dāng)狀態(tài)值為 4 時表示網(wǎng)絡(luò)請求響應(yīng)完畢,就可以獲取返回的值。
xhr.onreadystateChange = function(){
if( xhr.readyState==4 ){
if( xhr.status>=200 && xhr.status<300 || xhr.status==304 ){
console.log("請求成功",xhr.responseXML)
}else{
console.log("請求失敗")
}
}
}
通常我們需要獲取服務(wù)器返回的信息,然后對我們的網(wǎng)頁做相對應(yīng)的結(jié)果展示,通常使用 XMLHttpRequest 的 responseText 或 responseXML 屬性。
responseText ---> 獲取到的是字符串形式。接收到可直接使用,無需轉(zhuǎn)換。
document.getElementById("myDiv").innerHTML=xmlhttp.responseText;
responseXML ---> 獲取到 XML 形式的數(shù)據(jù)。使用時需要解析,如:
<person>
<name>小米粒</name>
<age>18</age>
</person>
解析時:
document.getElementsByTagName("name")[0]
responseXML 目前已被 json 取代,所以作為了解就好。
var xhr ;
if( window.XMLHttpRequest ){
xhr = new XMLHttpRequest()
}else{
xhr = new ActiveXObject("Microsoft.XMLHTTP") //兼容IE6 IE5
}
xhr.open('GET','1.txt',true)
xhr.send()
xhr.onreadystatechange = function(){
if(xhr.readyState==4){
if(xhr.status>=200 && xhr.status<300 || xhr.status==304){
console.log("請求成功",xhr.response) // 請求成功 abc
}else{
console.log("請求失敗")
}
}
}
1.txt 文檔內(nèi)容為 abc。所以返回的結(jié)果也是abc
Web開發(fā)中,通過POST請求將數(shù)據(jù)發(fā)送給服務(wù)器是一種常見的方式。使用jQuery可以輕松地發(fā)送POST請求,這需要使用jQuery的ajax()方法。本文將介紹jQuery如何使用POST請求發(fā)送數(shù)據(jù),并提供一個實際的例子。
使用jQuery的ajax()方法發(fā)送POST請求需要設(shè)置以下屬性:
以下是一個示例代碼:
$.ajax({
url: 'https://example.com/api',
type: 'POST',
dataType: 'json',
data: {
name: 'Alice',
age: 25,
city: 'New York'
},
success: function(response) {
console.log(response);
},
error: function(jqXHR, textStatus, errorThrown) {
console.log('錯誤:' + errorThrown);
}
});
在上面的示例中,我們向URL為https://example.com/api的API發(fā)送一個POST請求,并攜帶一個JavaScript對象作為數(shù)據(jù)發(fā)送。
當(dāng)API響應(yīng)成功時,success()回調(diào)函數(shù)將被執(zhí)行,并將響應(yīng)數(shù)據(jù)作為參數(shù)傳遞。當(dāng)API響應(yīng)失敗時,error()回調(diào)函數(shù)被執(zhí)行,并將HTTP錯誤信息作為參數(shù)傳遞。
除了使用ajax()方法外,還可以使用jQuery的$.post()方法來發(fā)送POST請求,如下所示:
$.post('https://example.com/api', {
name: 'Alice',
age: 25,
city: 'New York'
}, function(response) {
console.log(response);
}, 'json');
使用$.post()方法時,第一個參數(shù)是請求URL,第二個參數(shù)是要發(fā)送的數(shù)據(jù),第三個參數(shù)是成功響應(yīng)后的回調(diào)函數(shù),最后一個參數(shù)是響應(yīng)數(shù)據(jù)類型。
在發(fā)送POST請求時,有時需要在請求頭中添加一些信息,例如身份驗證令牌或版本信息。可以使用以下代碼在請求中添加標(biāo)頭信息:
$.ajax({
url: 'https://example.com/api',
type: 'POST',
dataType: 'json',
contentType: 'application/json',
data: JSON.stringify({ name: 'Alice', age: 25 }),
headers: {
'Authorization': 'Token xxx',
'X-API-Version': '1'
},
success: function(response) {
console.log(response);
},
error: function(jqXHR, textStatus, errorThrown) {
console.log('錯誤:' + errorThrown);
}
});
在上面的示例中,我們將headers屬性添加到請求中,并在其中添加了Authorization和X-API-Version標(biāo)頭。
在contentType中傳遞的“application/json”指示我們發(fā)送的數(shù)據(jù)是JSON格式。data屬性使用JSON.stringify()方法將數(shù)據(jù)轉(zhuǎn)換為JSON字符串。
本文介紹了如何使用jQuery發(fā)送POST請求,并提供了簡單和帶標(biāo)頭信息的請求的實際示例。使用jQuery可以方便地向服務(wù)器發(fā)送數(shù)據(jù),并等待響應(yīng)。在實際開發(fā)中,我們通常會使用POST請求來提交表單數(shù)據(jù)、發(fā)送文件或與服務(wù)器進(jìn)行交互。
*請認(rèn)真填寫需求信息,我們會在24小時內(nèi)與您取得聯(lián)系。