ajax+springboot传输图片到后台 并以blob形式存入数据库 --柚子真好吃

6 篇文章 0 订阅
5 篇文章 0 订阅

ajax+springboot传输图片到后台 并以blob形式存入数据库 --柚子真好吃

一、简介

  1. 本文章主要实现前端选择图片以MultipartFile形式发送至后端。
  2. 后端接收文件转化为Blob格式,存储到数据库中。

二、前端实现

  1. 同步方式代码
    	<div>
    		<form action="/sendFile" method="post" enctype="multipart/form-data">
    			<input type="file" name="file" />
    			<input type="text" name="text" />
    			<input type="submit" />
    		</form>
    	</div>
    
  2. 异步方式代码
    	<div>
    		<input id="file" type="file" />
    		<button id="showFile">wjtjcsndmy</button>
    	</div>
    
    	<script>
    	$("#showFile").on("click",function(){
    		var file = $("#file")[0].files[0];
    		console.log(file);
    		
    		var formData = new FormData();
    		formData.append("file",file);
    		
    		$.ajax({
    			url : "/sendFile",
    			data : formData,
    			type : "post",
    			processData:false,
    			contentType:false,
    			success: function(res){
    				console.log(res);
    			},
    			error:function(){
    				console.log("Hello Error!");
    			}
    		})
    		
    	})
    </script>
    

三、后端实现

  1. Controller层

    @RequestMapping(value = "/sendFile",method = RequestMethod.POST)
    public String sendFile(MultipartFile file){
        int count = fileService.saveFile(file);
        if (count == 1){
            return "Success";
        }else{
            return "Error";
        }
    }
    
  2. ServiceImpl实现类

    @Override
    public int saveFile(MultipartFile file) {
        String id = String.valueOf(UUID.randomUUID());  //生成uuid作为唯一标识
        Blob blob = null;
        try {
            blob = new SerialBlob(file.getBytes()); //将MultipartFile转 Blob
        } catch (Exception e) {
            e.printStackTrace();
        }
        return fileMapper.saveFile(id,blob);
    }
    
  3. Mapper.xml

    <insert id="saveFile">
      insert into file(fileid,file) values (#{fileId},#{file})
    </insert>
    

四、查询图片

  1. file.html

    <div>
    	<img style="width: 200px;" src="getPic?fileId=101" />
    </div>
    
  2. Controller

    @RequestMapping(value = "/getPic",method = RequestMethod.GET)
        public void getPic(HttpServletResponse response,String fileId){
            ServletOutputStream out = null;
            List<Map<String, Object>> list = fileService.getFile(fileId);
            byte[] b = (byte[]) list.get(0).get("file");
            InputStream is = new ByteArrayInputStream(b);
            response.setContentType("image/*");
            try {
                out = response.getOutputStream();
                int len = 0;
                byte[] buf = new byte[1024];
                while ((len = is.read(buf,0,1024)) != -1){
                    out.write(buf,0,len);
                }
                out.flush();
                out.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
    
        }
    
  3. Mapper.xml

    <select id="getFile" resultType="Map">
          select fileid,file from file where fileid = #{fileId}
    </select>
    
  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我是小金毛

可怜可怜孩子吧

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值