wireshark lua string:byte()错误
2016-2-6 3:22:48
收藏:0
阅读:68
评论:2
我在编写Lua解析器时遇到了一个字符串问题。我的数据包内容如下:
0000 00 00 00 69 00 10 00 01 00 00 00 ed 00 00 00 0c
0010 bf a6 5f ...
调试时,TVB的内容相同
偏移量为0x10的字节为0xbf,但是在我的解析器函数中,我得到了不同的结果。代码如下:
local str = buf(0x10):string()
local x = string.byte(str, 1)
变量x应该是0xbf,但它是0xef,而其他偏移量也是0xef:
local str = buf(0x11):string()
local x = string.byte(str, 1) -- 也得到0xef,应该是0xa6
local str = buf(11):string()
local x = string.byte(str, 1) -- 也得到0xef,应该是0xed
似乎大的值总是得到0xef作为结果,如0xa6 / 0xbf / 0xed …
而小的值将是正确的,如0x69 / 0x5f / 0x0c …
我正在使用最新的Wireshark 2.0,这是一个bug吗?
点赞
用户427545
假设 buf 是传递给你分析程序的参数,并且它是类型为 Tvb 的。当你调用它(比如,buf(0x10)),你就创建了一个 TvbRange 实例。它们都在这里有文档:
https://www.wireshark.org/docs/wsdg_html_chunked/lua_module_Tvb.html
tehtmi 正是关于你为什么得到了错误结果的原因,tvbrange:string() 返回使用 ASCII 编码的字符串(因为省略了编码参数)。
获得原始字节缓冲区(而不是将其转换为 ASCII 或 UTF-8 字符串)的方法是:
local x = buf:raw(0x10, 1)
(使用偏移量 16 和长度 1。)
如果你想直接使用 buf(0x10):raw(),请注意,由于某种原因,这将返回支持这个 Tvb 的完整数据源。也许是一个 bug 或特性... 解决方法:
local bytes = buf(0x10)
local x = bytes:raw(bytes:offset(), bytes:len())
2017-07-04 12:44:49
评论区的留言会收到邮件通知哦~
推荐文章
- 如何将两个不同的lua文件合成一个 东西有点长 大佬请耐心看完 我是小白研究几天了都没搞定
- 如何在roblox studio中1:1导入真实世界的地形?
- 求解,lua_resume的第二次调用继续执行协程问题。
- 【上海普陀区】内向猫网络招募【Skynet游戏框架Lua后端程序员】
- SF爱好求教:如何用lua实现游戏内调用数据库函数实现账号密码注册?
- Lua实现网站后台开发
- LUA错误显式返回,社区常见的规约是怎么样的
- lua5.3下载库失败
- 请问如何实现文本框内容和某个网页搜索框内容连接,并把网页输出来的结果反馈到另外一个文本框上
- lua lanes多线程使用
- 一个kv数据库
- openresty 有没有比较轻量的 docker 镜像
- 想问一下,有大佬用过luacurl吗
- 在Lua执行过程中使用Load函数出现问题
- 为什么 neovim 里没有显示一些特殊字符?
- Lua比较两个表的值(不考虑键的顺序)
- 有个lua简单的项目,外包,有意者加微信 liuheng600456详谈,最好在成都
- 如何在 Visual Studio 2022 中运行 Lua 代码?
- addEventListener 返回 nil Lua
- Lua中获取用户配置主目录的跨平台方法

我对 Wireshark 并不是很了解,但我对接下来的问题有一些了解。
您正在使用 Wireshark 的
tvbrange:string([encoding])函数。我在 Wireshark 网站上找到的文档说,默认编码是ENC_ASCII。0x80-0xFF 范围内的字节(您报告的问题所在)不是有效的 ASCII 码。Wireshark 可能所做的是将这些转换为 U+FFFD,Unicode 的“替换字符”。这是表示 Unicode 字符串中未知字符的标准做法。
然后,Wireshark 可能会在返回给 Lua 时将此字符串编码为 UTF-8。U+FFFD 的 UTF-8 编码的第一个字节是 0xEF,因此您看到的就是这个。
如果您想从 TVB 中获取原始字节值,可以尝试使用
tvbrange:bytes([encoding])函数来获取值,例如:local bytes = buf(0x10):bytes() local x = bytes:get_index(0) -- 或许是 1,我不能确定是从 0 还是 1 开始索引也许还有一些您可以传递给
tvbrange:string的编码可以达到您想要的效果,但我找不到任何好的参考文献。