JS将图片文件转为64位字符串再post到接口上传图片
HTML:
<div class="ai-item upload-id-img">
<p>上传身份证照片</p>
<div class="img-box">
<div class="positive-img">
<input type="file" id="img1" name="zm" class="inputFile">
<label for="img1">
<img src="http://pic.biyabi.com/h5/images/fm-img.png" id="preview">
</label>
</div>
<div class="opposite-img">
<input type="file" id="img2" name="fm" class="inputFile">
<label for="img2">
<img src="http://pic.biyabi.com/h5/images/zm-img.png" id="preview2">
</label>
</div>
</div>
</div>
可以通过给input上传控件设置样式不显示,给对应的的img标签注册点击事件来点击上传控件,相当于间接点击了上传控件
.inputFile {
width: 1px;
height: 1px;
opacity:;
overflow: hidden;
position: absolute;
z-index: -1;
}
js 实现:
//编辑页面上传图片
$('#img1').on('change', function () {
setImgPreview('img1', 'preview');
});
$('#img2').on('change', function () {
setImgPreview('img2', 'preview2');
});
//上传图片
function setImgPreview(imgObj, prev) {
var docObj = $("#" + imgObj);
var imgObjPreview = $("#" + prev);
//异步上传图片
uploadImage(docObj, imgObjPreview)
}
function uploadImage(docObj, imgObjPreview) {
//判断是否有选择上传文件
var imgPath = docObj.val();
if (imgPath == "") {
//alert("请选择上传图片!");
hDialog.show({ type: 'toast', toastText: '请选择上传图片!', toastTime: 3000, hasMask: false });
return;
}
//判断上传文件的后缀名
var strExtension = imgPath.substr(imgPath.lastIndexOf('.') + 1).toLowerCase();
if (strExtension != 'jpg' && strExtension != 'gif'
&& strExtension != 'png' && strExtension != 'bmp') {
//alert("请选择图片文件!");
hDialog.show({ type: 'toast', toastText: '请选择图片文件!', toastTime: 3000, hasMask: false });
return;
}
var ImgObj = new Image(); //建立一个图像对象
var AllowImgFileSize = 2100000; //上传图片最大值(单位字节)( 2 M = 2097152 B )
ImgObj.src = docObj[0].value;
//checkSizeofImg();
//function checkSizeofImg() {
// if (ImgObj.readyState != "complete") { //如果图像是未加载完成进行循环检测
// setTimeout("checkSizeofImg()", 500);
// //return false;
// }
//}
//ImgObj.onload = function () {
// ImgFileSize = Math.round(ImgObj.fileSize / 1024 * 100) / 100;//取得图片文件的大小
// if (AllowImgFileSize != 0 && AllowImgFileSize < ImgFileSize) {
// hDialog.show({ type: 'toast', toastText: '上传失败,请上传不大于2M的图片!', toastTime: 3000, hasMask: false });
// return;
// }
//}
//var file = $("#" + imgObj).files[0];
var reader = new FileReader();
var file = docObj[0].files[0];
var imgUrlBase64;
if (file) {
//将文件以Data URL形式读入页面
imgUrlBase64 = reader.readAsDataURL(file);
reader.onload = function (e) {
//var result = document.getElementById("result");
var ImgFileSize = reader.result.substring(reader.result.indexOf(",") + 1).length;
if (AllowImgFileSize != 0 && AllowImgFileSize < ImgFileSize) {
hDialog.show({ type: 'toast', toastText: '上传失败,请上传不大于2M的图片!', toastTime: 3000, hasMask: false });
return;
}
//显示文件
imgObjPreview.attr("src", reader.result);
//字符串形式上传 //data:image/png;base64,
var imgDataBase64 = imgObjPreview.attr("src").substring(imgObjPreview.attr("src").indexOf(",") + 1);
$.ajax({
type: 'post',
dataType: 'json',
data: { "_Image": imgDataBase64, "_format": "." + strExtension },
url: ajaxUrl + 'UploadIDCartImageBase64',
success: function (data) {
if (data) {
imgObjPreview.attr("src", data);
$("." + docObj.attr("name")).val(data);
docObj.parent().find('.logo-img2').remove();
}
},
//此接口返回的图片路径是error的响应文本
error: function (xhr) {
imgObjPreview.attr("src", xhr.responseText);
$("." + docObj.attr("name")).val(xhr.responseText);
docObj.parent().find('.logo-img2').remove();
},
beforeSend: function () {
var logoImg = '<img src="../images/loanding.gif" class="logo-img2" style="position: absolute;left: 50%;top: 50%;width: 20px; height: 20px; -webkit-transform: translate(-50%,-50%);">';
docObj.parent().append(logoImg);
}
});
}
reader.onerror = function () {
alert("error");
}
}
}
最终展示图

JS将图片文件转为64位字符串再post到接口上传图片的更多相关文章
- js如何将选中图片文件转换成Base64字符串?
如何将input type="file"选中的文件转换成Base64的字符串呢? 1.首先了解一下为什么要把图片文件转换成Base64的字符串 在常规的web开发过程中,大部分上传 ...
- 检查DLL,EXE文件是64位或者32位的方法
检查DLL,EXE文件是64位或者32位:输入corflags <assembly path>:
- .netcore 文件上传转为base64位字符串
.netcore文件上传Api接口,和正常的webForm提交类似,只是用postman测试接口时,记得给form表单命名,否则获取上传文件数量一直为0 后端代码 using System; usin ...
- js 将图片文件转换成base64
1.情景展示 在JavaScript中,如何使用图片文件转换成base64? 2.解决方案 /** * 网络图像文件转Base64 * @param img dom对象 */ function g ...
- 利用linux判断elf文件是64位还是32位
readelf 命令,参数为-h 例如 文件名为python >>>readelf -h python 得到的是ELF Header中的项Magic 第五个数 02时为64位,01时 ...
- Android从本地选择图片文件转为Bitmap,并用zxing解析Bitmap
如何从本地选择图片文件 使用Intent调用系统相册后,onActivityResult函数返回的是Uri格式的路径 /** * 打开系统相册 */ private void openSysAlbum ...
- api图片传输,转成64位字符串进行传输
byte[] getImageByte = HttpHelper.getImageByte(HttpContext.Current.Server.MapPath(("~/UploadFile ...
- 64位系统下注册32位dll文件
64位系统下注册32位dll文件 在64位系统里注册32位软件所需的一些dll会提示不兼容,大概因为32 位进程不能加载64位Dll,64位进程也不可以加载32的导致. 若要支持的32 位和64 位C ...
- win7(64位)Sql server 用T-sql读取本地数据文件dbf的数据文件
原文地址:https://www.cnblogs.com/cl1006/p/9924066.html 第一步启用Ad Hoc Distributed Queries 在SQLserver执行以下的语 ...
随机推荐
- linux磁盘空间用满的处理方法
linux下空间满可能有两种情况 可以通过命令 df -h 查看磁盘空间占用,实际上是查看磁盘块占用的文件(block) df -i 查看索引节点的占用(Inodes) 磁盘块和索引节点其中之一满 ...
- Nginx源码研究一:NGINX模块启动
Nginx 是一个轻量级,但是高性能的 HTTP 和 代理 服务器,也是一个 IMAP/POP3/SMTP代理服务器. 它的第一个版本0.1.0是由俄罗斯的工程师Igor Sysoev与2004年10 ...
- linux下实现rm()函数删除文件或目录
转载请注明原创:http://www.cnblogs.com/StartoverX/p/4600866.html 在linux下有两个函数可以用来删除文件: #include <unistd.h ...
- linux 命令行更新sdk
./android list sdk --proxy-host android-mirror.bugly.qq.com --proxy-port 8080 --no-ui -a -s ./androi ...
- Windows 批处理文件
窗口自动关闭:批处理文件执行完之后,窗口会自动关闭,若想执行完之后,窗口不自动关闭的话,在文件末尾添加1. 批处理文件执行完之后,窗口会自动关闭2. 若想执行完之后,窗口不自动关闭的话,在文件末尾添加 ...
- iOS开发之UIWebView自动滑动到顶部-备
但可以通过subview来操作. 通常用UIWebView加载网页,有时候需要点击一个按钮,或者页面的某个部位,使页面自动滚动到顶部,但是UIWebView不像UIScrollView那么方便. ...
- 解读 《2014 最流行编程语言》 by Code Eval
此文已转至http://cn.abnerchou.me/2014/02/23/fa87ae80/ 原文:点我 原文翻译:点我 首先了解下CodeEval是做什么的: A tool for auto e ...
- 从win7到mac os再到win10,体验总结
首先介绍自己的身份,软件工程毕业,现在IT男一枚,php程序员(前端必须会的啦). 原先自己用的是win7系统,大学四年都在用,所以习惯了.开发方式也是传统式的,以文件概念为主(就是手动管理文件),版 ...
- 安卓应用使用QQ登录的申请流程
“QQ互联”是腾讯为第三方网站.媒体.终端提供的开放平台.QQ互联拥有8个组件,提供诸如分享.登陆.like.qq提醒等能力.开发者使用QQ帐号登陆组件可以降低了用户的注册门槛,减少注册环节的用户流失 ...
- 什么时候使用NO_UNNEST
select * from test a where object_id in (select department_id from hr.dept_1 dept where department_i ...