[UPLOAD mechanism explanation] FileUpload

zhaozj2021-02-16  58

When writing a website program, the section is written in the website, and there will be only the communication between the Client and Server, and there will be binary file transfer. How to transfer in HTML Form, it is necessary to comply with RFC 1867. .

Basically, post.jsp should have a similar HTML TAG below:

Input Your name:

Select the file:

This part is a category of HTML, interested in drilling RFC ...

Section 02 Multipart / Form-Data HTTP Performance Situation

When you press the transfer, Browser will send post's information to Server.

POST

Http: // localhost: 9000 / fileupload / upload.jsp HTTP / 1.1

Accept: image / gif, image / x-xbitmap, image / jpeg, image / pjpeg, application / vnd.ms-powerpoint, application / vnd.ms-excel, application / msword, * / *

Referr:

Http: // localhost: 9000 / fileupload / post.jsp

Accept-language: zh-tw, zh-cn; q = 0.7, en-us; q = 0.3

CONTENT-TYPART / FORM-DATA; Boundary = --------------------------- 7d33E580784

Accept-encoding: Gzip, deflate

User-agent: mozilla / 4.0 (compatible; msie 6.0; windows NT 5.0)

Host: www.softleader.com.tw

Content-Length: 3020

Connection: Keep-alive

Cache-Control: No-cache

Cookie: jsessionid = 3b31f07f56328e7b623a9ba1c4e3479d

We can know that contet-type is the transfer of Boundary with multipart / form-data.

Section 03 actual example

file upload </ title></p> <p><meta http-equiv = "content-type" content = "text / html; charSet = big5"></p> <p></ hEAD></p> <p><body bgcolor = "# ffffff" text = "# 000000"> <p> <font size = "5" color = "# ff0000"></p> <p><b> Chapter 7 Archives Upload Example </ b> </ font> </ p> <form name = "form1" encTy = "multipart / form-data" method = "post" action = "jyfile.jsp"></p> <p><p> Upload file 1: <input type = "file" name = "file1" size = "20" maxlength = "20"> </ p></p> <p><p> Archive 1 Narrative: <input type = "text" name = "file1" size = "30" maxlength = "50"> </ p></p> <p><p> Upload file 2: <input type = "file" name = "file2" size = "20" maxlength = "20"> </ p></p> <p><p> Archive 2 Narration: <input type = "text" name = "file2" size = "30" maxlength = "50"> </ p></p> <p><p> Upload Archive 3: <input type = "file" name = "file3" size = "20" maxlength = "20"> </ p></p> <p><p> Archive 3 Narration: <input type = "text" name = "file3" size = "30" maxlength = "50"> </ p></p> <p><p> <input type = "submit" value = "Upload"> <input type = "reset" value = "Clear"> </ p></p> <p></ form></p> <p></ body></p> <p></ html></p> <p>This picture only shows part, please click View Full Picture</p> <p>= 514) WINDOW.OPEN (this.SRC); Else Return False; "HSPACE = 2 SRC =" http: //hi1-pass-ren/log/uploadimg/fileupload-1.gif "οnlοad =" ing (this. Width> = 514) {this.style.cursor = 'Hand'; this.alt = '!!! This image only shows part, please click View Full Picture !!!'; this.previoussibling.Style.Display = '' ;} "vspace = 2 border = 0></p> <p>Section 04 Transfer format</p> <p>Post /neWSpaper/JYFILE.JSP HTTP / 1.1</p> <p>Accept: image / gif, image / x-xbitmap, image / jpeg, image / pjpeg, application / vnd.ms-powerpoint, application / vnd.ms-excel, application / msword, * / *</p> <p>Referr:</p> <p>Http: // localhost: 9000 / newspaper / jyfile.html</p> <p>Accept-language: zh-tw, zh-cn; q = 0.7, en-us; q = 0.3</p> <p>CONTENT-TYPART / FORM-DATA; Boundary = --------------------------- 7D31091C6205FC</p> <p>Accept-encoding: Gzip, deflate</p> <p>User-agent: mozilla / 4.0 (compatible; msie 6.0; windows NT 5.0)</p> <p>Host: Localhost: 9000</p> <p>Content-Length: 428583</p> <p>Connection: Keep-alive</p> <p>Cache-Control: No-cache</p> <p>Cookie: jsessionid = E141744815A8FF44F8AA9BA6D5946710</p> <p>---------------------------- 7D31091C6205FC</p> <p>Content-disposition: form-data; name = "file1"; filename = "c: / test / test .exe" Content-Type: Application / OcTet-stream</p> <p>XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX (binary garbled)</p> <p>---------------------------- 7D31091C6205FC</p> <p>Content-disposition: form-data; name = "file1" EXE</p> <p>---------------------------- 7D31091C6205FC</p> <p>Content-disposition: form-data; name = "file2"; filename = "c: / test / test .gif"</p> <p>Content-Type: Image / GIF</p> <p>XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX (binary garbled)</p> <p>---------------------------- 7D31091C6205FC</p> <p>Content-disposition: form-data; Name = "file2"</p> <p>GIF</p> <p>---------------------------- 7D31091C6205FC</p> <p>Content-disposition: form-data; name = "file3"; filename = "c: / test / test.xls"</p> <p>Content-Type: Application / VND.MS-Excel</p> <p>XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX (binary garbled)</p> <p>---------------------------- 7D31091C6205FC</p> <p>Content-disposition: form-data; name = "file3"</p> <p>XLS</p> <p>----------------------------- 7D31091C6205FC -</p> <p>Section 05 to jyfile.jsp</p> <p><% @ Page ContentType = "text / html; charset = big5" language = "java"%> <% @ page import = "java.io. *"%></p> <p><% @ Page Import = "java.util. *"%></p> <p><% @ Page import = "org.apache.commons.fileUpload. *"%></p> <p><%</p> <p>// Declare the file to place the file to the server / .... / upload directory</p> <p>String savedirectory = "c: //";</p> <p>/ / Declaration Temporary Directory</p> <p>String tmpdirectory = "c: //";</p> <p>// Declaration to the total size of the files, the unit is BYTE, -1 means unlimited</p> <p>INT MAXPOSTSIZE = 1024 * 1024;</p> <p>%></p> <p><%</p> <p>// Declare a variable in which the store is described</p> <p>String FileDescription = NULL;</p> <p>// Declare a variable in the store name</p> <p>String filename = NULL;</p> <p>// Declare the variables of the stored upload file size</p> <p>Long filesis = 0;</p> <p>// Declare the variables of the stored upload file</p> <p>String contentType = NULL;</p> <p>/ / Calculate the number of uploaded files</p> <p>INT count = 0;</p> <p>%></p> <p><%</p> <p>DiskfileUpload Upload ();</p> <p>// Set the size of the memory store, exceed the write file, have a set temporary directory, the temporary file is placed in the temporary directory</p> <p>Upload.setsizethreshold (4096);</p> <p>/ / Set the total upload size limit</p> <p>Upload.setsizemax;</p> <p>// Set the temporary directory</p> <p>Upload.setRepositoryPath (TMPDIRECTORY);</p> <p>List / * fileItem * / items = UPLOAD.PARSEREQUEST (REQUEST);</p> <p>%></p> <p><body></p> <p><%</p> <p>Iterator it = items.iterator ();</p> <p>INT TMP = 0;</p> <p>FileItem TmpInm = NULL;</p> <p>While (item.hasnext ())</p> <p>{</p> <p>TMP ;</p> <p>FILEITEM ITEM = (FileItem) iter.next ();</p> <p>IF (item.isformfield ()) {</p> <p>// If it is a general field, get a file narrative</p> <p>FileDescription = item.getstring ();</p> <p>} Else {</p> <p>/ / Otherwise get a file information</p> <p>FILENAME = item.getname ();</p> <p>// Because different browsers will pass Path FileName, some only FileName</p> <p>Try {</p> <p>// for Wintel Platform</p> <p>FILENAME = filename.substring (filename.lastindexof ("//") 1);</p> <p>// for UNIX-LIKE Platform</p> <p>FileName = filename.substring (filename.lastindexof ("/") 1);</p> <p>} Catch (exception ex) {</p> <p>Out.println (ex);</p> <p>}</p> <p>Contenttype = item.getContentType (); filesis = item.getsize ();</p> <p>TmpItem = Item;</p> <p>}</p> <p>// Because a file is two fields, each read two fields are handled once</p> <p>IF (TMP == 2 && FileSize! = 0)</p> <p>{</p> <p>COUNT ;</p> <p>%></p> <p><font color = "red"> You uploaded by <% = count%> profile: </ font> <br></p> <p>The file name is: <% = filename%> <br></p> <p>The size of the file is: <% = filesize%> Bytes <br></p> <p>Archive type: <% = contenttype%> <br></p> <p>Description file: <% = FileDescription%> <br> <br></p> <p><%</p> <p>// write the archive into the archive directory</p> <p>Try {</p> <p>Out.println (filename);</p> <p>FILE UPLOADEDFILE = New File (SaveDirectory FileName);</p> <p>TmpItem.write (UPLOADEDFILE);</p> <p>} Catch (exception ex) {</p> <p>Out.println (ex);</p> <p>}</p> <p>TMP = 0;</p> <p>} Else if (tmp == 2 && filesis == 0) {</p> <p>TMP = 0;</p> <p>} // end if</p> <p>} // End while</p> <p>%></p> <p>You have uploaded <font color = "red"> <% = count%> </ font> file</p> <p></ body></p> <p></ html></p> <p>This picture only shows part, please click View Full Picture</p> <p>= 514) WINDOW.OPEN (THIS.SRC); Else Return False; "HSPACE = 2 SRC =" http: //hi1-pass-ren/log/uploadimg/fileupload-2.gif "οnlοad =" if (this. Width> = 514) {this.style.cursor = 'Hand'; this.alt = '!!! This image only shows part, please click View Full Picture !!!'; this.previoussibling.Style.Display = '' ;} "vspace = 2 border = 0></p> <p>Section 06 Struts fileupload</p> <p>Why do Struts 1.1 should I wait for Commons-FileUpload 1.0?</p> <p>Because Struts has a Subpackage called org.apache.struts.upload. *; This is the setting-related File format If you use struts for MVC Framework, you can refer to the development of Struts-Upload.war in Example.</p> <p>(1) Establish UPLOAD.JSP</p> <p><html: form action = "Upload.do?queryparam=su" ENCTYPE = "Multipart / Form-Data"></p> <p>File description: <html: text property = "theText" /> <br> select the file: <html: file property = "theFile" /> <br></p> <p></ html: form></p> <p>(2) Establish uplineform.java</p> <p>Public class uploadform extends actionform {</p> <p>........</p> <p>Public string getthetext () {</p> <p>Return Thet;</p> <p>}</p> <p>Public void setthetxt (string thetext) {</p> <p>THIS.THETEXT = Thet;</p> <p>}</p> <p>Public Formfile getthefile () {</p> <p>Return thefile;</p> <p>}</p> <p>Public void setthefile (formfile thefile) {</p> <p>THIS.THEFILE = Thefile;</p> <p>}</p> <p>........</p> <p>}</p> <p>Note that formfile is built in org.apache.struts.upload in package</p> <p>(3) Write uploadAction</p> <p>Public ActionForward Execute (ActionMapping Mapping,</p> <p>Actionform Form,</p> <p>HTTPSERVLETREQUEST REQUEST,</p> <p>HttpservletResponse response) {</p> <p>UPLOADFORM Theform = (UPLOADFORM) Form;</p> <p>String text = theform.getthetext ();</p> <p>Formfile file = theform.getthefile ();</p> <p>String filename = file.getfilename ();</p> <p>String contenttype = file.getContentType ();</p> <p>String size = (file.getfilesize () "bytes");</p> <p>.... // See how you handle</p> <p>.... // You can use InputStream to get file.getinputstream, etc.</p> <p>Return mapping.findforward ("thepageyouwannago");</p> <p>}</p> <p>(4) Establish struts-config.xml</p> <p><form-beneans></p> <p><form-bean name = "Uploadform"</p> <p>TYPE = "org.apache.struts.Webapp.upload.uploadform" /></p> <p></ form-beans></p> <p><action-mappings></p> <p><! - UPLOAD ACTION -></p> <p><action path = "/ upload" type = "org.apache.struts.Webapp.upload.uploadaction"</p> <p>Name = "UploadForm" Scope = "Request" Input = "/ Upload.jsp"></p> <p><forward name = "display" path = "/ display.jsp" /></p> <p></ action></p> <p>For details, please download Struts 1.1 SRC Review Content</p> <p>Section 06 Summary</p></div><div class="text-center mt-3 text-grey"> 转载请注明原文地址:https://www.9cbs.com/read-18863.html</div><div class="plugin d-flex justify-content-center mt-3"></div><hr><div class="row"><div class="col-lg-12 text-muted mt-2"><i class="icon-tags mr-2"></i><span class="badge border border-secondary mr-2"><h2 class="h6 mb-0 small"><a class="text-secondary" href="tag-2.html">9cbs</a></h2></span></div></div></div></div><div class="card card-postlist border-white shadow"><div class="card-body"><div class="card-title"><div class="d-flex justify-content-between"><div><b>New Post</b>(<span class="posts">0</span>) </div><div></div></div></div><ul class="postlist list-unstyled"> </ul></div></div><div class="d-none threadlist"><input type="checkbox" name="modtid" value="18863" checked /></div></div></div></div></div><footer class="text-muted small bg-dark py-4 mt-3" id="footer"><div class="container"><div class="row"><div class="col">CopyRight © 2020 All Rights Reserved </div><div class="col text-right">Processed: <b>0.042</b>, SQL: <b>9</b></div></div></div></footer><script src="./lang/en-us/lang.js?2.2.0"></script><script src="view/js/jquery.min.js?2.2.0"></script><script src="view/js/popper.min.js?2.2.0"></script><script src="view/js/bootstrap.min.js?2.2.0"></script><script src="view/js/xiuno.js?2.2.0"></script><script src="view/js/bootstrap-plugin.js?2.2.0"></script><script src="view/js/async.min.js?2.2.0"></script><script src="view/js/form.js?2.2.0"></script><script> var debug = DEBUG = 0; var url_rewrite_on = 1; var url_path = './'; var forumarr = {"1":"Tech"}; var fid = 1; var uid = 0; var gid = 0; xn.options.water_image_url = 'view/img/water-small.png'; </script><script src="view/js/wellcms.js?2.2.0"></script><a class="scroll-to-top rounded" href="javascript:void(0);"><i class="icon-angle-up"></i></a><a class="scroll-to-bottom rounded" href="javascript:void(0);" style="display: inline;"><i class="icon-angle-down"></i></a></body></html><script> var forum_url = 'list-1.html'; var safe_token = 'cNNrJySQG_2FzAorqg0NIGMQBTmVTQOWLKI_2BXZnrya25KlZ_2Fof6Y_2Bq59At1_2BeybLBHqCBHloE4hQDWd1C22m6r0g_3D_3D'; var body = $('body'); body.on('submit', '#form', function() { var jthis = $(this); var jsubmit = jthis.find('#submit'); jthis.reset(); jsubmit.button('loading'); var postdata = jthis.serializeObject(); $.xpost(jthis.attr('action'), postdata, function(code, message) { if(code == 0) { location.reload(); } else { $.alert(message); jsubmit.button('reset'); } }); return false; }); function resize_image() { var jmessagelist = $('div.message'); var first_width = jmessagelist.width(); jmessagelist.each(function() { var jdiv = $(this); var maxwidth = jdiv.attr('isfirst') ? first_width : jdiv.width(); var jmessage_width = Math.min(jdiv.width(), maxwidth); jdiv.find('img, embed, iframe, video').each(function() { var jimg = $(this); var img_width = this.org_width; var img_height = this.org_height; if(!img_width) { var img_width = jimg.attr('width'); var img_height = jimg.attr('height'); this.org_width = img_width; this.org_height = img_height; } if(img_width > jmessage_width) { if(this.tagName == 'IMG') { jimg.width(jmessage_width); jimg.css('height', 'auto'); jimg.css('cursor', 'pointer'); jimg.on('click', function() { }); } else { jimg.width(jmessage_width); var height = (img_height / img_width) * jimg.width(); jimg.height(height); } } }); }); } function resize_table() { $('div.message').each(function() { var jdiv = $(this); jdiv.find('table').addClass('table').wrap('<div class="table-responsive"></div>'); }); } $(function() { resize_image(); resize_table(); $(window).on('resize', resize_image); }); var jmessage = $('#message'); jmessage.on('focus', function() {if(jmessage.t) { clearTimeout(jmessage.t); jmessage.t = null; } jmessage.css('height', '6rem'); }); jmessage.on('blur', function() {jmessage.t = setTimeout(function() { jmessage.css('height', '2.5rem');}, 1000); }); $('#nav li[data-active="fid-1"]').addClass('active'); </script>