Jsp+Servlet实现文件上传下载 删除上传文件(三)

接着上一篇讲:Jsp+Servlet实现文件上传下载(二)--文件列表展示

本章来实现一下删除已上传文件,同时优化了一下第一章中的代码。

废话少说,上代码得意

1.调整列表页面list.jsp

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<html>
<head>
 <title>上传文件列表</title>
</head>
<body> 

<h3>文件列表</h3>
<table class="acclist_tab" border="1" bordercolor="#000000" cellspacing="0" cellpadding="2" style="border-collapse:collapse;">
 <tr>
  <th>文件名</th>
  <th>文件大小(KB)</th>
  <th>操作</th>
 </tr>
 <c:if test="${not empty accessoryList}">
  <c:forEach items="${accessoryList}" var="acc">
   <tr>
    <td>${acc.fileName}</td>
    <td>${acc.fileSize}</td>
    <td><a href="<%=request.getContextPath()%>/removeUploadedFile?id=${acc.id}" rel="external nofollow" >删除</a></td>
   </tr>
  </c:forEach>
 </c:if>
</table>
</body>
</html>

2.新增FileUtils工具类

package util; 

import java.io.File; 

/**
 * 文件操作工具类
 *
 * @author xusucheng
 * @create 2017-12-30
 **/
public class FileUtils {
 public static boolean delete(String path){
  File file = new File(path);
  if(!file.isFile()){
   System.out.println("删除失败,文件:"+path+"不存在!");
   return false;
  } 

  file.delete(); 

  return true;
 }
}

3.调整附件实体DAO,新增load方法

package dao.upload; 

import entity.upload.EntityAccessory;
import util.DBUtil; 

import java.math.BigDecimal;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List; 

/**
 * 附件上传DAO
 *
 * @author xusucheng
 * @create 2017-12-29
 **/
public class AccessoryDao {
 public static void add(EntityAccessory entity) {
  Connection conn = DBUtil.getConnection();
  String sql = "insert into tbl_accessory(file_name,file_size,file_ext_name,file_path) values(?,?,?,?)";
  try {
   PreparedStatement ps = conn.prepareStatement(sql);
   ps.setString(1, entity.getFileName());
   ps.setDouble(2, entity.getFileSize());
   ps.setString(3, entity.getFile_ext_name());
   ps.setString(4, entity.getFilePath());
   ps.execute();
   //conn.commit(); 

   DBUtil.close(null, ps, conn);
  } catch (SQLException e) {
   e.printStackTrace();
  }
 } 

 public static List<EntityAccessory> list() {
  Connection conn = DBUtil.getConnection();
  String sql = "select id,file_name,file_size,file_ext_name,file_path from tbl_accessory";
  List<EntityAccessory> accessoryList = new ArrayList<>();
  try {
   PreparedStatement ps = conn.prepareStatement(sql);
   ResultSet rs = ps.executeQuery(); 

   while (rs.next()) {
    EntityAccessory entity = new EntityAccessory();
    entity.setId(rs.getInt("id"));
    entity.setFileName(rs.getString("file_name"));
    entity.setFileSize(new BigDecimal(rs.getDouble("file_size") / 1024).setScale(2, BigDecimal.ROUND_HALF_UP).doubleValue());
    entity.setFile_ext_name(rs.getString("file_ext_name"));
    entity.setFilePath(rs.getString("file_path"));
    accessoryList.add(entity);
   } 

   DBUtil.close(rs, ps, conn);
  } catch (SQLException e) {
   e.printStackTrace();
  } 

  return accessoryList; 

 } 

 public static EntityAccessory load(int id){
  Connection conn = DBUtil.getConnection();
  PreparedStatement ps=null;
  ResultSet rs=null;
  EntityAccessory entity = new EntityAccessory();
  String sql = "select id, file_name,file_size,file_ext_name,file_path from tbl_accessory where id=?";
  try {
   ps = conn.prepareStatement(sql);
   ps.setInt(1,id);
   rs = ps.executeQuery();
   while (rs.next()){
    entity.setId(rs.getInt("id"));
    entity.setFileName(rs.getString("file_name"));
    entity.setFileSize(rs.getDouble("file_size"));
    entity.setFile_ext_name(rs.getString("file_ext_name"));
    entity.setFilePath(rs.getString("file_path"));
   }
  } catch (SQLException e) {
   e.printStackTrace();
  }finally {
   DBUtil.close(rs,ps,conn);
  } 

  return entity;
 } 

 public static void remove(int id) {
  Connection conn = DBUtil.getConnection();
  String sql = "delete from tbl_accessory where id=?";
  try {
   PreparedStatement ps = conn.prepareStatement(sql);
   ps.setInt(1,id);
   ps.execute();
   //conn.commit(); mysql默认开启了autocommit 

   DBUtil.close(null,ps,conn);
  } catch (SQLException e) {
   e.printStackTrace();
  }
 }
}

4.新增删除文件处理器,removeUploadedFileServlet

package servlet.upload; 

import dao.upload.AccessoryDao;
import entity.upload.EntityAccessory;
import util.FileUtils; 

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException; 

/**
 * 删除已上传文件
 *
 * @author xusucheng
 * @create 2017-12-30
 **/
@WebServlet("/removeUploadedFile")
public class removeUploadedFileServlet extends HttpServlet {
 @Override
 protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
  //String filePath = request.getParameter("filePath");
  int fileId = Integer.valueOf(request.getParameter("id"));
  EntityAccessory entity = AccessoryDao.load(fileId);
  //删除文件
  FileUtils.delete(entity.getFilePath());
  //删除数据库记录
  AccessoryDao.remove(fileId); 

  //跳回到文件列表页
  //request.getRequestDispatcher("listUploadedFiles").forward(request, response);
  response.sendRedirect("listUploadedFiles");
 } 

 @Override
 protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
  doPost(request, response);
 } 

}

5.测试效果截图

删除前:

删除后:

6.下集预告

实现文件下载功能

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • JSP servlet实现文件上传下载和删除

    本文实例为大家分享了Android九宫格图片展示的具体代码,供大家参考,具体内容如下 由于存储空间,对一般用户而言,就是用来操作存储文件的,所以这两天,特意看了一下windows下用servlet实现文件上传.下载和删除,下面是详细代码说明 上传: 用的是commons-fileupload-1.2.2.jar和commons-io-2.0.1.jar组件,可以去apache官网上去下载,然后放到WebRoot/WEB-INF/lib目录下 upload.html <html> <hea

  • jsp+servlet实现文件上传与下载功能

    本文实例为大家分享了jsp servlet实现文件上传与下载的具体代码,供大家参考,具体内容如下 上传: 需要导入两个包:commons-fileupload-1.2.1.jar,commons-io-1.4.jar import java.io.File; import java.io.IOException; import java.util.List; import javax.servlet.ServletException; import javax.servlet.http.Http

  • Jsp+Servlet实现文件上传下载 文件列表展示(二)

    接着上一篇讲: Jsp+Servlet实现文件上传下载(一)--文件上传 本章来实现一下上传文件列表展示,同时优化了一下第一章中的代码. 废话少说,上代码 mysql创建附件表 DROP TABLE tbl_accessory; CREATE TABLE tbl_accessory ( id INT AUTO_INCREMENT PRIMARY KEY, file_name VARCHAR(500), file_size DOUBLE(10,2), file_ext_name VARCHAR(1

  • Jsp+Servlet实现文件上传下载 文件上传(一)

    文件上传和下载功能是Java Web必备技能,很实用. 本文使用的是Apache下的著名的文件上传组件 org.apache.commons.fileupload 实现 下面结合最近看到的一些资料以及自己的尝试,先写第一篇文件上传.后续会逐步实现下载,展示文件列表,上传信息持久化等. 废话少说,直接上代码 第一步,引用jar包,设置上传目录 commons-fileupload-1.3.1.jar commons-io-2.4.jar 上传目录:WEB-INF/tempFiles和WEB-INF

  • Jsp+Servlet实现文件上传下载 删除上传文件(三)

    接着上一篇讲:Jsp+Servlet实现文件上传下载(二)--文件列表展示 本章来实现一下删除已上传文件,同时优化了一下第一章中的代码. 废话少说,上代码得意 1.调整列表页面list.jsp <%@ page contentType="text/html;charset=UTF-8" language="java" %> <%@ taglib prefix="c" uri="http://java.sun.com/j

  • springboot操作阿里云OSS实现文件上传,下载,删除功能

    参考资料:Java操作阿里云OSS操作官方文档 学会看文档,并实际运用也是一种习惯和技能 下面就来简单入门一下,用当下比较热门的Springboot 去操作阿里云OSS文件存储. 1.需求 (没踩过下面的坑的小伙伴可以直接跳过这一章节) 问题简述 首先,我在之前自己做一些开源小项目案例中遇到一些文件上传下载的问题,比如在本机文件上传和下载都可以正常使用,通过将文件上传到Springboot项目的根目录下,按日期分文件夹,文件访问也很方便,可以直接返回文件相对路径地址,并直接可以访问. 问题 然而

  • SpringBoot整合MongoDB实现文件上传下载删除

    本文主要内容 MongoDB基础操作命令示例练习 MongoDB居于GridFSTemplate的文件上传.下载.删除等操作(工作重点使用) 1. 基础命令 创建的数据库名称:horse,创建的集合名称:blog # 创建数据库 use horse # 删除当前数据库[horse] db.dropDatebase() # 查看所有数据库 show dbs # 设置用户的角色和权限 db.createUser({user:"horse",pwd:"mongo123",

  • Java FTP上传下载删除功能实例代码

    在没给大家上完整代码之前先给大家说下注意点: FTP上传下载,容易出现乱码,记得转换 package com.yinhai.team.action; import java.io.File; import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; import java.io.OutputStream; impo

  • python FTP批量下载/删除/上传实例

    最近几天,学习python3的对FTP操作,做下总结!!!! 1.FTP链接 这样写的好处就是如果报错,很快就能找到错在哪里,方便找到问题. 2.FTP文件批量下载 有点要注意的: 如果for循环中不加while..try..except..,当然也可以下载,但经常会出现500网络连接错误类似这种错误!! 3.FTP文件批量删除 4.FTP文件上传 5.FTP关闭连接 目前就先分享到这里,新手上路多多关照!!!! 以上这篇python FTP批量下载/删除/上传实例就是小编分享给大家的全部内容了

  • Webwork 实现文件上传下载代码详解

    本文主要从三个方面给大家介绍webwork文件上传下载知识,包括以下三个方面: 1. 包装 Request 请求 2. 获取文件上传的解析类 3. 项目实战配置和使用 Web上传和下载应该是很普遍的一个需求,无论是小型网站还是大并发访问的交易网站.WebWork 当然也提供了很友好的拦截器来实现对文件的上传,让我们可以专注与业务逻辑的设计和实现,在实现上传和下载时顺便关注了下框架上传下载的实现. 1. 包装 Request 请求 •每次客户端请求 Action 时,都会调用 WebWork 调度

  • JAVA技术实现上传下载文件到FTP服务器(完整)

    具体详细介绍请看下文: 在使用文件进行交互数据的应用来说,使用FTP服务器是一个很好的选择.本文使用Apache Jakarta Commons Net(commons-net-3.3.jar) 基于FileZilla Server服务器实现FTP服务器上文件的上传/下载/删除等操作. 关于FileZilla Server服务器的详细搭建配置过程,详情请见 FileZilla Server安装配置教程 .之前有朋友说,上传大文件(几百M以上的文件)到FTP服务器时会重现无法重命名的问题,但本人亲

  • 基于SecureCRT向远程Linux主机上传下载文件步骤图解

    有时候直接在Linux服务器上通过 wget 或 curl 工具下截比较大的网络文件时会比较慢,这时我们通常会改用在Windows平台通过迅雷等更加现代化的下载功具下好目标文件(迅雷开会员才能更高速的恶心操作是题外话哈,话说我也送了不少钱给迅雷~~~),这时就面临要把Windows平台下的文件传送到远程Linux服务器上的问题了. 把Windows平台下的文件传送到远程Linux服务器上的方法有很多,这里简单记录下在当前流行的Linux远程管理工具SecureCRT下如何操作及注意事项! 先使用

  • java微信开发之上传下载多媒体文件

    回复图片.音频.视频消息都是需要media_id的,这个是需要将多媒体文件上传到微信服务器才有的. 将多媒体文件上传到微信服务器,以及从微信服务器下载文件,可以参考:http://mp.weixin.qq.com/wiki/index.php?title=上传下载多媒体文件 上传下载多媒体文件的方法还是写到WeixinUtil.java中. 代码如下: import java.io.BufferedOutputStream; import java.io.BufferedReader; impo

随机推荐