- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在一个小型 Tesseract 项目上工作和测试,并完全归功于 http://aalvarez.me/blog/posts/building-an-ocr-service-with-tesseractjs-in-aws-lambda.html我有一个在 Lambda 中运行的 Tesseract 项目,它接受 s3 事件并处理上传到 s3 的图像。
下一个目标是处理来自 AWS IoT 的图像。主要障碍是您无法通过 MQTT 发送图像。
我的方法是在 MQTT 主题上发送图像的缓冲区/二进制流,然后 IoT 规则触发相同的 lambda 进行处理。
但是首先,我需要有一个有效的二进制流(还没有真正的硬件和摄像头,仅供引用,我是后端人员)通过 IoT 发送,所以我修改了我的项目,不仅存储在图像以及图像的二进制流/缓冲区。
我需要这样做,因为 AWS Cloudwatch 会 chop 日志记录,因此当我注销 Lambda 函数加载的 s3 对象的数据负载时,您得到的只是一个严重 chop 的缓冲区对象。
dataBody: <Buffer 89 50 4e 47 0d 0a 1a 0a 00 00 00 0d 49 48 44 52 00 00 01 90 00 00 01 90 08 06 00 00 00 80 bf 36 cc 00 00 20 00 49 44 41 54 78 5e ed 9d 09 f8 76 df 58 ... >
因此,我添加了一些代码,按照下面的方式使用 DynamoDB updateItem 和 SET 来设置数据库项上的属性,并使用用于执行 OCR 的原始缓冲区,如下所示
"UpdateExpression": "SET img = :attrValue",
"ExpressionAttributeValues": {
":attrValue": { "B": dataBody }
这有效,并且在带有一大串字符的项目中创建了属性,我认为这些字符是原始的,但可能采用了某种不同的格式
现在,如果我将这个大字符串作为 MQTT 有效负载发送并触发规则,那么 Lambda 就会触发,但是当我转换有效负载并尝试处理它时,Tesseract 会提示
类型错误:无法读取 null 的属性“mime”
该错误可能是将 IoT 有效负载转换为缓冲区进行处理的结果,因为在读取原始 s3 对象时,它现在与原始缓冲区完全不同,因此不存在 mime 属性。我正在选择的数据现在已被处理
let ocrBuffer = Buffer.from(iotEvent)
ocrBuffer: <Buffer 69 56 42 4f 52 77 30 4b 47 67 6f 41 41 41 41 4e 53 55 68 45 55 67 41 41 41 5a 41 41 41 41 47 51 43 41 59 41 41 41 43 41 76 7a 62 4d 41 41 41 67 41 45 ... >
对缓冲区和处理图像等有点新手,但我怀疑将其存储到 DynamoDB 的过程以某种方式改变了原始缓冲区或将其包装在某些东西中,因此我需要正确地取消更改/解开它,这样它就变成了与原始 Buffer 相同,以 89 而不是 69 开头。
有谁知道哪里出了问题以及应该从哪里开始寻找。
现在我可以将图像上传到 s3,并且我想以某种方式保存有效负载,以便我可以将其用作通过 IoT 服务使用的测试有效负载
谢谢标记
最佳答案
问题的症结似乎是来自 Tesseract 的这条消息:
类型错误:无法读取 null 的属性“mime”
这至少有一个明确的原因。当您将数据发送到 Tesseract 时,听起来您没有设置 Content-type http header 。
在 examples from Tesseract 看起来需要 Content-type header ,这很有意义,因为它需要知道您要发布到它的文件类型。
所以我认为这里的问题是您的 Lambda 函数如何将数据发布到 Tesseract,特别是它如何设置 Content-type 和 Content-Disposition header ?
尽管您的二进制数据可能存在问题,但我现在可能不会关注这一点,因为它似乎不是 Tesseract 提示的问题。
您可以尝试的一件事是使用curl将(本地)文件发布到Tesseract,非常简单。假设此方法可行,请将 HTTP 请求与您的 Lambda 函数生成的请求进行比较,然后从那里反向工作。我怀疑您没有内容问题,或者至少这可能不是当前的问题。
关于Javascript、Tesseract、AWS IoT、Dynamodb 和缓冲区,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48272990/
这个问题在这里已经有了答案: Possible to make an event handler wait until async / Promise-based code is done? (2
我经常有多个运行的进程(R,Python,eshell/shell),对于每个进程,我经常都有一个相关的脚本,可以从中发送摘要。为此,我通常将每个框架垂直地分成两个窗口,以便脚本文件(例如.py)位于
如何修改 emacs 在关闭缓冲区后选择要显示的缓冲区的方式? 当我有多个列显示相同的缓冲区,然后在其中一个缓冲区中打开另一个文件,然后关闭新打开的缓冲区时,它不会切换回前一个缓冲区,而是切换到另一个
如何将 ex 命令复制到剪贴板或粘贴到缓冲区? 在 Windows 上使用 gvim。 最佳答案 windows剪贴板可以通过the buffer + 访问.因此,可以使用 + 将剪贴板粘贴为前命令。
在 javascript 中如何以比以下更简单的方式获取 b 缓冲区? var num=6553599 var a = new Buffer(4); a.writeInt32LE(num)
每次我在 Google 上搜索有关 OpenGL 编程的文章时,我都会找到一些文章,但似乎所有文章都提到了着色器和缓冲区。那些是什么?你能解释其中的一些吗: 深度缓冲区 模板缓冲区 像素着色器 帧缓冲
我有java考试,当我学习时,我看到了这个练习,我尝试解决它,但我发现一些困难,所以请帮助我考虑实用程序中方法的以下注释、 header 和部分代码名为 Atbash 的加密类。 /**
每次我在 Google 上搜索有关 OpenGL 编程的文章时,我都会找到一些文章,但似乎所有文章都提到了着色器和缓冲区。那些是什么?你能解释其中的一些吗: 深度缓冲区 模板缓冲区 像素着色器 帧缓冲
对于每个属性使用跨步顶点缓冲区与紧密打包缓冲区有何优缺点?我的意思是例如: 步幅:xyzrgb xyzrgb xyzrgb 紧:xyzxyzxyz rgbrgbrgb 乍一看,使用步幅时您似乎可以轻松
我正在尝试将文本文件中每行的数字读取到 ArrayList 中。当我执行以下函数时,它总是跳过最后一个元素。有人可以帮我吗?因为我在这里没有遇到问题,因为它读取直到缓冲区为空,所以他应该在到达 Fil
#include #include int main () { time_t time_raw_format; struct tm * ptr_time; char *buff
基本上我有一个包含不同类型数据的自定义结构。例如: typedef struct example_structure{ uint8_t* example_1[4]; int example_2[4];
我之前的列表实现是一个简单的 LinearLayout,位于一个装满我的项目的 ScrollView 中。 我切换到 ListView 的 Android 实现以简单地使用 CursorAdapter
我想创建一个可变长度的输入事件窗口/缓冲区,当它接收到额外的事件时会变长。 这是为了实现“键入时搜索”功能。我想捕获点击,但为了不给服务器造成压力,我想明智地进行服务调用。 我想到的逻辑是缓冲击键,从
我想将 yuv420P 像素写入缓冲区而不是二进制文件。假设我在指针中存储了 luma 、 Cb 和 Cr。 luma = output_pixel.luma; cb = output_pixel.c
我想在 Go 中构建一个支持多个并发读取器和一个写入器的缓冲区。所有写入缓冲区的内容都应由所有读者读取。允许新读者随时加入,这意味着已经写入的数据必须能够为迟到的读者回放。 缓冲区应满足以下接口(in
本文转载自微信公众号「小明菜市场」,作者小明菜市场。转载本文请联系小明菜市场公众号。 前言 Java NIO 需要理解的主要有缓冲区,通道,选择器,这三个主要的部分。 基础
一 点睛 NIO,可以称为 New IO 或 Non Blocking IO,是在 JDK 1.4 后提供的新 API。传统的I/O 是阻塞式的 I/O、面向流的操作;而 NIO 是非阻塞 I/O 、
我正在寻找一种切换到包含搜索文本的缓冲区的方法。 例如。如果我打开了 100 个缓冲区,我想切换到一个包含 'fooBar = 1' 的缓冲区 最佳答案 我写了一个 Vim 插件来做到这一点:buff
我正在尝试将提取的视频帧(我使用 ffmpeg)推送到 FFMPEG 缓冲区中。我已经查看了 ffmpeg 的缓冲区源文件,例如 buffersrc.c 和 fifo.c,以确定我是否可以这样做,但我
我是一名优秀的程序员,十分优秀!