相册管理系统(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

回到顶部