base64 json上传文件

图片转成BASE64字符串,然后以JSON的方式传递。当图片大小在1M左右的时候没问题,可以上传。但是当文件大小>1.5M的是否发现图片转BASE64不成功,居然得到的值是NULL

问题描述
图片转成BASE64字符串,然后以JSON的方式传递。当图片大小在1M左右的时候没问题,可以上传。
但是当文件大小>1.5M的是否发现图片转BASE64不成功,居然得到的值是NULL

解决办法

配置 修改Tomcat 文件夹下面server.xml 文件中 将

替换

maxPostSize=“10485760”/设置10M 重启服务就可以了

ecplise项目中有一个Server项目
有一个tomcat v7.0 Server at localhost-config,
里面也有server.xml和content.xml 直接修改这里面的文件
tomcat重新发布时会用这里的配置文件覆盖tomcat下的conf下的文件。

注意:我这里是tomcat 7.0 , 大家的可能是别的版本,方式都一样

string json = ""; string newfilename = ""; string path = ""; try { if (context.Request.Files["file_upload"] != null && context.Request.Files["file_upload"].FileName != "") { string hzm = System.IO.Path.GetExtension(context.Request.Files["file_upload"].FileName);//后缀名 如 .doc string[] a = { ".txt", ".jpg", ".jpeg", ".gif", ".png", ".docx", ".doc", ".xlsx", ".xls", ".rar", ".zip",".pdf" };//设定好了的格式 if (!a.Contains(hzm)) { json = "{\"statusCode\":\"300\",\"message\":\"文件格式不正确\",\"navTabId\":\"nav6\",\"rel\":\"\",\"callbackType\":\"\",\"forwardUrl\":\"\"}"; return json; } else { int defaulsize = Convert.ToInt32(System.Configuration.ConfigurationManager.AppSettings["filesize"]);//取得设置的默认文件的大小 int filesize = (context.Request.Files["file_upload"].ContentLength) / 1024; //取得上传的文件的大小,单位为bytes if (filesize < defaulsize) { #region 对文件进行操作 newfilename = DateTime.Now.ToString("yyyyMMddHHmmssfff") + hzm;//文件的新名字 如20120711105734222.doc path = System.Web.HttpContext.Current.Server.MapPath("~/UploadFile//");//文件保存的路径 if (!Directory.Exists(path)) { Directory.CreateDirectory(path); } #endregion } else { //超过了文件的大小 json = "{\"statusCode\":\"300\",\"message\":\"上传的文件超过了3000M,请重新选择\",\"navTabId\":\"nav6\",\"rel\":\"\",\"callbackType\":\"\",\"forwardUrl\":\"\"}"; return json; } } } } catch (Exception) { json = "{\"statusCode\":\"300\",\"message\":\"文件格式不正确\",\"navTabId\":\"nav6\",\"rel\":\"\",\"callbackType\":\"\",\"forwardUrl\":\"\"}"; return json; } if (newfilename != "") { context.Request.Files["file_upload"].SaveAs(path + newfilename); //保存文件 }
前端Base64上传文件通常是在不需要服务器直接存储临时文件的情况下,将文件内容转换成Base64编码字符串的过程。这样做可以简化前端与服务器之间的交互,特别是对于小文件或者图片、文本等非二进制大文件。 以下是基本步骤: 1. **选择文件**:使用`HTML5`的`input type="file"`让用户选择本地文件。 2. **读取文件**:获取到文件后,使用JavaScript的File API,如`FileReader`对象,读取文件内容。 3. **转化为Base64**:调用`FileReader`的`readAsDataURL()`方法,读取文件数据并将其转换为Base64字符串。 4. **发送请求**:将Base64编码后的字符串作为`Content-Type: application/json`或其他适当的格式附加到HTTP请求体中,发送给服务器。 例如,在`fetch`或`axios`这类库中,代码可能看起来像这样: ```javascript let fileInput = document.getElementById('file-input'); fileInput.addEventListener('change', async (event) => { let file = event.target.files[0]; let reader = new FileReader(); reader.readAsDataURL(file); await new Promise((resolve, reject) => { reader.onloadend = () => { let base64Data = reader.result; // 发送POST请求,将base64Data作为body的数据部分 fetch('/api/upload', { method: 'POST', body: JSON.stringify({ fileData: base64Data }) }) .then(response => response.json()) .then(data => console.log('Upload successful:', data)) .catch(error => console.error('Error uploading:', error)); resolve(); }; reader.onerror = reject; }); }); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值