HTML5+Canvas调用手机拍照功能实现图片上传(上)

发布时间 - 2026-01-11 00:46:04    点击率:

因为最近一段时间,一直在弄微信项目,其中涉及到了证件上传的功能,刚开始的时候一点头绪都没有,上网查了很多资料,QQ群里面也问了不少人,很多人说如果是app程序,可以申请系统权限,然后再去调用系统底层的东西,但是微信是在浏览器里面操作的,我们自定义的页面也是通过微信内置浏览器打开的,而且微信浏览器在内部进行了很多特殊处理,屏蔽了很多东西,所以要在页面调用拍照功能或者是打开手机系统的图库目录是不可能的,当然,这些都只是大伙儿理论上的猜测而已,而在我查了两天的资料之后,发现这个问题原来是可以解决的,而且实现的过程居然也很简单。只是用到了HTML5的file文件上传功能,再配合canvas即可。下面附上源代码:

<html> 
<meta name="viewport" content="height=device-height, width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no"> 
<meta name="format-detection" content="telephone=yes"> 
<head> 
 <meta charset="UTF-8"> 
 <title>上传证件</title> 
 <style> 
 body { 
  margin: 20px 20%; 
  color:#777; 
  text-align: center; 
 } 
 #result{ 
  margin-top: 20px; 
 } 
 </style> 
</head> 
<body> 
 <h1 class="text-center">上传证件...</h1> 
 <hr/> 
 <input type="file"/> 
 <div id="result" align="center"></div> 
 <hr/> 
 
 <!-- 引入jQuery --> 
 <script type="text/javascript" src="../js/jQuery/jquery-1.9.1.min.js"></script> 
 <script type="text/javascript" src="../js/LocalResizeIMG.js"></script> 
 
 <!-- mobileBUGFix.js 兼容修复移动设备 --> 
 <script src="../js/mobileBUGFix.mini.js" type="text/javascript"></script> 
 <script type="text/javascript"> 
 $("input:file").localResizeIMG({ 
  width: 500, 
  quality: 0.8, 
  success: function (result) { 
  var img = new Image(); 
  img.src = result.base64; 
  console.log(result.clearBase64); 
  //$("body").append(img); 
  $("#result").empty(); 
  $("#result").append(img); //呈现图像(拍照結果) 
  $.ajax({ 
   url: "upLoadImageServlet", 
   type: "POST", 
   data:{formFile:result.clearBase64}, 
   dataType: "HTML", 
   timeout: 1000, 
   error: function(){ 
   alert("Error loading PHP document"); 
   }, 
   success: function(result){ 
   //alert(result); 
   //console.log(result); 
   alert("Uploads success~") 
   } 
  }); 
  } 
 }); 
 </script> 
</body> 
</html>

上面实现的流程导致是这样的,首先在前端把图片进行压缩,因为手机的不同,可能有的手机拍照给力,像素高,拍出来的图片的大小就相对大一些,所以这里通过一个插件进行了压缩,然后转换成为Base64的编码,再把Base64的编码使用AJAX来POST到服务器,然后在Java或者PHP后台进行Base64解码,解出来的路径即为上传图片的路径地址,然后再进行存储,写到文件或者数据库里面。

此外,这里需要说明一个问题:很多人都说到了微信内置浏览器,之前我也一直认为微信内置浏览器就是微信自己开发的一套浏览器,然后对很多东西进行了限制。其实不是这样的,微信本身并没有再重新开发一套浏览器,而是调用的系统自身的浏览器,是根据手机的不同系统而变化的。微信内置浏览器调用的是手机系统默认浏览器,ios和Android系统默认浏览器都是webkit内核,只是对HTML5和CSS3的支持程度可能不同。因为浏览器只是系统的一部分,因此系统默认浏览器不会单独升级,对HTM5、CSS3的支持程度与系统版本有很大关系。安卓版微信直接调用系统浏览器内核, iOS则是调用safari,大家可以看到下面1和3的效果是一模一样的,1是微信浏览器打开的,3则是魅族MX 3自带的系统浏览器打开的效果。

上面我的我都测试过了,可以正常运行。下面附上几张照片:

1、这是在微信里面打开的效果


2、这是在手机UC浏览器打开的效果:



3、这个是在系统自带浏览器里面打开的效果(ps:我的手机是魅族MX 3),但是这个不是打开系统图库目录,而是直接定位到了系统的文件夹根目录。

下一篇会讲到在Java后台进行图片上传操作:

HTML5+Canvas+jQuery调用手机拍照功能实现图片上传(二)

插件地址:https://github.com/think2011/LocalResizeIMG

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# HTML5  # Canvas  # 手机拍照  # 图片上传  # Javascript保存网页为图片借助于html2canvas库实现  # javascript结合canvas实现图片旋转效果  # JavaScript+html5 canvas实现图片破碎重组动画特效  # HTML5+Canvas调用手机拍照功能实现图片上传(下)  # 用canvas 实现个图片三角化(LOW POLY)效果  # HTML5 canvas 9绘制图片实例详解  # Canvas + JavaScript 制作图片粒子效果  # canvas实现图片根据滑块放大缩小效果  # canvas压缩图片转换成base64格式输出文件流  # 一步步教你利用Canvas对图片进行处理  # 这是  # 是在  # 进行了  # 则是  # 上传  # 很多东西  # 魅族  # 的是  # 都是  # 我也  # 在我  # 过了  # 是这样  # 我都  # 很多人  # 这个问题  # 要在  # 两天 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel怎么生成二维码图片_Laravel集成Simple-QrCode扩展包与参数设置【实战】  UC浏览器如何切换小说阅读源_UC浏览器阅读源切换【方法】  如何在云指建站中生成FTP站点?  微信小程序 闭包写法详细介绍  儿童网站界面设计图片,中国少年儿童教育网站-怎么去注册?  Laravel Seeder怎么填充数据_Laravel数据库填充器的使用方法与技巧  Laravel如何配置和使用缓存?(Redis代码示例)  如何在阿里云服务器自主搭建网站?  Laravel Seeder填充数据教程_Laravel模型工厂Factory使用  打开php文件提示内存不足_怎么调整php内存限制【解决方案】  Laravel Artisan命令怎么自定义_创建自己的Laravel命令行工具完全指南  瓜子二手车官方网站在线入口 瓜子二手车网页版官网通道入口  如何用VPS主机快速搭建个人网站?  Windows家庭版如何开启组策略(gpedit.msc)?(安装方法)  手机网站制作与建设方案,手机网站如何建设?  Laravel如何与Docker(Sail)协同开发?(环境搭建教程)  如何在阿里云完成域名注册与建站?  JS碰撞运动实现方法详解  高防网站服务器:DDoS防御与BGP线路的AI智能防护方案  Linux后台任务运行方法_nohup与&使用技巧【技巧】  Win11怎么查看显卡温度 Win11任务管理器查看GPU温度【技巧】  如何批量查询域名的建站时间记录?  HTML5段落标签p和br怎么选_文本排版常用标签对比【解答】  Java类加载基本过程详细介绍  网页设计与网站制作内容,怎样注册网站?  Laravel如何使用Facades(门面)及其工作原理_Laravel门面模式与底层机制  如何快速查询网址的建站时间与历史轨迹?  Laravel如何使用Socialite实现第三方登录?(微信/GitHub示例)  Laravel如何获取当前登录用户信息_Laravel Auth门面使用与Session用户读取【技巧】  制作公司内部网站有哪些,内网如何建网站?  LinuxCD持续部署教程_自动发布与回滚机制  如何在HTML表单中获取用户输入并用JavaScript动态控制复利计算循环  悟空识字如何进行跟读录音_悟空识字开启麦克风权限与录音  谷歌浏览器下载文件时中断怎么办 Google Chrome下载管理修复  Android自定义listview布局实现上拉加载下拉刷新功能  logo在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo?  Win11怎么设置虚拟桌面 Win11新建多桌面切换操作【技巧】  个人摄影网站制作流程,摄影爱好者都去什么网站?  Windows11怎样设置电源计划_Windows11电源计划调整攻略【指南】  Gemini手机端怎么发图片_Gemini手机端发图方法【步骤】  Laravel怎么配置.env环境变量_Laravel生产环境敏感数据保护与读取【方法】  独立制作一个网站多少钱,建立网站需要花多少钱?  Laravel如何使用缓存系统提升性能_Laravel缓存驱动和应用优化方案  开心动漫网站制作软件下载,十分开心动画为何停播?  javascript中闭包概念与用法深入理解  如何基于云服务器快速搭建网站及云盘系统?  详解Oracle修改字段类型方法总结  Android中Textview和图片同行显示(文字超出用省略号,图片自动靠右边)  如何制作公司的网站链接,公司想做一个网站,一般需要花多少钱?  Laravel如何使用Contracts(契约)进行编程_Laravel契约接口与依赖反转