亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > AJAX > 正文

Ajax配合Spring實現文件上傳功能代碼

2024-09-01 08:27:15
字體:
來源:轉載
供稿:網友

由于項目需要,開發一個可以上傳圖片到服務器的web表單頁面。

一、 需求

Web表單頁面,可以通過表單上傳圖片以及其他文字信息。

二、 圖片上傳的流程

之前沒有做過這類頁面,通過查詢資料。發現比較常見的做法,是先將圖片上傳到服務器端的某個文件目錄下,服務器向前臺返回圖片的存儲路徑;之后,前臺將圖片存儲路徑以及其他表單信息一起提交到服務器,所有的表單信息存儲在數據庫中。

三、 方法

由于項目需要,我這里介紹兩種圖片上傳方法,第一種是使用ajax對一個圖片直接上傳;第二種是先在前臺將圖片切割為較小的文件,之后使用ajax分別上傳圖片到服務器,服務器實現對文件的拼接。(方法二適合較大文件的上傳)下面我分別對兩種方法做介紹。

方法一: 直接上傳

1 html頁面

<pre name="code" class="html"><!DOCTYPE html> <head></head> <body> <form id="uploadForm" action="/PicSubmit/form" method="post" enctype="multipart/form-data" onsubmit="return submit_check()" class="bootstrap-frm" ></pre><pre name="code" class="html"><input id = "sid" type = "text" name="name" /></pre><pre name="code" class="html"><pre name="code" class="html"><input id = "fileImage" type = "file" name="filename" /></pre><pre name="code" class="html"><input id = "addressid" type = "hidden" name="address" /></pre><pre name="code" class="html"><input id="ajaxsub" type="button" class="button" value="上傳圖片" onclick="fileUpload()<span style="font-family: Arial, Helvetica, sans-serif;">" /> </span></pre><pre name="code" class="html"><input type="submit" class="button" value="提交表單" /> <input type="reset" class="button" value="重置表單" /> </pre></body></html><p></p> <pre></pre> <br> <pre></pre> 這一部分需要注意的是,form表單的enctype屬性必須設置為“multipart/form-data”,在Html5中,如果需要多張圖片一起上傳,可以在<input type="file"> 標簽中,增加multiple屬性,例如:<input type="file" id= “fileImage” multiple />。<br> <br> <br> <p></p> <p>2 js</p> <p>(1)js使用ajax提供的ajaxfileupload.js庫。這個庫使用起來還是比較方便的,和普通的ajax函數使用方法幾乎相同。首先,需要ajaxfileupload.js庫文件。這里需要注意,我之前在網上下載了一個ajaxfileupload.js文件不能用,浪費了很長時間,我直接把js庫文件粘貼到這里,方便分享。</p> <p></p><pre name="code" class="javascript">// JavaScript Document</pre><pre name="code" class="javascript">// ajax file uplaod jQuery.extend({   createUploadIframe: function(id, uri)   {     //create frame     var frameId = 'jUploadFrame' + id;     if(window.ActiveXObject) {       var io = document.createElement('<iframe id="' + frameId + '" name="' + frameId + '" />');       if(typeof uri== 'boolean'){         io.src = 'javascript:false';       }       else if(typeof uri== 'string'){         io.src = uri;       }     }     else {       var io = document.createElement('iframe');       io.id = frameId;       io.name = frameId;     }     io.style.position = 'absolute';     io.style.top = '-1000px';     io.style.left = '-1000px';     document.body.appendChild(io);     return io;   },   createUploadForm: function(id, fileElementId)   {     //create form     var formId = 'jUploadForm' + id;     var fileId = 'jUploadFile' + id;     var form = jQuery('<form action="" method="POST" name="' + formId + '" id="' + formId + '" enctype="multipart/form-data"></form>');     var oldElement = jQuery('#' + fileElementId);     var newElement = jQuery(oldElement).clone();     jQuery(oldElement).attr('id', fileId);     jQuery(oldElement).before(newElement);     jQuery(oldElement).appendTo(form);     //set attributes     jQuery(form).css('position', 'absolute');     jQuery(form).css('top', '-1200px');     jQuery(form).css('left', '-1200px');     jQuery(form).appendTo('body');     return form;   },   ajaxFileUpload: function(s) {     // TODO introduce global settings, allowing the client to modify them for all requests, not only timeout      s = jQuery.extend({}, jQuery.ajaxSettings, s);     var id = s.fileElementId;     var form = jQuery.createUploadForm(id, s.fileElementId);     var io = jQuery.createUploadIframe(id, s.secureuri);     var frameId = 'jUploadFrame' + id;     var formId = 'jUploadForm' + id;     if( s.global && ! jQuery.active++ )     {       // Watch for a new set of requests       jQuery.event.trigger( "ajaxStart" );     }     var requestDone = false;     // Create the request object     var xml = {};     if( s.global )     {       jQuery.event.trigger("ajaxSend", [xml, s]);     }     var uploadCallback = function(isTimeout)     {       // Wait for a response to come back       var io = document.getElementById(frameId);       try       {         if(io.contentWindow)         {           xml.responseText = io.contentWindow.document.body?io.contentWindow.document.body.innerHTML:null;           xml.responseXML = io.contentWindow.document.XMLDocument?io.contentWindow.document.XMLDocument:io.contentWindow.document;         }else if(io.contentDocument)         {           xml.responseText = io.contentDocument.document.body?io.contentDocument.document.body.innerHTML:null;           xml.responseXML = io.contentDocument.document.XMLDocument?io.contentDocument.document.XMLDocument:io.contentDocument.document;         }       }catch(e)       {         jQuery.handleError(s, xml, null, e);       }       if( xml || isTimeout == "timeout")       {         requestDone = true;         var status;         try {           status = isTimeout != "timeout" ? "success" : "error";           // Make sure that the request was successful or notmodified           if( status != "error" )           {             // process the data (runs the xml through httpData regardless of callback)             var data = jQuery.uploadHttpData( xml, s.dataType );             if( s.success )             {               // ifa local callback was specified, fire it and pass it the data               s.success( data, status );             };             if( s.global )             {               // Fire the global callback               jQuery.event.trigger( "ajaxSuccess", [xml, s] );             };           } else           {             jQuery.handleError(s, xml, status);           }         } catch(e)         {           status = "error";           jQuery.handleError(s, xml, status, e);         };         if( s.global )         {           // The request was completed           jQuery.event.trigger( "ajaxComplete", [xml, s] );         };         // Handle the global AJAX counter         if(s.global && ! --jQuery.active)         {           jQuery.event.trigger("ajaxStop");         };         if(s.complete)         {           s.complete(xml, status);         } ;         jQuery(io).unbind();         setTimeout(function()         { try         {           jQuery(io).remove();           jQuery(form).remove();         } catch(e)         {           jQuery.handleError(s, xml, null, e);         }         }, 100);         xml = null;       };     }     // Timeout checker     if( s.timeout > 0 )     {       setTimeout(function(){         if( !requestDone )         {           // Check to see ifthe request is still happening           uploadCallback( "timeout" );         }       }, s.timeout);     }     try     {       var form = jQuery('#' + formId);       jQuery(form).attr('action', s.url);       jQuery(form).attr('method', 'POST');       jQuery(form).attr('target', frameId);       if(form.encoding)       {         form.encoding = 'multipart/form-data';       }       else       {         form.enctype = 'multipart/form-data';       }       jQuery(form).submit();     } catch(e)     {       jQuery.handleError(s, xml, null, e);     }     if(window.attachEvent){       document.getElementById(frameId).attachEvent('onload', uploadCallback);     }     else{       document.getElementById(frameId).addEventListener('load', uploadCallback, false);     }     return {abort: function () {}};   },   uploadHttpData: function( r, type ) {     var data = !type;     data = type == "xml" || data ? r.responseXML : r.responseText;     // ifthe type is "script", eval it in global context     if( type == "script" )     {       jQuery.globalEval( data );     }     // Get the JavaScript object, ifJSON is used.     if( type == "json" )     {       eval( "data = " + data );     }     // evaluate scripts within html     if( type == "html" )     {       jQuery("<div>").html(data).evalScripts();     }     return data;   },   handleError: function( s, xhr, status, e )   {     // If a local callback was specified, fire it      if ( s.error ) {       s.error.call( s.context || s, xhr, status, e );     }     // Fire the global callback     if ( s.global ) {       (s.context ? jQuery(s.context) : jQuery.event).trigger( "ajaxError", [xhr, s, e] );     }   } });</pre><p></p> <p><br> </p>             
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美激情亚洲国产| 亚洲男人天堂2024| 久久91亚洲精品中文字幕奶水| 精品无人区太爽高潮在线播放| 亚洲欧美在线看| 日韩高清中文字幕| 久久久精品网站| 国产精品男人的天堂| 欧美激情手机在线视频| 日韩av在线精品| 亚洲欧美视频在线| 色琪琪综合男人的天堂aⅴ视频| 亚洲人成电影网站色…| 久久国产精品久久国产精品| 国产成人91久久精品| 欧美精品福利在线| 91久久精品在线| 美女性感视频久久久| 欧美亚洲另类视频| 久久天天躁狠狠躁夜夜躁| 亚洲qvod图片区电影| 久久在线观看视频| 久久69精品久久久久久国产越南| xvideos亚洲人网站| 日韩在线中文视频| 亚洲国产成人精品一区二区| 午夜精品在线观看| 色综合伊人色综合网站| 久久久久久有精品国产| 亚洲石原莉奈一区二区在线观看| 欧美视频中文字幕在线| 原创国产精品91| 国产精品视频久久久| 97久久久免费福利网址| 久久久精品国产网站| 亚洲 日韩 国产第一| 日韩av在线免费播放| 国产精品人成电影| 亚洲综合中文字幕68页| 欧美极品第一页| 色婷婷综合久久久久中文字幕1| 欧美最猛性xxxxx(亚洲精品)| 国产精品网红直播| 国产一区二区在线免费视频| 久久久国产一区二区三区| 亚洲精品黄网在线观看| 国产精品久久综合av爱欲tv| 日本精品久久久久影院| 欧美日韩激情美女| 中文字幕亚洲自拍| 成人av资源在线播放| 亚洲深夜福利在线| 日韩av片永久免费网站| 精品福利在线看| 欧美成年人视频网站欧美| 欧美成人精品在线播放| 成人激情春色网| 亚洲二区在线播放视频| 欧美日韩综合视频网址| 国产精品午夜国产小视频| 欧美日韩一区免费| 在线播放国产一区中文字幕剧情欧美| 久久久久久国产三级电影| 欧洲日韩成人av| 欧美性受xxxx白人性爽| 亚洲成人免费在线视频| 国产视频精品一区二区三区| 亚洲大胆人体在线| 久久久久久亚洲精品不卡| 欧美另类精品xxxx孕妇| 国产一区二区视频在线观看| 欧美性猛交xxxx| 欧美激情三级免费| 国产美女主播一区| 日韩激情av在线免费观看| 亚洲乱码国产乱码精品精天堂| 欧美激情喷水视频| 亚洲成人教育av| 亚洲aa中文字幕| 欧美日韩国产成人在线| 日韩小视频网址| 91经典在线视频| 日韩电影中文 亚洲精品乱码| 红桃视频成人在线观看| 欧美日韩国产成人高清视频| 色偷偷888欧美精品久久久| 欧美大片免费看| 日韩毛片在线看| 久热精品视频在线| 91av在线免费观看视频| 色婷婷综合成人av| 欧美国产欧美亚洲国产日韩mv天天看完整| 欧美激情一区二区三区在线视频观看| 久久久999精品免费| 欧洲亚洲女同hd| 中文字幕日韩免费视频| 欧美裸体xxxx极品少妇| 欧美国产日本高清在线| 亚洲va电影大全| 日韩av电影国产| 欧美激情亚洲一区| 国产综合久久久久| 欧美精品制服第一页| 欧美丝袜一区二区| 日韩在线观看网址| 亚洲人线精品午夜| 免费成人高清视频| 日产日韩在线亚洲欧美| 欧美专区在线观看| 九九综合九九综合| 欧美第一淫aaasss性| 亚洲一区二区三| 国产精品视频最多的网站| 欧美日韩一区免费| 精品久久久中文| 国模精品一区二区三区色天香| 国产精品自拍小视频| 久久精品国产欧美亚洲人人爽| xvideos亚洲人网站| 成人精品视频99在线观看免费| 成人做爰www免费看视频网站| 97av在线影院| 综合国产在线观看| 日韩电影中文 亚洲精品乱码| 国产精品丝袜久久久久久不卡| 精品国产一区av| 欧美有码在线视频| 亚洲自拍偷拍福利| 久久亚洲电影天堂| 国产在线观看91精品一区| 狠狠躁夜夜躁人人爽天天天天97| 色综合男人天堂| 91影院在线免费观看视频| 久久天天躁狠狠躁夜夜av| 亚洲精品久久久久中文字幕欢迎你| 日韩精品视频免费在线观看| 国内精品免费午夜毛片| 亚洲激情视频在线观看| 久久久久久国产精品三级玉女聊斋| 亚洲精选在线观看| 日韩精品视频中文在线观看| 久久韩国免费视频| 国产欧美日韩91| 日韩视频免费大全中文字幕| 日本电影亚洲天堂| 亚洲欧洲午夜一线一品| 亚洲精品乱码久久久久久金桔影视| 92看片淫黄大片欧美看国产片| 久久电影一区二区| 日韩亚洲精品电影| 亚洲精品久久久久久久久久久久| 国产亚洲一区二区精品| 久久久久久成人| 日韩**中文字幕毛片| 色琪琪综合男人的天堂aⅴ视频| 国产精品久久久久久久久久久久久| 国产精品一区二区三区成人| 91精品国产色综合| 国产精品久久久久9999| 日韩成人中文字幕在线观看| 欧美激情国产日韩精品一区18| 精品国产福利视频| 欧美日韩国产综合新一区| 91手机视频在线观看|