java前端接收回显图片_图片上传并回显后端篇

本文介绍了如何在Java Web环境中实现图片上传并回显的后端部分。首先展示了图片上传的效果,然后通过创建一个Java Web工程,搭建基本框架。文章详细解释了文件上传的思路,包括表单提交、二进制编码和Servlet处理。通过`UpImgUtils`工具类读取并处理上传的二进制流,最终将图片保存到服务器。最后,分析了临时文件的格式,解决了中文文件名乱码问题,并实现了从临时文件中提取图片内容并保存的功能。
摘要由CSDN通过智能技术生成

图片上传并回显后端篇

我们先看一下效果

1a14d189a2d7ebf43228fb5e75243490.gif

继上一篇的图片上传和回显,我们来实战一下图片上传的整个过程,今天我们将打通前后端,我们来真实的了解一下,我们上传的文件,是以什么样的形式上传到服务器,难道也是一张图片?等下我们来揭晓

我们在实战开始前呢,我们先做一下准备工作,比如新建一个java web工程,如果你不懂这个的话,那我建议你先学一下Javaweb,可以去我的公众号找一下这方面的教程。我们就给我们的工程起名为UpImg,我们再给他建一个web包和util包,再把我们以前前端做的图片回显的代码拷到工程里,我们来看一下项目

6f740198488aa7cc52a076959d95aa4f.png

我们发布一下项目来看一下

1cb6441d46b7401d661025cd2d02aecb.png

这样的话,我们基本的框架就做好了,我们今天就先用form表单来实战一下图片的上传,下一期我们就通过ajax来实现异步图片上传,我们先给我们的前端代码加点料

这个样式我就不再美化了,我们来看一下效果

324c23d5a6a7318c395ba3540d721ca3.png

这样的话,我们前端基本就完成了,我来讲解一下部分代码吧;表单的enctype属性:

1、默认属性:application/x-www-form-urlencoded,只处理表单域中的value属性值,采用这种编码的方式的表单会将表单域的值处理成url编码方式

2、multipart/form-data,这种编码方式的表单会以二进制流的方法来处理表单数据。这种编码方式会将文件域指定文件的内容也封装到请求参数里

3、text/plain,这种方式主要适用于直接通过表单发送邮件的方式

接下来我们讲解一下文件上传的思路,

1、先是表单提交

2、对数据和附件进行二进制编码

3、servlet中使用二进制流获取内容

思路我们已经知道了,那我们就开始编码吧

我们先在util包下新建一个类,我就起名为UpImgUtils,接下来我们就编码吧

package util;

import java.io.File;

import java.io.FileOutputStream;

import java.io.IOException;

import java.io.InputStream;

import javax.servlet.http.HttpServletRequest;

/**

* upload Img Utils

*

* @author admin

*

*/

public class UpImgUtils {

/*

* 思路 1、从request当中获取流信息

* 2、新建一个临时文件,用输出流指向这个文件

* 3、关闭流

*/

public static void keepFile(HttpServletRequest re

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现将本地图片以base64格式上传到后端,可以使用以下步骤: 1. 在Vue项目中安装mavon-editor插件,可以使用npm进行安装:`npm install mavon-editor --save` 2. 在需要使用编辑器的Vue组件中引入mavon-editor并注册组件: ```vue <template> <mavon-editor v-model="content" @imgAdd="handleImgAdd"></mavon-editor> </template> <script> import 'mavon-editor/dist/css/index.css' import MavonEditor from 'mavon-editor' export default { components: { MavonEditor }, data() { return { content: '' } }, methods: { handleImgAdd(data) { // 处理图片上传 } } } </script> ``` 3. 在handleImgAdd方法中,可以使用FormData对象将base64格式的图片数据上传到后端,代码如下: ```javascript handleImgAdd(data) { const file = data.file const reader = new FileReader() const vm = this reader.readAsDataURL(file) reader.onload = function() { const formData = new FormData() formData.append('image', this.result) axios.post('/upload-image', formData).then(response => { vm.content += '<img src="' + response.data.url + '">' }) } } ``` 上述代码中,我们使用FileReader对象将文件读取为base64格式,然后创建FormData对象,将base64数据作为参数添加到formData中。最后,使用axios库的post方法将formData发送到后端。当上传成功后,我们将回调函数中的response.data.url作为图片的src属性,插入到编辑器中。 4. 在后端接收base64格式的图片数据,并将其转换为文件保存到服务器,最后返回图片的URL地址。这一部分需要根据后端框架和语言进行实现,这里不做过多介绍。 以上就是使用mavon-editor将本地图片以base64格式上传到后端回显的步骤。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值