频道直达 - 学院 - 下载 - 交易 - 特效 - 字库 - 手册 -排名-工具- 繁體
网页教学网站开发 设为首页
加入收藏
联系我们
建站搜索: 常用广告代码   用户注册 | 用户登陆
您当前的位置:中国建站之家 -> 网站开发设计技术教程 -> JSP教程 -> 用Struts向MYSQL数据库中储存图片实例

用Struts向MYSQL数据库中储存图片实例

作者:未知  来源:www.jz123.cn  发布时间:2007-8-27 8:16:47  发布人:圈圈

减小字体 增大字体

这个例子是通过用Struts的FormFile来写入到MySQL中。用户通过选一个图片,然后按submit就可以存入数据库中,其中先要建立一个表:

create table test (name varchar(20), pic blob );

在MySQL的test库中

<%@ 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"%>
<html>
 <head>
  <title>JSP for multiForm form</title>
 </head>
 <body>
  <html:form action="/multi"
  enctype="multipart/form-data">
  一定要用enctype=“multipart/form-data“
  不然就提交之后就会有抛出异常
   file : <html:file property="file"/>
   <html:errors property="file"/></br>
   name : <html:text property="name"/>
   <html:errors property="name"/></br>
   <html:submit/><html:cancel/>
  </html:form>
 </body>
</html>

2. 相对应的ActionForm:

//Created by MyEclipse Struts
// XSL source (default):
platform:/plugin/com.genuitec.eclipse.
cross.easystruts.eclipse_3.8.1
/xslt/JavaClass.xsl
package saoo.struts.form;
import org.apache.struts.action.ActionForm;
import org.apache.struts.upload.FormFile;
/**
 * MyEclipse Struts
 * Creation date: 08-24-2004
 *
 * XDoclet definition:
 * @struts:form name="multiForm"
 */
public class MultiForm extends ActionForm
{
    // ----------------
 Instance Variables
    /** file property */
    private FormFile file;
    /** name property */
    private String name;
    // -----------------
Methods
    /**
     * 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;
    }
    /**
     * Returns the name.
     * @return String
     */
    public String getName()
 {
        return name;
    }
    /**
     * Set the name.
     * @param name The name to set
     */
    public void setName(String name)
 {
        this.name = name;
    }
}

3. 对就的Action:

//Created by MyEclipse Struts
// XSL source (default):
platform:/plugin/com.genuitec.eclipse.
cross.easystruts.eclipse_3.8.1
/xslt/JavaClass.xsl
package saoo.struts.action;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.SQLException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
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;
import saoo.struts.form.MultiForm;
/**
 * MyEclipse Struts
 * Creation date: 08-24-2004
 *
 * XDoclet definition:
 * @struts:action path="/multi"
 name="multiForm" input="/form/multi.jsp"
 scope="request"
 */
public class MultiAction extends Action
{
    // ---------------
 Instance Variables
    // ---------------
 Methods
    /**
     * 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);
//加入图片到数据库
ps.setBinaryStream
(2,file.getInputStream(),
file.getFileSize());
            ps.executeUpdate();
            ps.close();
            con.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");
    }
}


将本文收藏到QQ书签与更多好友分享
[打 印]
[] [返回上一页] [收 藏]
∷相关文章评论∷    (评论内容只代表网友观点,与本站立场无关!) [更多评论...]
精彩推荐
热门文章
· 注册码大全二
· 注册码大全四
· 注册码大全一
· 要10G免费网络硬盘的请进..
· 通过google 赶快来赚美金..
· 注册码大全十
· 头像-qq头像(qq新头像)4..
· 让你轻松架设FTP服务器1..
· 注册码大全三
· 梦幻背景图片7
· 卡通动物图片6
· 网页制作素材-按钮素材2..
· 让你轻松架设FTP服务器5..
· 风景图片8
· 注册码大全九
· 让你轻松架设FTP服务器2..
关注此文读者还看过
· 餐具—素材
· PHP新手上路(三)
· 提升网站使用性 打造实用..
· 写入文本文件的过程函数..
· 知识搜索应运而生 引领..
· 防止使用者按上一頁按鈕..
· Photoshop调制色调淡雅惨..
· 信产部:花半年整顿市场 ..
· 调查:日本网络普及率最高..
· 使用模板实现ASP代码与页..
· 互联网周刊:腾讯的敌人是..
· FLASH基础
· SEO的优化体会日记
· 如何正确理解PHP的错误信..
· 雅虎开放邮箱API 欲为任..
· 一个不错的随机函数
相关文章
关于本站 - 网站帮助 - 广告合作 - 下载声明 - 友情连接 - 网站地图 - 人才招聘
网站合作、内容监督、商务咨询:QQ: 9576619
Copyright ? 2005--2008 中国建站之家版权所有
粤ICP备05092265号