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执行以下的语 ...
随机推荐
- zabbix log(logrt) key的使用
今天看了篇帖子是关于如何利用zabbix 自带的key去读log,监控linux异常登陆,一直以来都是自己写脚本去读log的.就想看看这个zabbix log 这个key怎么样..好吧开始: 官方文档 ...
- 手机页面关于头部固定定位与input出现的问题
前些天写了一个页面,要求头部导航进行固定定位position:fixed.内容区域有输入框input.在大多数手机上都是显示正常的,可偏在一些低版本的手机却出现问题了. 把我给苦恼的不行. 问题:头部 ...
- MongoDB insert/update/one2many案例
以博文与评论为例,博文有标题内容,对应多个评论,评论有评论人.评论内容等. ()插入一条博文: db.blog.insert( {','title':'this is blog title1','co ...
- POSTGRESQL小玩
因为CDH上需要用它来建HIVE的元库... 参考: http://www.cnblogs.com/mchina/archive/2012/06/06/2539003.html 一.简介 Postgr ...
- 是用VLC API将RTSP流convert为视频文件
一直在文档中找不到,接口设计的也不大好.不过终于在stackoverflow上找到解决方案了. 原来在LIbVLC库实例化的时候就需要传递相关的参数.我的代码大致是这样实现: const char * ...
- PHP PDO 安装使用
PDO(PHP Data Object) 是PHP 5新出来的东西,在PHP 6都要出来的时候,PHP 6只默认使用PDO来处理数据库,将把所有的数据库扩展移到了PECL,那么默认就是没有了我们喜爱的 ...
- BZOJ1640: [Usaco2007 Nov]Best Cow Line 队列变换
1640: [Usaco2007 Nov]Best Cow Line 队列变换 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 493 Solved: 2 ...
- 设计模式(十五):Iterator迭代器模式 -- 行为型模式
1.概述 类中的面向对象编程封装应用逻辑.类,就是实例化的对象,每个单独的对象都有一个特定的身份和状态.单独的对象是一种组织代码的有用方法,但通常你会处理一组对象或者集合. 集合不一定是均一的.图形用 ...
- DPDK2.1开发者手册1-2
Programmer’s Guide Release 2.1.0 翻译的目的是强化自己对dpdk的理解,看看2.1版本和现在使用的版本的差异,其次就是可能要走了,为那些要上手dpdk,但是又不想看英文 ...
- arrayPointer
1,分别使用指针加减 int wages[2] = {100000000,20000000}; int *pw = wages or int *pw = &wages[0] 表示指针指向数组的 ...