说真的,做开发快两年了。自己感觉自己并没有多大的进步。心里很遗憾,虽然每次领导安排的任务也几乎都能完成。但是自我感觉质量部是很高。
近期发现身边的牛人同事们个个都有在维护自己的博客。每当完成一件工作就会将自己的工作总结好发出来与大家一起分享,我也知道这样做的好处。只是一直懒不愿意去写。每次都是在工作的时候东拼西凑的把工作好不容易完成,完事以后根本不想再回头去整理这些。久了以后发现自己都看不懂之前写的那些破代码了。
于是暗下决心以后一定痛定思痛、悔过自新!
这两天的工作其实没有什么技术含量、只是我太久没有接触过了、导致一时手生。说简单点仅仅是个图片上传而已。只是中途涉及到一点修改和覆盖的逻辑。
要求是这样的,在提交一条稿件时需要上传图片,图片上传到服务器上,地址存在表里。很简单的也许两年前让我写也就是一个小时的事情。可是现在却耽误了我两天让我觉得自己退化的实在有点可怕。
废话多了。开始说开发吧
首先jsp页面
上传图片,先在页面上的form表单中建个file提交对象
[flash=200,200]
[/flash]
因为用的是webwork框架所以自定义成提交都以jspa形式。和struts的*.do到action是一个意思
红色部分
multipart/form-data是提交form表单用来传输文件流用的。记得很久以前这样写过。我当时忘了写了,害我找了半天都找不着,如果不填action的file对象一直是空的。
webwork的action层
必须声明一个和页面的file提交对象名称一致的file对象
private File [color=darkred]linknewsPic[/color];
private String [color=darkred]linknewsPicFileName;[/color]//文件名称也必须以fileName结尾。不知道为什么这样。这段完全是听同事的。
//保存方法
//开始上//上传图片
if(linknewsPic!=null){
IPortalWindowService pws =(IPortalWindowService)getBean("portalWindowService");
SystemManager sm = SystemManager.getInstance();//创建读取系统文件对象
String picBasePath = sm.getPropValue("xhpPicBasePath");//读取/conf.properties";配置文件(我这里是xhpPicBasePath=/temp)在windows下Webllogic默认把地址创建在Webllogic默认的盘符下的根目录下
SimpleDateFormat sf = new SimpleDateFormat("yyyy/MM/dd");
String str = sf.format(dt);
//获取文件后缀名
String hzname = linknewsPicFileName.substring(linknewsPicFileName.length()-4);//因为jsp的js验证已经限制了文件格式。所以默认截取的这最后的后缀名为.jpg或者.gif之类的后缀。
File picFile = new File(picBasePath+ "/" + str + "/" + System.currentTimeMillis() + hzname);//创建新的file对象给定地址为刚刚读取的地址加以年月日生成的目录。文件名称以当前的时间毫秒值为名称。(内部系统不存在多人同时上传的可能所以毫秒值完全满足)
System.out.println("文件保存路径:"+picFile.getPath());
boolean isupd = saveAs(picFile.getPath());//上传方法
if(isupd){
System.out.println("链接稿图片上传成功!");
System.out.println(picFile.getAbsolutePath());
tanlink.setIMAGEDIR(picFile.getPath());
tanlink.setISCOPYURL("0");
}else{
System.out.println("链接稿图片上传失败!");
resultMap.put("modify", "链接稿图片上传失败,修改失败");
return SUCCESS;
}
}
//上传方法
public boolean saveAs(String destFilePathName) {
final int BUFFER = 2048;//缓存字节
InputStream in = null;//创建输入流对象
OutputStream out = null;//输出流对象
try {
File loadFile = new File(destFilePathName);//创建文件对象
int count;
byte data[] = new byte[BUFFER];//读取文件字节数组
File parentFile = loadFile.getParentFile();//获取要上传文件的上级目录
if (parentFile!=null && !parentFile.exists()) {
if(!parentFile.mkdirs()){//创建该文件目录包括年月日的目录
logger.warn("error mkdirs:"+parentFile.getAbsolutePath());
return false;//如果创建失败则返回
}
}
// write the files to the disk
out = new FileOutputStream(loadFile);//创建文件输入流对象
in = new FileInputStream(this.getLinknewsPic());//读取流
while ((count = in.read(data, 0, BUFFER)) != -1) {//每次写入指定字节数
out.write(data, 0, count);
}
out.flush();//清空输入流
} catch (UnknownHostException e) {
e.printStackTrace();
return false;
} catch (IOException e) {
e.printStackTrace();
return false;
} catch (Exception e) {
e.printStackTrace();
return false;
} finally {
try {
if (in != null) {in.close();}
} catch (Exception e) {
e.printStackTrace();
}
try {
if (out != null) {out.close();}
} catch (Exception e) {
e.printStackTrace();
}
}
return true;
}
jsp中的js验证限制文件格式
<form id="editLinkNews" action="saveLinkNews.jspa" method="post" onsubmit="return
checkForm(this);" enctype="multipart/form-data">
function checkForm(form){
if(form.linktitle.value==""){
alert("请输入稿件名称");
return false;
}
if(form.linksourceurl.value==""){
alert("请输入稿件地址");
return false;
}
if(form.news_date.value==""){
alert("稿件发布时间不填则为系统当前时间");
}
if(form.out_time.value==""){
alert("稿件过期时间不填则为系统当前时间");
}
// alert(form.elements['iscopy'].length);
var radio = form.iscopy;
for(i=0;i<radio.length;i++){
var check = radio[i].checked;
if(check){
iscopyvalue = radio[i].value;
if(iscopyvalue=="1"){
var s = /(\w+):\/\/([^/:]+)(:\d*)?([^# ]*)/;
var picValue= form.elements["coplinknewsPic"].value;
if(picValue!="" && !picValue.match(s)){
alert("请重新输入格式正确的网址再提交!");
return false;
}
}else{
var s = /^.*?\.(jpg|JPG|jpeg|JPEG|gif|GIF|png|PNG){1}$/;
var picValue = form.elements["linknewsPic"].value;
if(picValue!="" && !picValue.match(s)){
alert("请重新选择正确的图片格式上传,支持的格式有*.jpg,*.jpeg,*.gif,*.png");
return false;
}
}
break;
}
}
}
分享到:
相关推荐
webwork中上传文件,webwork文件上传.doc
简单的使用webwork框架实现了文件上传的功能 主要是针对EXCEL文件
WebWork 文件上传 多个文件上传 范例
项目里需要实现webwork 上传与下载文件操作, 自己摸索过程中出现了很多问题,一一解决, 记录下来本准备做参考,现贡献给大家, 记得有点乱,耐心看完,一定会有帮助的。
fileupload+dwr2+webwork2实现带进度条上传文件
本文主要从三个方面给大家介绍webwork文件上传下载知识,包括以下三个方面: 1. 包装 Request 请求 2. 获取文件上传的解析类 3. 项目实战配置和使用 Web上传和下载应该是很普遍的一个需求,无论是小型网站还是大...
使用webwork上传excel并导入数据库,上传时只能上传excel文件,数据库为mysql,可以根据需要自行修改。 数据库的配置也请自行修改。
NULL 博文链接:https://xiaoqiang21.iteye.com/blog/763674
webwork上传文件pdf文件说明文档
NULL 博文链接:https://cxl2012.iteye.com/blog/2011487
NULL 博文链接:https://sgl124764903.iteye.com/blog/812973
NULL 博文链接:https://goowolf.iteye.com/blog/513688
关键是正对最新版webwork,在action中进行操作,说得很细致,有源代码实例。也将异常情况处理列出来了。
第1章 Struts 2概述,第2章 Struts 2下的HelloWorld,第3章 Struts 2基础,第4章 深入Struts 2,第5章 Struts 2的类型转换,第6章 文件的上传和下载.,第7章 Struts 2的拦截器,第8章 Struts 2的输入校验,9.2 ...
真正的《webwork in action》,共三部分,放在一起解压即可。 因为一次上传不了那么大的文件,所以有些麻烦。
《Struts2权威指南——基于WebWork核心的MVC开发》的源代码。请完全放心,绝对保证质量。由于源码中包含jar文件,打出的包过大,只能分多次上传,请谅解。原文件大于415M,压缩后377M,分压成16个包。此为第68个包。
该两个文件是基于webwork框架的两个文件上传包,两个缺一个不可,里面包含各自的源文件
Struts 2权威指南--基于WebWork核心的MVC开发.pdf 12卷,最后要下载我上传的 "海啸文件分割器V1.0.rar"或自行去网站下载进行12卷的合并..谢谢
Struts 2权威指南--基于WebWork核心的MVC开发.pdf 12卷,最后要下载我上传的 "海啸文件分割器V1.0.rar"或自行去网站下载进行12卷的合并..谢谢