欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

bboss mvc大文件上传及or mapping存储大文件机制详解

程序员文章站 2024-02-28 19:56:10
...
继续上两篇文章:
bboss mvc文件上传下载实战演练-[url]http://yin-bp.iteye.com/blog/1130035[/url]
bboss mvc文件上传下载实战进阶-[url]http://yin-bp.iteye.com/blog/1131637[/url]

本文着重介绍bboss mvc大文件上传和利用持久层的or mapping机制存储大文件功能介绍,切入正题

[size=medium][b]功能点说明:[/b][/size]
1.jsp form附件上传表单
2.jquery easyui 表单提交
3.mvc控制附件处理方法
4.绑定附件值对象
5.利用or mapping技术持久化附件信息和附件内容

大致流程如下:
通过将表单提交的附件信息传递给控制方法,mvc将表单数据以及附件信息封装到DeskTopBackGround对象中,利用持久层组件将该附件信息存储到数据库中。

下面逐一说明:

[size=medium][b]首先介绍各个层面都要用到的附件值对象[/b][/size]
public class DeskTopBackGround {	
private String cn_name;
private Timestamp creatdate;
private String filename;
@Column(type="blobfile")
private MultipartFile picture;
。。。//省略get/set方法
}


DeskTopBackGround 中的属性MultipartFile picture包含了附件信息和附件内容,需要注意的是,必须通过@Column(type="blobfile")注解说明附件类型,即是一个blob二进制附件还是一个clob文本附件,分别对应为:@Column(type="blobfile")和@Column(type="clobfile"),这样ormapping机制就能清楚地进行相应的处理。


[size=medium][b]jsp 附件上传表单[/b][/size]
 <form action=""  method="POST" id="addbackground" enctype="multipart/form-data">
<table>
<tr>
<td>
名称:<input type="text" name="cn_name" id="cn_name"/>
</td>
</tr>
<tr>
<td>
附件:<input type="file" name="picture" id="file" />
</td>
</tr>
<tr>
<td>
<input type="button" class="button" value="添加背景图片" onclick="addBackGround(this)" />
</td>
</tr>
</table>
</form>


jquery-easyui form表单提交操作:

 $("#addbackground").form('submit', {
"url": "uploadBackGround.page",//控制器请求url
onSubmit:function(){
//显示遮罩
blockUI();
},
success:function(responseText){
//去掉遮罩
unblockUI();
if(responseText == "success"){
$.messager.alert("提示对话框" , "附件上传成功!");
queryList();
}
else
$.messager.alert("提示对话框" , "附件上传失败:"+responseText);
}
});


[size=medium][b]mvc控制附件处理方法[/b][/size]
public  @ResponseBody String uploadBackGround( DeskTopBackGround bean)
{
try
{
bean.setFilename(bean.getPicture().getOriginalFilename());//设置附件名称到filename属性
bean.setCreatdate(new Timestamp(new Date().getTime()));//设置创建时间
String sql = "insert into td_sm_desktopstylecustom(filename,creatdate,cn_name,picture) values(#[filename],#[creatdate],#[cn_name],#[picture])";
SQLExecutor.insertBean(sql, bean);
return "success";
}
catch (Exception e)
{
return "fail:"+e.getMessage();
}

}


控制方法包含一个DeskTopBackGround bean参数,mvc框架根据表单的信息生成DeskTopBackGround 对象实例,uploadBackGround方法对该实例进行相应的处理后,通过持久层的or mapping接口存储到数据库表中:
SQLExecutor.insertBean(sql, bean);

然后将处理结果信息相应到客户端,客户端进行相应的提示:
$.messager.alert("提示对话框" , "附件上传成功!");


[size=medium][b]后记[/b][/size]
到此本文的正文内容就介绍完了,至于mvc配置文件和持久层数据源配置请参考博客中相关文章:
bboss mvc基础配置介绍-[url]http://yin-bp.iteye.com/blog/1139608[/url]
bbossgroups 开发系列文章之-最佳实践-[url]http://bbossgroups.group.iteye.com/group/wiki/3092-mvc-bboss-config[/url]
bboss persistent框架数据库连接池配置介-[url]http://yin-bp.iteye.com/blog/352599[/url]