Esp32Cam WebServer 网页源代码查看与编辑

Esp32Cam WebServer 网页源代码查看与编辑

  • date: 2022-01-12
  • lastmod: 2022-01-12

原文地址

背景介绍

为 Esp32 Cam 配置 Arduino 开发环境并人脸识别测试 中成功运行了开发板自带的示例程序,在网页中看到了摄像头的实时画面。然后这个开发板就在我的某创盒子了呆了几年吧。今年掏出来试试是因为 foldscope 试镜失败,尝试下手机摄像头观察发现可行,于是才掏出这个 esp32cam,根据同样的原理,最后在自己组装的纸片上也成功了,原因是把 z 轴拉到极限就可以了。

但是很奇怪的是和“安信可科技](https://docs.ai-thinker.com/esp32-cam)”给出的案例不同,我的网页中显示的图片右上角没有保存(Save)按钮,代码 bug 很正常的嘛,于是找源码看看,在源代码中用搜索字符串的方式也没有找到网页代码在哪里,就这么点地方,愣是没有看到我所熟悉的 HTML,一时半会没整明白。后来在 gitee 找到了一个狠人把这个页面由英文改为中文,但是代码(技术宅物语 / ESP32-CAM-WEB摄像头)里也是没有 html 代码,在评论区里链接的文章了解了怎么操作的,最后也找到了 esp32cam WebServer的最新版代码,跑起来看到了期待的 save。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-BbVYoQyX-1641972984186)(…/…/static/images/esp32camWeb/webPreview.jpeg)]

转换的机制

html 转无符号数组

之前在太极创客的案例里都是直接写 html 字符串插入到代码里,或者直接 html 文件存储到内存里直接引用,说白了就是未经优化的原文。一般长下面这样

<!doctype html>
<html>
    <head>
        <meta charset="utf-8">
        <meta name="viewport" content="width=device-width,initial-scale=1">
        <title>Robot Zero One Was Here</title>
    </head>
    <body>
        <div id="logo">
            <label for="nav-toggle-cb" id="nav-toggle">&#9776;&nbsp;&nbsp;Toggle settings</label>
         </div>
    </body>
</html>

然后可以看到里面有空格,为了最小化存储,我们可以删除空格,这不会影响浏览器渲染的结果,然后就开始压缩了,使用的工具是 gzip,编码方式是霍夫曼编码,最后压缩成一堆一眼看不懂的 0 和 1,然后用十六进制的方式(0x1f0x8b0x080x080xfd0x7d…)描述这些01,最后把这些十六进制分隔开存储到数组(uint8_t index_ov2640_html_gz[])里。

说了那么多不如实践一下,CyberChef 给出了一个案例,可以使用 STEP 看一下每一步的过程,最后要到数组的话需要去掉第一个逗号,加上花括号。

数组转 html

反向操作一波即可。我把上面的案例逆向了一波,看这个

参考

  • 3
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
在上一期的免费项目:高性价比WIFI图传方案快速入门教程的介绍中,详细地介绍了ESP32-CAM模块的简单使用 ,其裁剪了官方图传和人脸识别的代码改造成简单的图传代码,由官方四个文件的代码缩减成一个文件的代码。目的就是让买家能快速上手这个源码。让这个源码复杂度降低很多,利于阅读和学习。 在这一期的免费项目:修改了上一期的项目的源码,实现嵌入式web server功能实现远程浏览器WIFI点灯的操作(PIN4的IO口集成了闪光灯LED,所以不用外接灯了,亮瞎眼的亮度),实现了将服务器嵌入到单片机,单片机wifi联网之后,局域网访问单片机主页(通过串口打印的网址)就可以在网页里面控制开发板的灯,该设计是ESP32-CAM物联网应用的一个巨大的尝试,本人浪费生命值写了两天代码,踩了很多坑,也学到很多,写了一共三个版本的代码,此版本的代码是最便宜的一个版本,呵呵,不会接线和操作的看上期的项目即可,这里不再重复说明了,重要的事情说一遍:我有收费版的代码,服务更周到。 下面请看模块运行效果图: 下面是实物图: 模块的原理图: 电脑接上串口CH340,CH340接上ESP32-CAM之后,打开串口调试助手,调试效果如下: 服务器返回消息: 真源码截图(绝对给力): 项目总结:这次是利用ESP32-CAM模块对物联网应用的一次巨大的尝试,在电路城目前好像还没有相关的教程,在B站虽然有类似的项目,但是根本没有源码,也没有教程,而且功能没有我这个那么强大,因为我这个嵌入式服务器是有反馈的,而且支持网页手动输入指令,开灯或者关灯指令发送之后服务器会给客户端一个响应的,代码都是自己手工完成的,也借鉴过很多相关的项目。只要掌握这个嵌入式服务器远程点灯的项目,那么其他类似的设计就可以举一反三了。需要注意的是这个版本的代码是没有任何注释的,代码冗余度也很大,收费版的代码更加精简和加入详细注释(最关键)和调试代码。如下所示: 后期的的项目会涉及到图像处理(颜色识别,人脸检测,人脸识别,颜色跟踪,智能小车,手机app客户端控制,云平台语音识别,云平台图像识别等等,私有云图像处理,私有云监控搭建)全部原创开源,敬请期待。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值