Transport the image to the database with Struts?

xiaoxiao2021-03-06  81

This example is written in MySQL by using Struts's Formfile. . .

Use the user by selecting a picture, then press SUBMIT to deposit into the database

First set up a table:

Create Table Test (Name Varchar (20), Pic Blob); in MySQL Test Library

<% @ page language = "java"%> <% @ taglib uri = "http://jakarta.apache.org/struts/tags-bean" prefix = "bean"%> <% @ Taglib URI = "http: //jakarta.apache.org/struts/tags-html "prefix =" html "%> jsp for multiform form </ title> </ head> <body> <html: form action = "/ multi" encType = "multipart / form-data"> must use encType = "multipart / form-data" to throw an exception file after committing, <html: file property = "file" /> <html: errors proty = "file" /> </br> Name: <html: text protety = "name" /> <html: errors proty = "name" /> </br> <HTML: Submit /> < HTML: Cancel /> </ html: form> </ body> </ html></p> <p>2. Comparison ActionForm:</p> <p>// Created by myeclipse struts // xsl source (default): platform: /plugin/com.genuitec.eclipse.cross.easystruts.eclipse_3.8.1/xslt/javaclass.xsl</p> <p>Package saoo.struts.form;</p> <p>Import org.apache.struts.Action.Actionform; import org.apache.struts.upload.formfile;</p> <p>/ ** * myeclipse struts * creation date: 08-24-2004 * xdoclet definition: * @struts: form name = "multiform" * / public class multiform extends actionform {</p> <p>/ / -------------------------------------------------------------------------------------------- --------- Instance Variables</p> <p>/ ** File Property * / private formfile file;</p> <p>/ ** Name property * / private string name;</p> <p>/ / -------------------------------------------------------------------------------------------- --------- Methods</p> <p>/ ** * returns the file. * @Return formfile * / public formfile getfile () {return file;} / ** * set the file. * @Param file the file to set * / public void setfile (Formfile file) { THIS.FILE = file;</p> <p>/ ** * returns the name. * @Return string * / public string getName () {Return Name;}</p> <p>/ ** * set the name. * @Param name the name to set * / public void setname (string name) {this.name = name;}</p> <p>}</p> <p>3. For the Action:</p> <p>// Created by myeclipse struts // xsl source (default): platform: /plugin/com.genuitec.eclipse.cross.easystruts.eclipse_3.8.1/xslt/javaclass.xsl</p> <p>Package Sao.struts.Art;</p> <p>import java.io.FileNotFoundException; import java.io.IOException; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.SQLException;</p> <p>Import javax.servlet.http.httpservletRequest; import javax.servlet.http.httpservletResponse;</p> <p>import org.apache.struts.action.Action; import org.apache.struts.action.ActionForm; import org.apache.struts.action.ActionForward; import org.apache.struts.action.ActionMapping; import org.apache.struts . UPLOAD.FORMFILE;</p> <p>Import Sao.Struts.form.Multiform;</p> <p>/ ** * myeclipse struts * code date: 08-24-2004 * xdoclet definition: * @struts: action path = "/ multi" name = "multiform" infut = "/ form / multi.jsp" scope = "request "* / Public class multiaction extends action {</p> <p>/ / -------------------------------------------------------------------------------------------- --------- Instance Variables</p> <p>/ / -------------------------------------------------------------------------------------------- --------- Methods</p> <p>/ ** * Method execute * @param mapping * @param form * @param request * @param response * @return ActionForward * / public ActionForward execute (ActionMapping mapping, ActionForm form, HttpServletRequest request, HttpServletResponse response) {MultiForm multiForm = (MultiForm Form; Formfile file = multiform.getfile (); string name = multiform.getName (); try {class.forname ("org.gjt.mm.mysql.driver); string url =" JDBC: mysql: // / TEST "; connection con = drivermanager.getConnection (url," root "," password "); string sql =" Insert INTO PIC VALUES (?) "; preparedStatement PS = Con.PrepareStatement (SQL); ps.setstring (1, name); // Add a picture to the database ps.setbinaryStream (2, file.getinputstream (), file.GetFileSize (); ps.ExecuteUpdate (); ps.close (); conif.close ();} Catch (SQLException SE) {SE.PRINTSTACKTRACE (); Return mapping.findForward ( "error");} catch (ClassNotFoundException e) {// TODO Auto-generated catch block e.printStackTrace (); return mapping.findForward ( "error");} catch (FileNotFoundException e) {// TODO Auto-generated catch block e.printStackTrace (); return mapping.findForward ( "error");} catch (IOException e) {// TODO Auto-generated catch block e.printStackTrace (); return mapping.findForward ("Error");} return mapping.findforward ("success");}</p> <p>}</p></div><div class="text-center mt-3 text-grey"> 转载请注明原文地址:https://www.9cbs.com/read-124032.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="124032" 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.050</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 = 'mW9cggSaxMNzHly0tZNFAqWu91pr0RlmGrlHngH64R9_2FdQFqOJuOo7BRDmbe9e3b1ocYCKLqUBeA7mMbHYmVvQ_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>