javaee实验:文件上传及截器的使用

news2025/1/16 1:58:10

目录

  • 文件上传
  • @ModelAttribute注解
  • 实验目的
  • 实验内容
  • 实验过程
    • 项目结构
    • 编写代码
    • 结果展示

文件上传

Spring MVC 提供 MultipartFile 接口作为参数来处理文件上传。
MultipartFile 提供以下方法来获取上传的文件信息:
 getOriginalFilename 获取上传的文件名字;
 getInputStream 获取一个 InputStream;
 getSize 上传文件的大小
 isEmpty 文件上传内容为空,或者没有文件上传
如果上传单个文件,使用 MultipartFile 类对象接收单个上传文件,如果是同时上传多个
文件,则使用 MultipartFile 数组类来接收多个文件。
例 1:单个文件上传

@PostMapping("/upload/multipart")
@ResponseBody
public Map<String, Object> upload(@RequestParam("photo") MultipartFile
photo)
{
。。。
} 
其中,upload 方法参数类型为 MultipartFile,使用 photo 对象接收单个上传文件,
@RequestParam("photo")获取请求参数“photo”值,该变量名称与视图表单中的名称对
应。
<input type="file" name="photo" value="请选择上传的文件" />

例 2:批量文件上传

 @PostMapping("/upload/multipart1")
@ResponseBody
// 使用Spring MVC的MultipartFile类作为参数
public Map<String, Object> upload1(@RequestParam("photo") 
MultipartFile[] photos)
 {
 。。。
 }

2
其中,upload1 方法参数类型为 MultipartFile[],即使用数组来接收多个上传的文
件。这要求 HTTP 请求中包含有多个名字为“photo”的文件。

 <form method="post"
 action="./multipart1" enctype="multipart/form-data">
 <input type="file" name="photo" value="请选择上传的文件" /><p>
 <input type="file" name="photo" value="请选择上传的文件" /><p>
 <input type="file" name="photo" value="请选择上传的文件" /><p> 
 <input type="submit" value="提交" />
 </form>

@ModelAttribute注解

@ModelAttribute 注解主要是将请求参数绑定到 Model 对象上。@ModelAttribute 注解只
有一个 Value 属性,类型为 String,表示绑定的属性名称。当 Controller 类中有任意一个方法
被@ModelAttribute 注解标记,页面请求只要进入这个控制器,不管请求哪个方法,均会先
执行被@ModelAttribute 标记的方法,所以可以用@ModelAttribute 注解的方法做一些初始化
操作。当同一个 Controller 类中有多个方法被@ModelAttribute 注解标记,所有被
@ModelAttribute 注解标记的方法均会被执行,按先后顺序执行,然后再进图请求的方法。

实验目的

(1) 掌握 MultipartFile 类的使用
(2) 掌握 Spring MVC 实现文件上传方法
(3) 掌握@ModelAttribute 注解的使用方法

实验内容

(1) Spring MVC 框架实现单文件上传。
(2) Spring MVC 框架实现批量文件上传。
(3) @ModelAttribute 注解应用

实验过程

项目结构

在这里插入图片描述
当然原本uploaded里面是什么都没有的,这里本来就是存放上传的文件的地方

编写代码

FileController

import org.springframework.stereotype.Controller;
import org.springframework.util.FileCopyUtils;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.multipart.MultipartFile;

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.HashMap;
import java.util.Map;
import java.util.logging.SimpleFormatter;


@Controller
public class FileController {

    // 定义一个跳转到上传页面的方法,映射到/upload/page路径
    @GetMapping("/upload/page")
    public String uploadPage(){
        return "/file/upload";
    }

    // 定义一个处理文件上传的方法,映射到/upload/multipart路径
    @PostMapping("/upload/multipart")
    @ResponseBody
    //使用Spring MVC的MultipartFile数组作为参数,对应了保存的临时文件
    public Map<String,Object> upload(@RequestParam("photo")MultipartFile[] photos){
        String path="D:/idea/code/java/MultipartFile/src/main/resources/uploaded/";//保存路径
        // 定义一个计数器,用于记录上传成功的文件个数
        int count = 0;
        // 遍历上传的文件数组
        for (MultipartFile photo : photos) {
            // 使用日期格式化类来生成文件名
            String filename=new SimpleDateFormat("yyyyMMddHHmmssSSS").format(new Date());

            //获取上传文件的后缀suffix
            String suffix=photo.getOriginalFilename().substring(photo.getOriginalFilename().lastIndexOf("."));
            // 判断文件的后缀是否是.jpg,如果不是则跳过这个文件
            if(!suffix.equals(".jpg")){
                continue;
            }
            try {
                // 创建一个文件对象,指定保存的位置和文件名
                File destFile = new File(path + filename + suffix);
                // 判断文件的父目录是否存在,如果不存在则创建
                if (!destFile.getParentFile().exists()) {
                    destFile.getParentFile().mkdirs();
                }
                // 将文件保存到指定的位置
                photo.transferTo(destFile);
                // 将计数器加一
                count++;
            }catch (IOException e){
                // 捕获异常并打印
                e.printStackTrace();
            }
        }
        // 判断计数器是否大于零,如果是则表示有文件上传成功
        if (count > 0) {
            // 返回一个成功的提示信息
            return dealResultMap(true,"上传成功,共上传了" + count + "个文件");
        } else {
            // 返回一个失败的提示信息
            return dealResultMap(false,"上传失败,没有符合条件的文件");
        }
    }
    //处理上传文件结果
    private Map<String,Object>dealResultMap(boolean success,String msg){
        Map<String,Object> result=new HashMap<String,Object>();
        result.put("success",success);
        result.put("msg",msg);
        return result;
    }

}

upload.html

<!DOCTYPE html>
<html lang="zh-CN">
<head>
  <meta charset="UTF-8">
  <title>文件上传</title>
</head>
<body>
<h1>文件上传</h1>
<p>请选择一个.jpg格式的图片文件,然后点击上传按钮,将文件上传到服务器。</p>
<form action="/upload/multipart" method="post" enctype="multipart/form-data">
  <input type="file" name="photo" accept="image/jpeg">
  <input type="submit" value="上传">
</form>
<div id="result"></div>
<script>
  // 获取表单元素
  var form = document.querySelector("form");
  // 获取结果元素
  var result = document.getElementById("result");
  // 监听表单的提交事件
  form.addEventListener("submit", function(event) {
    // 阻止表单的默认提交行为
    event.preventDefault();
    // 创建一个FormData对象,用于封装表单数据
    var formData = new FormData(form);
    // 创建一个XMLHttpRequest对象,用于发送异步请求
    var xhr = new XMLHttpRequest();
    // 设置请求的方法和地址
    xhr.open("POST", "/upload/multipart");
    // 设置请求的响应类型为JSON
    xhr.responseType = "json";
    // 设置请求的回调函数
    xhr.onload = function() {
      // 判断请求的状态是否成功
      if (xhr.status === 200) {
        // 获取响应的数据
        var data = xhr.response;
        // 判断上传的结果是否成功
        if (data.success) {
          // 显示成功的提示信息
          result.innerHTML = "<p style='color:green'>" + data.msg + "</p>";
        } else {
          // 显示失败的提示信息
          result.innerHTML = "<p style='color:red'>" + data.msg + "</p>";
        }
      } else {
        // 显示错误的提示信息
        result.innerHTML = "<p style='color:red'>请求失败,状态码:" + xhr.status + "</p>";
      }
    };
    // 发送请求
    xhr.send(formData);
  });
</script>
</body>
</html>

MultipartFileApplication

import com.example.multipartfile.controller.FileController;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class MultipartFileApplication {

    public static void main(String[] args) {

        SpringApplication.run(MultipartFileApplication.class, args);
    }

}

结果展示

搜索自己对应的url
在这里插入图片描述
单击选择文件,打开文件夹进行文件的选择
在这里插入图片描述
选择好文件
在这里插入图片描述
点击上传
在这里插入图片描述
返回idea中查看
在这里插入图片描述
在选择的保存路径uploaded中出现了我们选择上传的图片,当然也可以选择多文件上传,只要同时选择多个文件,然后点击上传就可以了

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1281244.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

12.03 二叉树简单题2

257. 二叉树的所有路径 给你一个二叉树的根节点 root &#xff0c;按 任意顺序 &#xff0c;返回所有从根节点到叶子节点的路径。 叶子节点 是指没有子节点的节点。 示例 1&#xff1a; 输入&#xff1a;root [1,2,3,null,5] 输出&#xff1a;["1->2->5",&q…

人工智能原理复习--不确定推理

文章目录 上一篇不确定推理概述主观Bayes(贝叶斯)方法可信度方法证据理论下一篇 上一篇 人工智能原理复习–确定性推理 不确定推理概述 常识具有不确定性。 常识往往对环境有极强的依存性。 其中已知事实和知识是构成推理的两个基本要素&#xff0c;不确定性可以理解为在缺…

智跃人力资源管理系统GenerateEntityFromTable.aspx接口存在SQL注入漏洞 附POC

@[toc] 智跃人力资源管理系统GenerateEntityFromTable.aspx接口存在SQL注入漏洞 附POC 免责声明:请勿利用文章内的相关技术从事非法测试,由于传播、利用此文所提供的信息或者工具而造成的任何直接或者间接的后果及损失,均由使用者本人负责,所产生的一切不良后果与文章作者…

2023.12.03 homework

小学五年级数学&#xff0c;就有x y z&#xff0c;已经和我们念书的时代不一样了&#xff0c;以前我们是初一才有的 教育和工作一样&#xff0c;分析为什么会出现错误&#xff0c;然后如何避免该错误的出现&#xff0c;这个我们家长要关注的&#xff0c;跟工作中如何分析生产中…

ES6 Promise的用法,async/await异步处理同步化

文章目录 一、什么是promise &#xff1f;二、await / async ES7的新规范&#xff0c;异步处理同步化 一、什么是promise &#xff1f; promise是解决异步的方法&#xff0c;本质上是一个构造函数&#xff0c;可以用它实例化一个对象。对象身上有resolve、reject、all&#xff…

Docker下安装可视化工具Portainer

目录 Portainer简介 Portainer安装 Portainer简介 Portainer是一款开源的容器管理平台&#xff0c;它提供了一个易于使用的Web UI界面&#xff0c;可用于管理和监控容器和集群&#xff0c;旨在使容器管理更加简单和可视化&#xff0c;适用于各种规模的容器环境&#xff0c;从…

解决top-k问题--堆排序

目录 TOP-K问题 堆排序 考虑以下情况&#xff1a; 1.在n个数里面找最大的一个数 2.在n个数里面找最大的两个数 3.在n个数中求前k大的数 为什么不用大根堆呢&#xff1f; 代码 时间复杂度 TOP-K问题 即求数据结合中前K个最大的元素或者最小的元素&#xff0c;一般情况下数…

Sakila数据库和World数据库

Sakila数据库和World数据库 安装MySQL8.2的时候多出两个样例数据库 Sakila数据库和World数据库 Sakila数据库是一个关于DVD租赁的样例数据库&#xff0c;用于展示MySQL的各种功能和特性。Sakila数据库中包含了多个表&#xff0c;包括电影、演员、客户、租赁记录等&#xff0c;可…

美甲美睫店预约会员管理小程序作用如何

美甲美睫是美业中较为重要的类目&#xff0c;主要以小摊、门店/连锁形式&#xff0c;随着线上化程度加深&#xff0c;传统线下美业店面临着困境&#xff0c;想要进一步增长及解决痛点&#xff0c;就需要线上数字化运营得到更多生意。 那么通过【雨科】平台搭建美甲美睫店小程序…

AMBA 5 CHI 协议节点实例和读数据的来源

1. CHI协议节点实例 如上图所示&#xff0c;RN-F、RN-I、HN-F、SN-F、HN-I、SN-I通过内部互联总线连接起来。这里的ICN可以是CMN-700。其中SN-F和SN-I是连接主存&#xff0c;RN-F和HN-F内部都有cache。 2. CHI读数据的可能来源 如上图所示&#xff0c;CHI协议中可能的读数据来…

1949-2021年全国31省公路里程数据

1949-2021年全国31省公路里程数据 1、指标&#xff1a;公路里程 2、范围&#xff1a;包括31省 1978-2021年期间无缺失 3、来源&#xff1a;各省NJ、产业NJ、各省统计GB 4、指标解释&#xff1a;公路里程指报告期末公路的实际长度。 统计范围&#xff1a;包括城间、城乡间、乡…

HDMI之数据岛

概述 发送端在发送视频信号之前,将多媒体信息通过数据岛传输给接收端。接收端通过数据岛信息获取当前分辨率(VIC),编码信息(RGB/YCR等),色彩空间,位深等等。然后对应将视频信息解码。与此同时,多余的带宽用于传输音频信息等。本文通过具体的包信息(从实验室仪器拍照…

[MySQL]日期和时间函数

文章目录 1 获取日期、时间 CURDATE() &#xff0c;CURRENT_DATE()CURTIME() &#xff0c; CURRENT_TIME()NOW() / SYSDATE() / CURRENT_TIMESTAMP() / LOCALTIME() / LOCALTIMESTAMP()UTC_DATE()UTC_TIME()代码示例2 日期与时间戳的转换 UNIX_TIMESTAMP()UNIX_TIMESTAMP(date)…

使用WPF设计时绑定加快开发速度

知识来源&#xff1a;B站up主 香辣恐龙蛋 第一步 第二步

字符串冲刺题

关卡名 字符串冲刺题 我会了✔️ 内容 1.掌握最长公共前缀问题 ✔️ 2.掌握字符串压缩问题 ✔️ 3.如果想挑战一下就研究&#xff1a;表示数值的字符串 ✔️ 1 最长公共前缀 这是一道经典的字符串问题&#xff0c;LeetCode14 先看题目要求&#xff1a;编写一个函数来查找…

【Vue2】Vue的介绍与Vue的第一个实例

文章目录 前言一、为什么要学习Vue二、什么是Vue1.什么是构建用户界面2.什么是渐进式Vue的两种开发方式&#xff1a; 3.什么是框架 三、创建Vue实例四、插值表达式 {{}}1.作用&#xff1a;利用表达式进行插值&#xff0c;渲染到页面中2.语法3.错误用法 五、响应式特性1.什么是响…

OpenOffice 4.1.14的安装以及与数据库进行连接

起因&#xff1a;因为MS Office的Access只能和自家的数据库连接&#xff0c;感觉不太舒服&#xff0c;因此尝试使用Openoffice组件中的Base进行替换。这里记录一下从安装到进行数据库连接的过程。 1.下载地址 https://www.openoffice.org/download/index.html 我这里是Debian1…

ArcGIS制作某村土地利用现状图

1. 根据坐落单位名称属性选择并提取作图数据 (1) 将“作图线状地物”、“作图图班”和“村庄”图层加入ARCGIS&#xff08;右键Layers-Add data&#xff09;&#xff0c;选择相应路径下的文件加载即可。 (2) 按属性来提取作图村庄的地类图班、线状地物和村界文件&#xff08;…

(Python) 特殊变量

整体 内置模块 name 用到的模块 对象 函数

AGNES层次聚类

已知数据集D中有9个数据点&#xff0c;分别是(1,2)&#xff0c;(2&#xff0c;3)&#xff0c;(2,1), (3,1),(2,4),(3,5),(4,3),(1,5),(4,2)。要求&#xff1a; (1)采用层次聚类的聚集算法进行聚类&#xff0c;k2。 (2)距离计算采用欧几里得距离。 (3)簇之间的距离采用单链接方…