HTML5 通过 FileReader 实现文件上传

本文介绍如何利用HTML5的FileReader将文件转换为Base64编码,再通过AJAX实现文件上传。前端使用JavaScript读取文件并发送请求,后端接收Base64编码并转换为文件。

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

概述

在页面中上传时,之前一般都是需要使用form表单进行上传。html5 中提供了FileReader 可以将文件转换成Base64编码字符串,因此就可以直接使用

AJAX实现文件上传。

 

实现代码

1.前端JS代码

var url= /*[[@{/sys/upload}]]*/ ;
    function uploadFile(){
        var file = document.getElementById("file").files[0];
        var reader = new FileReader();
        reader.readAsDataURL(file);
        reader.onload = function(e){ 
            // ajax 上传图片
            $.post(url, { data: e.target.result},function(ret){
               console.info(ret);
            },'json');
        } 
    }

2.后端代码

@RequestMapping("/sys/upload")
    public JSONObject upload(HttpServletRequest request) {
        JSONObject json=new JSONObject();
        String data=request.getParameter("data");
        
        int  idx=data.indexOf(",");
        String fileBase64=data.substring(idx+1);
        byte[] fileBytes= Base64.decodeBase64(fileBase64);
        
        writeByte("d:\\file.jar", fileBytes);
        
        json.put("success", true);
       
        return json;
    }

在后端代码接收的是base64 编码,转换成bytes后写入文件。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值