IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Java知识库 -> Spring MVC的文件上传 -> 正文阅读

[Java知识库]Spring MVC的文件上传

当信息多的时候(比如文章,图片,视频,音频,等等),我就需要以上传文件,就是将文件上传到服务器进行保存,然后将文件的名字保存到数据库表中,然后下次读取就是通过数据库中的表的文件名来在服务器中读取对应的文件,返回到前端页面给用户看。

在控制中接受文件,用到Apache的组件+SpringMVC进行封装简化接收的操作。
Apache组件将接收的二进制文件信息转换为文件,SpringMVC进一步对职工过程封装

将接受的文件存到服务器当中(IO)

搭建

导入上传下载所需要的jar包

        <dependency>
            <groupId>commons-fileupload</groupId>
            <artifactId>commons-fileupload</artifactId>
            <version>1.3.3</version>
        </dependency>

SpringMVC提供的一个文件解析器

    <!--文件解析器 defaultEncoding上传过来的编码 maxUploadSize上传最大的文件的大小-->
    <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
        <property name="defaultEncoding" value="utf-8"></property>
        <property name="maxUploadSize" value="10485760"></property>
    </bean>

控制其接受的时候:

@RequestParam(“fileName”) CommonsMultipartFile file RequestParam里的是前端接受图片的名字

● file.getOriginalFilename();获得原始文件名

● file.getContentType();获得文件类型

● file.getInputStream();获得输入流对象


我这里是用图片举例的
前端对图片的处理

这需要导入一个 ajaxfileupload.js的js


<script src="js/ajaxfileupload.js"></script>

 $.ajaxFileUpload({
                    url: 'admin/getAdmin', //用于文件上传的服务器端请求地址
                    fileElementId: 'file1', //文件上传域的ID
                    dataType: 'json', //返回值类型 一般设置为json
                    success: function (data){
                        $("#img1").attr("src", data.imgurl);
                        console.log(data);
                    }
                }
 )
 
<input type="file" id="file1" name="file" />
<input type="button" value="上传"/>

代码演示:
前端图片上传:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script type="text/javascript" src="js/jquery-1.8.3.min.js"></script>
    <script type="text/javascript" src="js/ajaxfileupload.js"></script>
    <script type="text/javascript">
        function fileUpload(){
            $.ajaxFileUpload({
                    url: 'admin/fileUpload', //用于文件上传的服务器端请求地址 调用后端数据访问接口
                    fileElementId: 'fileId', //文件上传域的ID
                    dataType: 'json', //返回值类型 一般设置为json,后端向前端返回的格式
                    success: function (data) {
                    }
                });
        }
    </script>
</head>
<body>
    上传用户头像
<input type="file" name="fileName" accept=".jqg,.png,.gif" id="fileId">
<input type="button" value="上传" onclick="fileUpload()">
</body>
</html>

后端接受处理保存:

package com.wang.ssm.controller;

import com.wang.ssm.service.AdminService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.multipart.commons.CommonsMultipartFile;

import java.io.File;
import java.io.IOException;


@RestController
@RequestMapping(path = "/admin")
public class AdminController {

    @Autowired//Spring的标签,表示将对象注入进来
    AdminService adminService;

    /*接受文件
    * Apache + SpringMVC组装的接受文件*/
    @PostMapping(value = "/fileUpload")
    //@RequestParam("fileName") CommonsMultipartFile file RequestParam里的是前端接受图片的名字
    public void fileUpload(@RequestParam("fileName") CommonsMultipartFile file){
        System.out.println(file.getOriginalFilename());//获得图片的名字
        File file1 = new File("D:\\userImg\\"+file.getOriginalFilename());
        //保存的路径+图像名字
        try {
            file.transferTo(file1);
            /*响应回路径*/
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

SpringMVC的配置文件里也要加上文件解析器
在这里插入图片描述
web里也肯定要启动SpringMVC的配置文件。

前端页面访问图片

服务器端的文件访问就必须是通过服务器来访问的。

所以在idea中就要将自己创建的包放到web中来。
在这里插入图片描述
在前端就可以以web的形式访问到文件夹中的内容。

  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2021-12-04 13:15:32  更:2021-12-04 13:20:50 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 3:19:49-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码