Base64上传文件(图片)

本文介绍了Base64编码在图片上传中的应用,包括其将文件转码后增大1.5倍的特性,通常用于单图片直接入库操作。提供了一个前端JSP页面的示例代码,展示了如何通过FileReader接口读取图片并转换为Base64字符串,以及使用jQuery进行AJAX提交。后端使用SpringMVC接收Base64字符串并进行处理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

base64优缺点简介:

1:base64在对图片等文件进行转码后的大小是原来的1.5倍左右。

2:一般我们都是用base64进行单图片上传,直接入库的操作(单独的图片库)

3:base64在特殊情况下也可进行多图片传输(图片内存总和小于2MB)

 

前端jsp完整代码

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>

<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>

<%String path = request.getContextPath();

String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";

%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">

<html>

           <head><base href="<%=basePath%>"></head>

<body>

          <div class="myFeedback">

                <!-- 获取文件 -->

              <p class="imgProve">

                     <input type="file" />

                    <img src=""/>

               </p>

               <!-- 单击事件 -->

              <p class="submit"> 提交异议</p>

              </div>

</body>

<script src="inc/jquery-1.8.3.js"></script>

<script type="text/javascript">

(function($) {

       //执行获取图片文件

       $('.myFeedback .imgProve input').change(function(){

               var reader = new FileReader();

               reader.readAsDataURL(this.files[0]);

               reader.onload = function(e) {

                       $('.myFeedback .imgProve img').attr('src', this.result);

               }

        })

       //提交触发ajax

      $('body').on('click','.myFeedback .submit',function(){

             var formDate = {};

             formDate.imgProve = $('.imgProve img').attr('src');

             $.ajax({

                   type: "POST",

                   url: "SpringMVC/upload3",

                   data: { formDatas: JSON.stringify(formDate) },

                   success: function(data) {}

             })

     })

}(jQuery));

</script>

</html>

 

后端代码:

@RequestMapping(value = "upload3",method = RequestMethod.POST)

@ResponseBody

public void filesUpload3(HttpServletResponse response,

@RequestParam("formDatas") String t

) throws IOException{

      JSONObject j1 = JSONObject.fromObject(t);

       System.out.println("j1="+j1);

}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值