功能文件的上传,下载和管理
技术: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("该文件不存在!"); } } }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
主要内容:什么是数据库,数据库管理系统,DBMS的特征,DBMS的优点,DBMS的缺点,学习前提条件,面向读者,问题反馈DBMS教程提供了数据库的基本和高级概念。 我们的DBMS教程专为初学者和专业人士设计。数据库管理系统是用于管理数据库的软件。 DBMS教程包括DBMS的所有主题,如介绍,ER模型,键,关系模型,连接操作,SQL,函数依赖,事务,并发控制等。 什么是数据库 数据库是相互关联数据的集合,用于有效地检索,插入和删除数据。 它还用于以表格,模式,视图和报告等形式组织数据。 例如: 学
本文向大家介绍java实现超市库存管理系统,包括了java实现超市库存管理系统的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了java库存管理系统的具体代码,供大家参考,具体内容如下 模拟真实的库存管理逻辑,完成超市管理系统的日常功能实现。 经过分析,首先需要一个功能菜单,然后输入所选的功能后,调用序号对应的功能方法,实现想要的操作。 具体的步骤如下: 1.完成超市商品初始化。创建商
本文向大家介绍数据库管理系统的优势,包括了数据库管理系统的优势的使用技巧和注意事项,需要的朋友参考一下 数据库管理系统(DBMS)定义为允许用户定义,创建,维护和控制对数据库访问的软件系统。DBMS使最终用户可以创建,读取,更新和删除数据库中的数据。它是程序和数据之间的一层。 与基于文件的数据管理系统相比,数据库管理系统具有许多优势。这些优点中的一些在下面给出- 减少数据冗余 基于文件的数据管理系
本文向大家介绍数据库管理系统的局限性,包括了数据库管理系统的局限性的使用技巧和注意事项,需要的朋友参考一下 与基于文件的管理系统相比,数据库管理系统非常有用。但是,它确实有一些缺点。其中一些如下- 更昂贵 创建和管理数据库的成本很高。数据库需要昂贵的软件和硬件。还需要训练有素的人员来处理数据库,并且数据库也需要连续维护。所有这些最终使数据库成为一项相当昂贵的冒险。 高复杂度 数据库管理系统非常复杂
1.5.1. 什么是MaxDB? 1.5.2. MaxDB的历史 1.5.3. MaxDB的特性 1.5.4. 许可和支持 1.5.5. MaxDB和MySQL之间的特性差异 1.5.6. MaxDB和MySQL之间的协同性 1.5.7. 与MaxDB有关的链接 MaxDB是一种大型高效的企业数据库。数据库管理通过了SAP认证。 MaxDB是数据库管理系统的新名称,以前称为SAP DB。2003年
1.4.1. MySQL的历史 1.4.2. MySQL的的主要特性 1.4.3. MySQL稳定性 1.4.4. MySQL表最大能达到多少 1.4.5. 2000年兼容性 MySQL是最流行的开放源码SQL数据库管理系统,它是由MySQL AB公司开发、发布并支持的。MySQL AB是由多名MySQL开发人创办的一家商业公司。它是一家第二代开放源码公司,结合了开放源码价值取向、方法和成功的商业