JS 利用 webcam访问摄像头 上传到服务器

webcam JS 较为详细的指南

定义标题

<!doctype html>
<html>
<head><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>How to capture picture from webcam with Webcam.js</title></head>
<body>  
  • <meta> 标签用于设置页面的视口(viewport),
  • content 属性指定了视口的宽度为设备的宽度,并启用了初始缩放比例为 1.0。这样可以确保页面在不同设备上以适当的方式显示。
  • <title> 标签定义了页面的标题,显示在浏览器的标签页或标题栏上,本例中标题为 “How to capture picture from webcam with Webcam.js”。

定义my_camera样式

	<!-- CSS --><style>	<!-- 定义my_camera样式 -->#my_camera{width: 320px;height: 240px;border: 1px solid black;}</style>
  • 这段代码定义了一个样式规则,在 HTML 页面中为 id 为 “my_camera” 的元素应用了该样式。
  • 在样式规则中,width 属性设置了元素的宽度为 320 像素,height 属性设置了元素的高度为 240 像素,border 属性设置了元素的边框为 1 像素的黑色实线。
  • 这段代码可以用于定义一个相机显示区域的样式,使其具有固定的宽度和高度,并且有一个黑色的边框。

JS.div

  • HTML 的 <div> 是一个块级元素。它是一个无语义的容器元素,用于将其他元素分组在一起,以便样式和布局的目的。
  • <div> 元素没有默认的样式或行为,仅仅提供了一个空的盒子,可以通过 CSS 来自定义其外观和行为。
  • <div> 元素可以包含其他任意元素,包括文本、图片、表单等等。

define a device

	<!-- --><div id="my_camera"></div><input type=button value="Configure" onClick="configure()"><input type=button value="Take Snapshot" onClick="take_snapshot()"><input type=button value="Save Snapshot" onClick="saveSnap()"><div id="results"  ></div>
  • 这段代码是一个 HTML 页面的主体部分,包含了一个用于显示摄像头视频的容器、三个按钮和一个用于显示结果的容器。
  • <div id="my_camera"></div> 是一个空的 <div> 元素,它的 id 属性被设置为 “my_camera”。这个元素用于显示摄像头视频,后面的 JavaScript 代码会将摄像头视频渲染到这个元素中。
  • <input> 元素是用来创建按钮的,有三个按钮分别是 “Configure”、“Take Snapshot” 和 “Save Snapshot”。每个按钮都有一个 onClick 属性,用于指定按钮被点击时所触发的 JavaScript 函数。
  • 接下来的代码 <div id="results"></div> 是另一个空的 <div> 元素,它的 id 属性被设置为 “results”。这个元素用于显示操作结果,例如当用户点击 “Save Snapshot” 按钮时,JavaScript 代码会将截取的照片显示在这个元素中。

define js action

	<!-- Script --><script type="text/javascript" src="webcamjs/webcam.min.js"></script>...</script>
  • 这行代码是在 HTML 页面中引入了一个外部的 JavaScript 文件。
  • 通过使用 <script> 标签和 src 属性,可以将 webcam.min.js 文件加载到页面中。
  • 这个文件是 webcam.js 库的压缩版本,它提供了一些用于操作和控制摄像头的函数和方法,以便在网页中捕捉图像或视频。通过引入这个 JavaScript 文件,可以在后续的代码中使用这个库提供的功能。

webcam.min.js

set style of camera

	<!-- Code to handle taking the snapshot and displaying it locally --><script language="JavaScript">// Configure a few settings and attach camerafunction configure(){Webcam.set({width: 320,height: 240,image_format: 'jpeg',jpeg_quality: 90});Webcam.attach( '#my_camera' );}// A button for taking snaps

navigator

navigator 是 JavaScript 中的一个内置对象,用于提供有关浏览器环境和用户代理的信息。它包含了一系列的属性和方法,可以用来获取和操作与浏览器相关的信息。下面是一些 navigator 对象的常用属性:

  • navigator.userAgent:返回包含浏览器用户代理字符串的字符串。
  • navigator.language:返回当前浏览器环境的首选语言。
  • navigator.platform:返回运行浏览器的操作系统平台。
  • navigator.appVersion:返回浏览器的版本号和操作系统信息。

通过使用 navigator 对象,可以根据浏览器的不同特性和功能来进行相关的逻辑判断和操作,从而提供更好的用户体验或调整功能的实现方式。

		// preload shutter audio clipvar shutter = new Audio();shutter.autoplay = false;shutter.src = navigator.userAgent.match(/Firefox/) ? 'shutter.ogg' : 'shutter.mp3';

take snapshot

		function take_snapshot() {// play sound effectshutter.play();// take snapshot and get image dataWebcam.snap( function(data_uri) {// display results in pagedocument.getElementById('results').innerHTML = '<img id="imageprev" src="'+data_uri+'"/>';console.log('Capture successfully');} );Webcam.reset();}

Question what’s data_uri

在JavaScript中,data URI(Uniform Resource Identifier)是一种用来嵌入小型数据的方式。它是一种特殊的URL格式,可以将数据直接嵌入到HTML、CSS、JavaScript等文件中,而无需引用外部资源文件。* Data URI的格式如下:data:[mediatype][;base64],<data>其中,mediatype是数据的MIME类型(例如,image/jpeg表示JPEG格式的图像,text/plain表示纯文本),base64是可选的,表示是否使用base64编码,<data>是实际的数据内容。* 例如,一个包含了纯文本的data URI如下:data:text/plain,Hello%20World!* 一个包含了base64编码图像的data URI如下:data:image/jpeg;base64,/9j/4AAQSkZJRgABAQEASABIAAD...(以下省略)

Display

上面的id="imageprev"的datauri如下,严格按照 😊 base64编码的图像格式 😊
在这里插入图片描述

data URI的优点是可以减少HTTP请求数量,提高网页的加载速度。但是,由于数据直接嵌入到文件中,会增加文件的大小,可能导致文件变得更大,在一些情况下可能不适用。另外,不同浏览器对data URI的限制也有所不同,需要注意兼容性问题。

savesnap

		function saveSnap(){// Get base64 value from <img id='imageprev'> sourcevar base64image =  document.getElementById("imageprev").src;Webcam.upload( base64image, 'upload.php', function(code, text) {console.log('Save successfully');//console.log(text);});}</script></body>
</html>

upload.php

<?php// new filename
$filename = 'pic_'.date('YmdHis') . '.jpeg';$url = '';
if( move_uploaded_file($_FILES['webcam'][$filename],'upload/'.$filename) ){$url = 'http://' . $_SERVER['HTTP_HOST'] . dirname($_SERVER['REQUEST_URI']) . '/upload/' . $filename;
}// Return image url
echo $url;
?>

upload.js

  • 尚未成功
```javascript 
// 获取base64图片数据
var base64Image = document.getElementById('imageprev').src;// 将base64图片数据转换为Blob对象
var byteCharacters = atob(base64Image.split(',')[1]);
var byteNumbers = new Array(byteCharacters.length);
for (var i = 0; i < byteCharacters.length; i++) {byteNumbers[i] = byteCharacters.charCodeAt(i);
}
var byteArray = new Uint8Array(byteNumbers);
var blobImage = new Blob([byteArray], { type: 'image/jpeg' });// 创建一个FormData对象
var formData = new FormData();
formData.append('webcam', blobImage, 'image.jpeg');// 创建一个XMLHttpRequest对象
var xhr = new XMLHttpRequest();// 定义请求完成后的回调函数
xhr.onload = function() {if (xhr.status === 200) {var imageUrl = xhr.responseText;console.log('图像已上传,URL为:', imageUrl);} else {console.log('上传图像时发生错误');}
};// 发送POST请求到服务器的/upload文件夹
xhr.open('POST', '/upload', true);
xhr.send(formData);

文件上传by php

php.move_uploaded_file
在这里插入图片描述
php.$_FILES
tomcat&php&mysql

upload by js

Blob、File 、DataURL(Base64)、BlobURL 之间的类型闭环,你确定都知道?

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/796024.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

stm32开发之threadx使用记录(主逻辑分析)

前言 threadx的相关参考资料 论坛资料、微软官网本次使用的开发板为普中科技–麒麟&#xff0c;核心芯片为 stm32f497zgt6开发工具选择的是stm32cubemx(代码生成工具)clion(代码编写工具)编译构建环境选择的是arm-none-gcc编译 本次项目结构 CMakeList对应的配置 set(CMAKE_…

Thinkphp5萤火商城B2C小程序源码

源码介绍 Thinkphp5萤火商城B2C小程序源码&#xff0c;是一款开源的电商系统&#xff0c;为中小企业提供最佳的新零售解决方案。采用稳定的MVC框架开发&#xff0c;执行效率、扩展性、稳定性值得信赖。 环境要求 Nginx/Apache/IIS PHP5.4 MySQL5.1 建议使用环境&#xff…

微信小程序开发学习笔记——4.6tabBar底部tab栏配置用法

>>跟着b站up主“咸虾米_”学习微信小程序开发中&#xff0c;把学习记录存到这方便后续查找。 一、tabBar https://developers.weixin.qq.com/miniprogram/dev/reference/configuration/app.html#tabBar 二、icon下载 https://www.iconfont.cn/collections/index?spma…

Docker详细安装与使用教程:从入门到实践

引言 Docker作为一种轻量级的容器化技术&#xff0c;以其隔离、便携、高效的特性&#xff0c;极大地简化了应用的部署、管理和扩展过程。本篇教程将带领您从零开始&#xff0c;逐步掌握Docker的安装、基础操作、镜像管理、容器运行以及网络与数据卷设置&#xff0c;助您…

springcloud第4季 使用resilience4j实现服务流量治理

一 前言 1.1 断路器介绍 断路器是一种开关装置&#xff0c;当某个服务单元发生故障后&#xff0c;通过断路器向调用方返回一个符合预期&#xff0c;可处理的备选响应。保证服务不会被长时间&#xff0c;不必要的占用&#xff0c;从而避免在分布式系统故障的蔓延、乃至雪崩。…

MBTI职业性格大解析:测测你更适合哪种工作?(包含开源免费的API)

MBTI简介 MBTI是根据荣格的心理类型理论著成&#xff0c;已经成为权威的性格测试。 MBTI&#xff08;Myers-Briggs Type Indicator&#xff09;&#xff0c;是一种迫选型、自我报告式的性格评估测试&#xff0c;用以衡量和描述人们在获取信息、作出决策、对待生活等方面的心理…

C++学习——指针篇

本篇文章记录我学习C的指针内容&#xff0c;希望我的分享能给你带来不一样的收获&#xff01; 目录 一、指针有什么好处 二、什么是指针 三、C指针内容详解 &#xff08;一&#xff09;、空指针&#xff08;Null&#xff09; &#xff08;二&#xff09;、指针的算数运算 …

DL00198-基于3DUnet的脑肿瘤语义分割完整代码+数据集含输出结果

完整代码数据集见文末 3DUNet是一种卷积神经网络&#xff08;CNN&#xff09;&#xff0c;专为处理3D图像而设计。它基于U-Net架构&#xff0c;是一种对称的卷积网络&#xff0c;具有上采样和下采样的过程。PyTorch 3DUNet在U-Net的基础上添加了更多的卷积层和跳跃连接&#xf…

PostCSS安装以及使用详解

PostCSS是一个用于处理CSS的工具&#xff0c;它基于Node.js采用插件体系&#xff0c;允许开发者通过使用插件来转换、优化和处理CSS代码。下面将详细介绍PostCSS的安装和使用方法。 一、安装PostCSS PostCSS的安装主要依赖于Node.js和npm&#xff08;Node.js包管理器&#xf…

关于Spring Boot

一、Spring Boot简介与背景 在当前的Java应用程序开发领域&#xff0c;Spring Boot 已经成为了一种非常受欢迎的选择。Spring Boot是Spring Framework的一种扩展&#xff0c;旨在简化基于Spring的应用程序的开发和部署过程。它的出现填补了许多传统Spring开发中的空白&#xf…

在git上先新建仓库-把本地文件提交远程

一.在git新建远程项目库 1.选择新建仓库 以下以gitee为例 2.输入仓库名称&#xff0c;点击创建 这个可以选择仓库私有化还公开权限 3.获取仓库clone链接 这里选择https模式就行&#xff0c;就不需要配置对电脑进行sshkey配置了。只是需要每次提交输入账号密码 二、远…

大语言模型RAG项目实战

学习完大语言模型落地的关键技术&#xff1a;RAG的相关概念&#xff0c;我们今天来用代码实现一下RAG。 项目实战&#xff1a;基于百度ERNIE SDK 和 LangChain 搭建个人知识库。 1、安装ERNIE Bot !pip install --upgrade erniebot测试embedding import erniebot erniebot.…

网站基本建设基本上步骤

网站基本建设基本上步骤 一.领取一个免费域名和SSL证书&#xff0c;和CDN 1.打开网站链接&#xff1a;https://www.rainyun.com/ycpcp_ 首先创建一个CDN&#xff0c;这里以我加速域名“cdntest.biliwind.com 1”为例 这里就要填写 cdntest.biliwind.com 1 &#xff0c;而不是…

4.1 JavaScript的使用

JavaScript有两种使用方式&#xff1a;一是在HTML文档中直接添加代码&#xff1b;二是将JavaScript脚本代码写到外部的JavaScript文件中&#xff0c;再在HTML文档中引用该文件的路径地址。 这两种使用方式的效果完全相同&#xff0c;可以根据使用率和代码量选择相应的开发方式。…

day19-归并两个有序数组

问题描述&#xff1a; 给你两个按 非递减顺序 排列的整数数组 nums1 和 nums2&#xff0c;另有两个整数 m 和 n &#xff0c;分别表示 nums1 和 nums2 中的元素数目。 请你 合并 nums2 到 nums1 中&#xff0c;使合并后的数组同样按 非递减顺序 排列。 注意&#xff1a;最终…

Qt5.15以上版本在线安装步骤,可选择更多早期版本

以ubuntu系统为例&#xff1a; 1、先去下载在线安装程序&#xff1a; https://download.qt.io/official_releases/online_installers/ 选择合适的版本&#xff0c;这里是在x64机器的ubuntu虚拟机里安装QT&#xff0c;所以选择如下版本&#xff1a; 或者直接在终端执行如下命令…

Qt | 元对象系统

一、QByteArray 类简介 1、QByteArray 类简介  该类是一个用于处理字符串的类似于 C++的 string 类型的类,在 Qt 中,对字符串的处理,经常使用的是 QString 类,该类保证字符串以\0结尾,并使用隐式共享(copy-on-write)来减少内存用量和不必要的数据复制。  QByteArra…

【ControlNet v3版本论文阅读】

网络部分最好有LDM或者Stable Diffusion的基础&#xff0c;有基础的话会看的很轻松 Abstract 1.提出了一种网络结构支持额外输入条件控制大型预训练的扩散模型。利用预训练模型学习一组不同的条件控制。 2.ControlNet对于小型&#xff08;<50k&#xff09;或大型&#xff…

Halcon的HWindowControl控件在C#WinForm中的使用介绍(包括绘制ROI)

Halcon的HSmartWindowControl控件在C#WinForm中的使用介绍&#xff08;包括绘制ROI&#xff09; 文章目录 Halcon的HSmartWindowControl控件在C#WinForm中的使用介绍&#xff08;包括绘制ROI&#xff09;一、 引入hSmartWindowControl控件二、 编写打开图像功能三、 编写绘制RO…

如何保护您的企业免受人工智能生成的深度伪造品的侵害

最近&#xff0c;网络犯罪分子利用一家跨国公司高管的“深度伪造”视频&#xff0c;说服该公司驻香港的员工汇出 2560 万美元。 根据包含多个 Deepfake 的视频电话会议&#xff0c;员工认为是他们驻英国的首席财务官要求转移资金。 据报道&#xff0c;警方已逮捕六名与该诈骗案…