oracle建表语句:
create sequence seq_zs_file_manage
create table File_up_down
(
file_id number(10),
file_name varchar2(200),
file_comment varchar2(500),
file_path varchar2(255),
file_type numeric(10),
file_size number(10),
file_state varchar2(20)
user_id varchar2(30),
user_name varchar2(50),
upload_time date,
download_count number(10)
);
alter table File_up_down add org_id number; //机构Id
alter table File_up_down modify(FILE_PATH varchar2(255))
alter table File_up_down modify(USER_id char(32))
comment on column File_up_down.File_Id is '文件ID';
comment on column File_up_down.File_Name is '文件名称';
comment on column File_up_down.file_comment is '文件说明';
comment on column File_up_down.file_path is '上传路径';
comment on column File_up_down.user_id is '上传用户code';
comment on column File_up_down.user_name is '上传用户';
comment on column File_up_down.upload_time is '上传时间';
comment on column File_up_down.download_count is '下载次数';
comment on column File_up_down.file_type is '文件大小/M';
comment on column File_up_down.state is '状态';
Mysql:
CREATE TABLE File_up_down
(
file_id VARCHAR(50) PRIMARY KEY,
file_name VARCHAR(100),
file_comment VARCHAR(500),
file_path VARCHAR(255),
file_type VARCHAR(20),
file_size INT,
file_state VARCHAR(20),
upload_user_id VARCHAR(30),
upload_user_name VARCHAR(50),
upload_time DATE,
download_count INT
)
上传模板代码:
* jsp
<s:form action="pdManagerAction_deploy.action" enctype="multipart/form-data">
<!-- 二进制 -->
<s:file name="resource" cssClass="InputStyle">
* action
private File resource;
public void setResource(File resource) {
this.resource = resource;
}
* serviceImpl
String url = UploadUtils.saveUploadFile(resource); //UploadUtils见上传文件
下载模板代码
* ServiceImpl:
public InputStream download(Long ftid) throws Exception {
FormTemplate formTemplate = (FormTemplate)this.formTemplateDao.getEntryById(ftid);
String fileName = URLEncoder.encode(formTemplate.getName(), "utf-8");
ActionContext.getContext().put("fileName",fileName);
return new FileInputStream(new File(formTemplate.getUrl()));
}
* Action:
private InputStream inputStream;
public InputStream getInputStream() {
return inputStream;
}
public String downloadFormTemplate() throws Exception{
this.inputStream = this.formTemplateService.download(this.getModel().getFtid());
return SUCCESS;
}
* struts.xml
<result type="stream">
<param name="contentType">application/octet-stream</param>
<param name="inputName">inputStream</param>
<param name="contentDisposition">attachment;filename="${#fileName}"</param>
<param name="bufferSize">40960</param>
</result>
步骤过程:
struts2框架的文件上传:
* 单文件上传:
* 在动作类action中声明相关属性:
* 在动作类action中,要声明与页面中表单name属性同名的属性,同名的属性的类型时File类型;
* 在动作类action中,要声明[同名的属性]ContentType,类型时String类型;
* 在动作类action中,要声明[同名的属性]FileName,类型时String类型
* 给所有属性提供get和set方法
* 在业务方法中,处理文件上传:
* 获取要上传文件的路径,保存的位置
* 在目标文件夹内,创建一个与上传文件同名的文件
* 通过FileUtils工具类提供copyFile()方法,将临时文件内容拷贝到目标文件夹下的那个同名的文件
* 设置上传文件的总大小
* 在struts.xml文件中,<constant name="struts.multipart.maxSize" value="2097152000"></constant>
* 设置上传文件的大小、类型和扩展名:
* 在自定义的配置文件中,在action标签下:
<!-- 配置拦截器的参数,这里是文件上传拦截器 -->
<interceptor-ref name="defaultStack">
<!--
配置文件上传拦截器的参数
* 与定义参数的顺序无关
* 允许的类型(allowedTypes)和允许的扩展名(allowedExtensions)必须保持一致
-->
<!--
* 配置上传文件的大小
* struts.xml文件中配置的是上传文件的总大小
* 这里配置的是上传文件的单个大小
-->
<param name="fileUpload.maximumSize">20971520</param>
<!-- 配置上传文件允许的类型,如果配置多个值的话,用","隔开 -->
<param name="fileUpload.allowedTypes">text/plain,application/msword</param>
<!-- 配置上传文件的扩展名,如果配置多个值的话,用","隔开 -->
<param name="fileUpload.allowedExtensions">.txt</param>
</interceptor-ref>
* 自定义上传文件的错误提示信息:
* 在动作类action同目录下,创建一个名为fileuploadmessage.properties资源文件(名为自定义)
* 改资源文件配置如下:
struts.messages.error.uploading=Error uploading: {0}
struts.messages.error.file.too.large=File too large: {0} "{1}" "{2}" {3}
struts.messages.error.content.type.not.allowed=Content-Type not allowed: {0} "{1}" "{2}" {3}
struts.messages.error.file.extension.not.allowed=File extension not allowed: {0} "{1}" "{2}" {3}
* 多文件上传:
* 所有流程于配置都与单文件上传一致。
* 需要注意的是:
* 在页面中,虽然是多文件上传,但是页面中表单的name属性的值必须保持一致;
* 在动作类action中声明的相关属性,类型改成数组;
* 在业务方法中,相关处理流程改成单文件上传的循环。