相册管理系统(Java表单+xml数据库存储)
功能文件的上传,下载和管理
技术:1.用xml当做数据库存储信息(dom4j,xpath)
2.Java表单的文件上传和下载
3.文件目录的打散 ( Hash目录是一种优化文件存储性能的方法)
需要的jar包:
commons-fileupload-1.2.2.jar、commons-io-2.1.jar、dom4j-1.6.1.jar和jaxen-1.1-beta-6.jar
--------------------------------------------------------------------------------
先写index.jsp
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>相册管理系统</title>
</head>
<body>
<h1>我的小相册</h1>
<a href="jsps/upload.jsp">上传相册</a>
<a href="servlets/ShowServlet">浏览相册</a>
</body>
</html>
upload.jsp是下载页面放在jsps目录下
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
</head>
<body>
<h1>相处上传</h1>
<form action="<%=request.getContextPath()%>/servlets/UploadServlet"
method="post" enctype="multipart/form-data">
文件:<input type="file" name="file1"/><br/>
说明:<input type="text" name="desc" /><br/>
<input type="submit" value="上传" />
</form>
</body>
</html>
photos.xml放在src目录下
<?xml version="1.0" encoding="UTF-8"?>
<photos>
</photos>
在写值对象PhotoModel
package cn.hncu.demain;
public class PhotoModel {
private String id;
private String realName;
private String ext;
private String dir;
private String dateTime;
private String ip;
private String desc;
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getRealName() {
return realName;
}
public void setRealName(String realName) {
this.realName = realName;
}
public String getExt() {
return ext;
}
public void setExt(String ext) {
this.ext = ext;
}
public String getDir() {
return dir;
}
public void setDir(String dir) {
this.dir = dir;
}
public String getDateTime() {
return dateTime;
}
public void setDateTime(String dateTime) {
this.dateTime = dateTime;
}
public String getIp() {
return ip;
}
public void setIp(String ip) {
this.ip = ip;
}
public String getDesc() {
return desc;
}
public void setDesc(String desc) {
this.desc = desc;
}
@Override
public String toString() {
return "PhotoModel [id=" + id + ", realName=" + realName + ", ext="
+ ext + ", dir=" + dir + ", dateTime=" + dateTime + ", ip="
+ ip + ", desc=" + desc + "]";
}
}
写工具类两个:
MyUtil(日期格式化,目录打散代码,随机id代码)
package cn.hncu.utils;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.UUID;
public class MyUtils {
private MyUtils() {
}
private static SimpleDateFormat format=new SimpleDateFormat("yyyy年MM月dd日 hh:mm:ss");
public static String getCurrentDateTime(){
return format.format(new Date());
}
public static String getUUid(){
UUID uuid=UUID.randomUUID();
String id=uuid.toString().replaceAll("-", "");
return id;
}
public static String getDir(String uuid){
String dir1=Integer.toHexString(uuid.hashCode() & 0xf);
String dir2=Integer.toHexString((uuid.hashCode() & 0xf0)>>4);
return dir1+"/"+dir2;
}
}
Dom4jFactory(dom4j的相关操作,获取document对象,保存操作)
package cn.hncu.utils;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.UnsupportedEncodingException;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter;
public class Dom4jFactory {
private static Document dom = null;
private static String path;
static {
try {
SAXReader sax = new SAXReader();
// 学习一下服务器下的资源路径加载方式(因为我们的资源已经从MyEclipse中发布到Tomcat服务器中了,所以跟原来纯Java项目不一样了)
// 利用当前类找到它的类加载器,然后通过该类加载器再去获得资源路径
path = Dom4jFactory.class.getClassLoader().getResource("photos.xml")
.getPath();
dom = sax.read(new FileInputStream(path));
} catch (Exception e) {
throw new RuntimeException(e.getMessage(), e);
}
}
public static Document getDom(){
return dom;
}
public static boolean save(){
try {
OutputFormat format=new OutputFormat();
format.setEncoding("utf-8");
XMLWriter w = new XMLWriter( new FileOutputStream(new File(path)),format);
w.write(dom);
w.close();
return true;
} catch (Exception e) {
return false;
}
}
}
从底层写PhotoDao
package cn.hncu.dao;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import org.dom4j.Document;
import org.dom4j.Element;
import cn.hncu.demain.PhotoModel;
import cn.hncu.utils.Dom4jFactory;
public class PhotoDao {
//添加
public boolean add(PhotoModel photo){
Document dom=Dom4jFactory.getDom();
Element root=dom.getRootElement();
Element ePhoto=root.addElement("photo");
ePhoto.addAttribute("id", photo.getId());
ePhoto.addAttribute("realName", photo.getRealName());
ePhoto.addAttribute("dir", photo.getDir());
ePhoto.addAttribute("ip", photo.getIp());
ePhoto.addAttribute("dateTime", photo.getDateTime());
ePhoto.addAttribute("ext", photo.getExt());
ePhoto.addElement("desc").setText(photo.getDesc());
boolean boo=Dom4jFactory.save();
return boo;
}
//浏览
public List<PhotoModel> getAll(){
Document dom=Dom4jFactory.getDom();
List<PhotoModel> list=new ArrayList<PhotoModel>();
Element root=dom.getRootElement();
Iterator<Element> it=root.elementIterator();
while(it.hasNext()){
PhotoModel photo=new PhotoModel();
Element e=it.next();
photo.setId(e.attributeValue("id"));
photo.setDateTime(e.attributeValue("dateTime"));
photo.setDir(e.attributeValue("dir"));
photo.setExt(e.attributeValue("ext"));
photo.setIp(e.attributeValue("ip"));
photo.setRealName(e.attributeValue("realName"));
photo.setDesc(e.elementText("desc"));
list.add(photo);
}
return list;
}
public PhotoModel getSingleById(String id) {
Document dom=Dom4jFactory.getDom();
List<PhotoModel> list=getAll();
for(PhotoModel photo:list){
if(photo.getId().equals(id)){
return photo;
}
}
return null;
}
public boolean del(String id) {
Document dom=Dom4jFactory.getDom();
Element e=(Element) dom.selectSingleNode("//photo[@id='"+id.trim()+"']");
return e.getParent().remove(e);
}
}
最后写四个servlet
UploadServlet 上传Servlet代码
package cn.hncu.servlets;
import java.io.File;
import java.io.IOException;
import java.io.InputStream;
import java.io.PrintWriter;
import java.util.List;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.commons.fileupload.FileItem;
import org.apache.commons.fileupload.FileUploadException;
import org.apache.commons.fileupload.disk.DiskFileItemFactory;
import org.apache.commons.fileupload.servlet.ServletFileUpload;
import org.apache.commons.io.FileUtils;
import cn.hncu.dao.PhotoDao;
import cn.hncu.demain.PhotoModel;
import cn.hncu.utils.MyUtils;
public class UploadServlet extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setContentType("text/html;charset=utf-8");
PrintWriter out = response.getWriter();
out.println("<!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.01 Transitional//EN\">");
out.println("<HTML>");
out.println(" <HEAD><TITLE>A Servlet</TITLE></HEAD>");
out.println(" <BODY>");
out.println("不支持get方式上传!");
out.println(" </BODY>");
out.println("</HTML>");
out.flush();
out.close();
}
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setContentType("text/html;charset=utf-8");
PrintWriter out = response.getWriter();
String path=request.getServletContext().getRealPath("/photos");
DiskFileItemFactory factory=new DiskFileItemFactory();
factory.setRepository(new File("g:/a"));
ServletFileUpload upload = new ServletFileUpload(factory);
upload.setSizeMax(1024*1024*10);//最大10M
upload.setHeaderEncoding("utf-8");//用于设置文件名的编码,相当于:request.setCharacterEncoding("utf-8");
FileItem fi=null;
try {
List<FileItem> list=upload.parseRequest(request);
PhotoModel photo = new PhotoModel();//数据封装---需要7个属性
boolean boo=false;
InputStream in = null;
for(FileItem fi2:list){
fi=fi2;
if(fi.isFormField()){
String desc=fi.getString("utf-8");
photo.setDesc(desc);//desc
}else{
in=fi.getInputStream();
String realName=fi.getName();
if(realName==null || realName.trim().equals("")){
out.print("没有选择文件!");
return;
}
if(realName.indexOf("\\")!=-1){
realName=realName.substring(realName.lastIndexOf("\\")+1);
}
photo.setRealName(realName);//真实文件名
String ext=realName.substring(realName.lastIndexOf("."));
photo.setExt(ext);//3
photo.setDateTime(MyUtils.getCurrentDateTime());//4
photo.setId(MyUtils.getUUid());//5
photo.setDir(MyUtils.getDir(photo.getId()));//6
photo.setIp(request.getRemoteAddr());//7
}
}
//把相片信息存储到数据库
PhotoDao dao=new PhotoDao();
boo=dao.add(photo);
//如果上面的相片信息保存成功,那么才开始接收图片文件,把它保存到服务器硬盘
if(boo){
System.out.println(dao);
path=path+"/"+photo.getDir();
File dir=new File(path);
if(!dir.exists()){
dir.mkdirs();
}
String fileName=path+"/"+photo.getId()+photo.getExt();
FileUtils.copyInputStreamToFile(in, new File(fileName));
String strPath = request.getContextPath()+"/servlets/ShowServlet";
out.print("上传成功!<a href='"+strPath+"'>浏览相册</a>");
}else{
out.print("上传失败!");
}
} catch (FileUploadException e) {
throw new RuntimeException("上传失败!", e);
}finally{
if(fi!=null){
fi.delete();
}
}
out.flush();
out.close();
}
}
ShowServlet 浏览相册的Servlet端
package cn.hncu.servlets;
import java.io.IOException;
import java.io.PrintWriter;
import java.util.List;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import cn.hncu.dao.PhotoDao;
import cn.hncu.demain.PhotoModel;
public class ShowServlet extends HttpServlet {
IOException if an error occurred
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doPost(request, response);
}
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setContentType("text/html;charset=utf-8");
request.setCharacterEncoding("utf-8");
PrintWriter out = response.getWriter();
out.println("<!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.01 Transitional//EN\">");
out.println("<HTML>");
out.println(" <HEAD><TITLE>A Servlet</TITLE></HEAD>");
out.println(" <BODY>");
String table="<table border='1' width='100%'>"+
"<tr><th>文件名</th><th>上传ip</th><th>上传时间</th><th>图片</th><th>说明</th><th>操作</th></tr>"
;
out.print(table);
PhotoDao dao=new PhotoDao();
List<PhotoModel> list=dao.getAll();
for(PhotoModel p:list){
out.print("<tr>");
out.println("<td>"+p.getRealName()+"</td>");
out.println("<td>"+p.getIp()+"</td>");
out.println("<td>"+p.getDateTime()+"</td>");
//输出图片
String path=request.getContextPath()+"/photos/"+p.getDir()+"/"+p.getId()+p.getExt();
out.println("<td><a href='"+path+"'><img src='"+path+"' width='200' height='200'></img></a></td>");
String op="<a href='"+request.getContextPath()+"/servlets/DelServlet?id="+p.getId()+"'>删除</a> ";
out.println("<td>"+p.getDesc()+"</td>");
op+="<a href='"+request.getContextPath()+"/servlets/DownServlet?id="+p.getId()+"'>下载</a>";
out.println("<td>"+op+"</td>");
out.print("</tr>");
}
out.println("</table>");
out.println(" </BODY>");
out.println("</HTML>");
out.flush();
out.close();
}
}
DownServlet 下载的服务器代码
package cn.hncu.servlets;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.io.PrintWriter;
import java.net.URLEncoder;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import cn.hncu.dao.PhotoDao;
import cn.hncu.demain.PhotoModel;
public class DownServlet extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doPost(request, response);
}
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
String id=request.getParameter("id");
response.setContentType("application/force-download");
PhotoModel p=new PhotoDao().getSingleById(id);
if(p!=null){
String realName=p.getRealName();
realName=new String(realName.getBytes("iso8859-1"),"utf-8");
response.setHeader("content-Disposition", "attachment;filename=\""+realName+"\"");
String relpath=getServletContext().getRealPath("/photos/"+p.getDir()+"/"+p.getId()+p.getExt());
InputStream in=new FileInputStream(relpath);
OutputStream out=response.getOutputStream();
System.out.println(relpath);
byte buf[]=new byte[1024];
int len=0;
while ((len=in.read(buf))!=-1){
out.write(buf,0,len);
}
out.close();
}else{
response.setContentType("text/html;charset=utf-8");
response.getWriter().println("该文件已经被删除!");
}
}
}
Delservlet 删除操作的服务器
package cn.hncu.servlets;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import cn.hncu.dao.PhotoDao;
import cn.hncu.demain.PhotoModel;
public class DelServlet extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doPost(request, response);
}
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
request.setCharacterEncoding("utf-8");
response.setContentType("text/html;charset=utf-8");
PrintWriter out=response.getWriter();
String id=request.getParameter("id");
PhotoModel p=new PhotoDao().getSingleById(id);
if(p!=null){
if(!p.getIp().equals(request.getRemoteAddr())){
out.println("你无权进行删除!");
return;
}
//※※※※以下部分课后补敲的!!!!
//1删除数据库中的信息
PhotoDao dao=new PhotoDao();
boolean boo=dao.del(id);
//2把服务器硬盘中的文件删除
if(boo){
String fileName="photos/"+p.getDir()+"/"+p.getId()+p.getExt();
String pathFileName = getServletContext().getRealPath(fileName);
File f=new File(pathFileName);
if(f.exists()){
f.delete();
}
String strPath = request.getContextPath()+"/servlets/ShowServlet";
out.println("相片删除成功!<a href='"+strPath+"'>浏览相册</a>");
}else{
out.println("相片删除失败!");
}
}else{
response.setContentType("text/html;charset=utf-8");
response.getWriter().println("该文件不存在!");
}
}
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
以上是 相册管理系统(Java表单+xml数据库存储) 的全部内容, 来源链接: utcz.com/p/210151.html