一:前台
form中的enctype是"multipart/form-data"是设置表单的MIME编码。默认情况,这个编码格式是application/x-www-form-urlencoded,不能用于文件上传;只有使用了multipart/form-data,才能完整的传递文件数据,进行下面的操作.
上传按钮用: s:file name=
<s:form action="photoInfo_photo_add" enctype="multipart/form-data">
<tr>
<td width="80" height="40">相片标题:</td>
<td width="470" bgcolor="#FFFFFF"><s:textfield name="photoName"/></td>
</tr>
<tr>
<td height="40">相册类别:</td>
<td bgcolor="#FFFFFF"><s:select name="photoType" list="#request.types" /></td>
</tr>
<tr>
<td height="40">相片地址:</td>
<td bgcolor="#FFFFFF"><s:file name="upload"/></td>
</tr>
<tr>
<td height="40"> </td>
<td><s:submit value=" 添加相片 "/><s:hidden name="author" value="%{#session.account}"/></td>
</tr>
</s:form>
二:struts对照片的限制
xml里配置的
存储位置,图片格式,大小等
<action name="photoInfo_*" class="com.mr.webiter.PhotoAction" method="{1}">
<param name="savePath">/photo</param>
<interceptor-ref name ="fileUpload">
<param name ="allowedTypes">image/bmp,image/png,image/gif,image/pjpeg</param>
<param name="maximumSize">1024000</param>
</interceptor-ref>
<interceptor-ref name ="defaultStack"/>
三:照片的命名
先取出当前毫秒的时间,加上文件名,再去掉拓展名
String address = System.currentTimeMillis()
+ photoInfo.getUploadFileName().substring(
photoInfo.getUploadFileName().lastIndexOf("."));
插一下, 每个photo实例中都包含一下几个元素:(还有别的)
private String photoType = "";
private String photoName = "";
private String photoAddress = "";
private Integer photoVisit = 0;
private String author = "";
private File upload = null;
组装一下photo实例, 把用户名写进去, 然后服务器端的名称组装进去
File imageFile = new File(ServletActionContext.getServletContext()
.getRealPath("/photo")
+ "/" + address);
photoInfo.setPhotoAddress("photo/" + address);
objectDao = new ObjectDao<PhotoInfo>();
最后存入数据库
if (objectDao.saveT(photoInfo)) {
copy(photoInfo.getUpload(), imageFile);
result = "上传成功!";
}
四:显示照片
最简单的显示方式就是:按上传的用户名查一下所有photo实例,
public String photo_query() {
String account = (String) request.getSession().getAttribute("account");
String hql = "from PhotoInfo where author='" + account + "'";
objectDao = new ObjectDao<PhotoInfo>();
List<PhotoInfo> list = objectDao.queryList(hql);
request.setAttribute("list", list);
还有相册什么的,那些显示方式大同小异,就是多了些筛选条件. 相册有时间再分析吧