html文件:提供上传文件的入口

<input type="file" name="upload"><!-- name很重要,与后面action文件对应 -->

xml文件:

<!-- 上传资料 -->
<action name="upload" class="web.FileUploadAction" method="execute">
<!-- 上传成功,返回 -->
<result name="success">success_commit.jsp</result>
<result name="error">error.jsp</result>
</action>

action文件:

public class FileUploadAction {
private String remark;// 备注
private int id;// id
private File upload;// 与html文件中input[type=file]必须一样
private String uploadFileName;// 文件名,必须这样写,upload和html文件中input[type=file]必须,FileName ResultService rService = new ResultService(); public String execute() {
try {
// 点击上传之后
// 保存上传数据
int row = 0;
// 检查是否上传了文件
if (uploadFileName != null && !uploadFileName.equals("")) {
//考虑到需要保存文件进行的操作比较多,上传了文件另外保存
row = rService.save(upload, uploadFileName, demandid,
remark); } else {
// 没有上传文件
row = rService.save(demandid, remark);
} if (row == 1) {// 修改的行数
// 上传成功
return "success";
} else {
//上传失败
return "error";
}
} catch (Exception e) {
return "error";
}
} // 以下是getter/setter方法(略去)
}

service层

 public int save(File file, String filename, int id, String remark) {
// 有文件保存方法
String lj = copyfile(file, filename);
Result res = new Result();
res.setFile(new File(lj));
res.setDemandid(id);
res.setRemark(remark);
res.setTitle(filename);
return rDao.saveResult(res);
}
//没有文件的保存方法
public int save(int id,String remark){
Result res = new Result();
res.setDemandid(id);
res.setRemark(remark);
return rDao.saveResultNoFile(res);
} public String copyfile(File file, String filename) {
// 把文件拷贝到服务器的指定目录下
String realpath = ServletActionContext.getServletContext().getRealPath(
"/info");
String lj = realpath + "\\" + filename;
try {
if (file != null) {
File savefile = new File(new File(realpath), filename);
if (!savefile.getParentFile().exists()) {
savefile.getParentFile().mkdirs();
}
// 调用copyFile方法
FileUtils.copyFile(file, savefile);
}
} catch (Exception e) {
e.printStackTrace();
}
return lj;
}

dao层(与数据库进行交互)

public int saveResult(Result res) {// 保存有文件的
int row = 0;
Connection conn = null;
PreparedStatement ps = null;
String sql = "insert into result(id,content,remark,time,title,demandid) values(id_result.nextval,?,?,?,?,?)";// Oracle数据库
// id_result 序列号
try {
conn = DBUtil.getConn();
File file = res.getFile();
FileInputStream fis = new FileInputStream(file);
ps = conn.prepareStatement(sql);
int len = (int)file.length();
ps.setBinaryStream(1, fis, len);
ps.setString(2, res.getRemark());
ps.setLong(3, System.currentTimeMillis());
ps.setString(4, res.getTitle());
ps.setInt(5, res.getDemandid()); row = ps.executeUpdate();
fis.close(); } catch (Exception e) {
e.printStackTrace();
} finally {
DBUtil.close(conn, ps, null);
}
// 返回修改的行数
return row;
}

struts2文件上传(保存为BLOB格式)的更多相关文章

  1. Struts2文件上传下载

    Struts2文件上传 Struts2提供 FileUpload拦截器,用于解析 multipart/form-data 编码格式请求,解析上传文件的内容,fileUpload拦截器 默认在defau ...

  2. struts2文件上传,文件类型 allowedTypes

    struts2文件上传,文件类型 allowedTypes 1 '.a' : 'application/octet-stream', 2 '.ai' : 'application/postscript ...

  3. 学习Struts--Chap07:Struts2文件上传和下载

    1.struts2文件上传 1.1.struts2文件上传的基本概述 在开发web应用的时候,我们一般会为用户提供文件上传的功能,比如用户上传一张图像作为头像等.为了能上传文件,我们必须将表单的met ...

  4. 【Java EE 学习 35 下】【struts2】【struts2文件上传】【struts2自定义拦截器】【struts2手动验证】

    一.struts2文件上传 1.上传文件的时候要求必须使得表单的enctype属性设置为multipart/form-data,把它的method属性设置为post 2.上传单个文件的时候需要在Act ...

  5. springMvc 使用ajax上传文件,返回获取的文件数据 附Struts2文件上传

    总结一下 springMvc使用ajax文件上传 首先说明一下,以下代码所解决的问题 :前端通过input file 标签获取文件,通过ajax与后端交互,后端获取文件,读取excel文件内容,返回e ...

  6. Struts2文件上传和下载(原理)

    转自:http://zhou568xiao.iteye.com/blog/220732 1.    文件上传的原理:表单元素的enctype属性指定的是表单数据的编码方式,该属性有3个值:1)     ...

  7. Struts2 文件上传

    一:表单准备 ① 要想使用HTML 表单上传一个或多个文件     –须把 HTML表单的 enctype属性设置为multipart/form-data     –须把HTML 表单的method ...

  8. JAVA Web 之 struts2文件上传下载演示(二)(转)

    JAVA Web 之 struts2文件上传下载演示(二) 一.文件上传演示 详细查看本人的另一篇博客 http://titanseason.iteye.com/blog/1489397 二.文件下载 ...

  9. JAVA Web 之 struts2文件上传下载演示(一)(转)

    JAVA Web 之 struts2文件上传下载演示(一) 一.文件上传演示 1.需要的jar包 大多数的jar包都是struts里面的,大家把jar包直接复制到WebContent/WEB-INF/ ...

随机推荐

  1. Unity3D - 关于Dynamic和Static

    含有Collider和RigidBody的GameObject, Unity视之为Dynamic 含有Collider的GameObject, Unity视之为Static 如果Static的物体发生 ...

  2. UVa839 Not so Mobile

      我的解法: 建树,递归判断 #include<cstdio> #include<cstring> #include<iostream> #include< ...

  3. hdu 5587 Array 数学题

    Array Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=5587 De ...

  4. C# 利用范型与扩展方法重构代码

    在一些C#代码中常常可以看到 //An Simple Example By Ray Linn class CarCollection :ICollection { IList list; public ...

  5. ElasticSearch使用

    安装之前,请参考https://github.com/richardwilly98/elasticsearch-river-mongodb根据你的MongoDB版本号决定需要的elasticsearc ...

  6. 关于IE8中使用Jquery load方法无法正常加载页面

    最近发现,在IE8中使用Jquery load方法时无法正常加载页面,页面显示空白,没有加载.调试发现,页面多了一个</div>标签,但在FF和CH下表现正常.希望能给遇到同样问题的码农有 ...

  7. iOS开发——UI_swift篇&UITableView实现单元格展开与隐藏

    UITableView实现单元格展开与隐藏  关于UITableView的展开的收缩在前面的文章我已经结束,就是使用代理,通知,block传值的时候实现的,当时是使用一个Bool值来实现,最后使用着三 ...

  8. PhoneGap开发手机程序入门教程

    用PhoneGap开发手机移动程序 1.     什么是PhoneGap PhoneGap是一个自由开放源码的开发工具和框架,允许利用HTML + JavaScript + CSS的强大功能在多个手机 ...

  9. SQL用法总结

    1.创建数据库语句 create table persons( 'id' INT NOT NULL AUTO_INCREMENT, ) NOT NULL, ) NOT NULL, PRIMARY KE ...

  10. C#_在.net中序列化读写xml方法的总结

    阅读目录 开始 最简单的使用XML的方法 类型定义与XML结构的映射 使用 XmlElement 使用 XmlAttribute 使用 InnerText 重命名节点名称 列表和数组的序列化 列表和数 ...