- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我目前正在研究 python 中的套接字编程,我在使用 socket.htons() 时遇到了一些奇怪的行为......它似乎在每次调用时都会翻转字节。
我正在实现一个简单的 ping 脚本,据我所知,网络字节顺序是大端,而我的系统字节顺序是小端。
如果我在我的 16 位校验和上使用 htons,wireshark 会报告它不正确,但是如果我只是将校验和打包到一个结构中而不使用 htons,wireshark 会确认它是正确的。
这是 wireshark 在使用 htons 时捕获的内容
Checksum: 0xece4 [incorrect, should be 0xe4ec]
这是一个简单的例子......
>>> z = 0xFF00
>>> print z
65280
>>> z = socket.htons(z)
>>> print z
255
>>> z = socket.htons(z)
>>> print z
65280
如有任何想法,我们将不胜感激,希望只是我做错了什么。
编辑:
>>> print sys.byteorder
little
最佳答案
一切看起来都像它应该的那样工作。即使在您的示例中,也会交换 2 个字节,然后再交换回来。如果系统字节顺序与网络相同,那么它是空操作,但您的问题表明网络字节顺序是大,而主机是小 ,所以交换是它应该做的。
In [1]: a = 0xECE4
In [2]: b = 0xE4EC
In [3]: a
Out[3]: 60644
In [4]: b
Out[4]: 58604
In [5]: socket.htons(a)
Out[5]: 58604
In [6]: socket.htons(b)
Out[6]: 60644
In [7]: socket.htons(a) == b
Out[7]: True
In [8]: socket.htons(b) == a
Out[8]: True
In [9]: hex(socket.htons(a))
Out[9]: '0xe4ec'
In [10]: hex(socket.htons(b))
Out[10]: '0xece4'
In [11]: bin(socket.htons(a))
Out[11]: '0b1110010011101100'
In [12]: bin(socket.htons(b))
Out[12]: '0b1110110011100100'
来自 python socket reference :
socket.htons(x)
Convert 16-bit positive integers from host to network byte order. On machines where the host byte order is the same as network byte order, this is a no-op; otherwise, it performs a 2-byte swap operation.
关于Python 2.7 套接字 htons,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8088278/
我一直在想,为什么我在使用write/read的时候不用htons/ntohl呢? (至少到目前为止我看到的所有例子都没有。) 我怎么知道接收到的字节具有正确的字节顺序? 最佳答案 好吧,如果您打算在
我有一段代码使用了 htons,但在编译过程中遇到了这个错误。 error: use of old-style cast [-Werror=old-style-cast] 行是: mFarEnd.si
我有一个程序一直依赖于 native::io::net::{htons, ntohs} 但现在在 Could not find 'io' in 'packet: :native'。变化似乎发生在上周的
我正在尝试新的 C++ 套接字编程。我在理解 htons、htonl 和相关函数的功能时遇到了一些困难。我阅读了一些文档,但我的问题如下, 对于单个服务器和单个客户端,我在两端都使用 htons 作为
我在下面粘贴我的客户端和服务器代码。我的程序运行良好,除了我试图在我的 src 和 dest 字段中发送一个 ipaddress,并且出于某种原因,即使我将它作为 131.199.166.232 发送
我是套接字编程的新手,我想了解 htons() 的操作.我在 Internet 上阅读了一些教程,例如 this和 this例如一个。但我不明白什么是htons()确实如此。我尝试了以下代码: #in
考虑以下代码: #include #include int main(int argc, char *argv[]) { uint16_t num = 123; if (htons
我正在学习简单的套接字程序并遇到了这些,我想知道 htons 和 htonl 之间有什么区别,甚至 ntohs 和恩托尔。 最佳答案 htons 主机到网络短 ntohs 网络托管短片 htonl主机
要从另一台大端机器转换字节数组,我们可以使用: long long convert(unsigned char data[]) { long long res; res = 0; for(
我目前正在研究 python 中的套接字编程,我在使用 socket.htons() 时遇到了一些奇怪的行为......它似乎在每次调用时都会翻转字节。 我正在实现一个简单的 ping 脚本,据我所知
我正在编写一个客户端-服务器应用程序,它使用 UDP 在两台 Intel x64 计算机之间发送数据报。我控制双方的硬件,并已验证它们使用相同的小端架构。 我可以确认两台机器都是小尾数法,在发送数据之
我定义了 uint16 变量。我想在编译中进行验证,无论何时使用此变量,都必须首先使用 hton() 对其进行转换。有没有办法在 gcc 编译期间验证它? 谢谢。 最佳答案 我认为在 C 中没有合适的
为什么Coverity会产生警告 > "cc" clobber ignored 对于下面提到的代码中的函数调用 htons() 和 ntohs()? lSocketAddr.sin_port = ht
我已阅读 this explanation和 this manual page关于htons、htonl、ntohl和ntohs的用法,但是我还是不太明白它们的用法(一般来说,我对套接字 API 和网
我需要在可能位于不同平台的服务器和客户端之间发送一个枚举缓冲区。 但是枚举的大小取决于平台,我应该调用哪个函数? (htons() 或 htonl()),例如以下枚举: typedef enum f_
当我通过套接字将一个整数变量从一个进程发送到另一个进程,然后在接收端打印值时,不使用 ntohl/htonl,该值仍然相同,那么除了初始化之外,我还需要在哪里使用这些函数套接字结构。我了解小/大端。但
我最近喜欢阅读 Beej's Guide to Network Programming .在 section 7.4他谈到了与发送花车有关的问题。他提供了一个简单(天真的)解决方案,他通过将 floa
我不确定为什么 htons 和 ntohs 都存在于标准库中。他们做的事情完全一样——除非我有点困惑! htonl 和 ntohl 也是如此。 最佳答案 它们提供自文档化代码,告诉读者数据是按主机顺序
htons() 将主机字节顺序转换为网络字节顺序。 网络字节顺序是 Big-Endian,主机字节顺序可以是 Little-Endian 或 Big-Endian。 在 Little Endian 系
我正在使用现有代码,它通过 TCP 连接传递数据 - union ibv_gid 而不转换字节顺序。里面有注释:“gid会逐字节传输,所以不需要做”hton“。代码是正确的,可以工作,但我不明白为什么
我是一名优秀的程序员,十分优秀!