- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
美好的一天!
我想制作一个客户端并将其连接到 netcat 简单服务器。
1) 使用默认设置和#define 编译的库(唯一的东西——我设置了一些调试信息)2) 将 lib 链接到项目(工作正常)3)用ubuntu设置虚拟机并使netcat与
一起工作~$ sudo netcat -l -v 7
这意味着我们正在监听端口 7(七)。
Now I use ifconfig and get
inet addr:172.17.9.71
Bcast:172.17.11.255
Mask:255.255.252.0
暂时还好。
4) ping 和 telnet 工作正常 - 我看到它们可以访问 netcat。
我的 ifconfig 统计数据是
inet addr:172.17.9.165
Bcast:172.17.11.255
Mask:255.255.252.0
5) 现在我正在尝试使用我的客户端连接到 netcat 服务器,该客户端是使用 lwip 编写的输出是:
LWIP_HAVE_LOOPIF = 0
LWIP_HAVE_LOOPIF = 0
tcp_bind: bind to port 55555
tcp_connect to port 7
netif_default = -780756800
netif_is_up(netif_default) = 0
ip_route: No route to 172.17.9.71
connect err = -4
netif_default = -780756800
netif_is_up(netif_default) = 0
ip_route: No route to 172.17.9.71
ip_output: No route to 172.17.9.71
Assertion "mem_free: mem->used" failed at line 339 in ../../../../../lwip/src/core/mem.c
完整 list :
const char *helloworld = "hello world\n";
void hello_end(struct tcp_pcb *pcb, u8_t *state)
{
tcp_err(pcb, NULL);
tcp_recv(pcb, NULL);
tcp_sent(pcb, NULL);
tcp_poll(pcb, NULL, 0);
mem_free(state);
}
err_t hello_recv(void *arg, struct tcp_pcb *pcb, struct pbuf *p, err_t err)
{
u8_t *state = (u8_t *)arg;
u16_t len;
if (p == NULL)
if (*state == 255) /* close send */
hello_end(pcb, state);
else /* close not yet send */
*state |= 2;
else
{
len = p->tot_len;
pbuf_free(p);
tcp_recved(pcb, len);
}
return ERR_OK;
}
void hello_err(void *arg, err_t err)
{
mem_free(arg);
}
err_t hello_poll_close(void *arg, struct tcp_pcb *pcb)
{
u8_t *state = (u8_t *)arg;
if (tcp_close(pcb) == ERR_OK)
{
if ((*state & 2) == 2) /* close received */
hello_end(pcb, state);
else /* close not yet received */
*state = 255;
}
return ERR_OK;
}
err_t hello_connected(void *arg, struct tcp_pcb *pcb, err_t err)
{
tcp_write(pcb, helloworld, 12, 0);
return ERR_OK;
}
err_t hello_connect() {
lwip_init();
u8_t *state;
err_t err;
struct tcp_pcb *pcb;
ip_addr_t ipaddr;
IP4_ADDR(&ipaddr, 172,17,9,71);
if ((state = mem_malloc(1)) == NULL) {
return ERR_MEM;
}
*state = 1;
if ((pcb = tcp_new()) == NULL) {
mem_free(state);
return ERR_MEM;
}
tcp_arg(pcb, state);
tcp_err(pcb, hello_err);
tcp_recv(pcb, hello_recv);
tcp_sent(pcb, NULL);
tcp_poll(pcb, hello_poll_close, 10);
tcp_bind(pcb,IPADDR_ANY, 55555); //Bind ourselvs to the port 55555 and my own adress
err = tcp_connect(pcb, &ipaddr, 7, hello_connected);
if (err != ERR_OK) {
std::cout << "connect err = " << (int)err << std::endl;
mem_free(state);
tcp_abort(pcb);
}
getchar();
return ERR_OK;
}
int main(int argc, char** argv) {
err_t err = hello_connect();
if (err != ERR_OK) {
std::cout << "2err = " << err << std::endl;
}
std::cout << "End of Main" << std::endl;
return 0;
return 0;
}
从这里我开始认为问题是我没有设置 NETIF。
但我不知道怎么做。
我想我不希望 lwip 默认创建 tap0
(这使得
tap0 Link encap:Ethernet HWaddr 86:97:2c:64:b7:78
inet addr:192.168.1.1 Bcast:192.168.1.255 Mask:255.255.255.0
inet6 addr: fe80::8497:2cff:fe64:b778/64 Scope:Link
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:0 errors:0 dropped:0 overruns:0 frame:0
TX packets:33 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:500
RX bytes:0 (0.0 B) TX bytes:6555 (6.4 KiB)
)
我想将我的应用程序绑定(bind)到 localhost 或 eth1 - 无论怎样...我该怎么做?我在申请中做错了什么?
顺便说一下,当我这样做的时候
char *eth = "eht1";
netif_set_default(netif_find(eth));
在我的初始化函数中我得到了这个输出
WIP_HAVE_LOOPIF = 0
LWIP_HAVE_LOOPIF = 0
tcpip_thread: PACKET 0x7f72acaa1988
ip_input: packet not for us.
tcp_bind: bind to port 55555
tcp_connect to port 7
netif_default = 0
它落在
err = tcp_connect(pcb, &ipaddr, 7, hello_connected);
(没有通过...)
有人能帮忙吗?
最佳答案
它是您用来与服务器通信的以太网接口(interface)吗?在代码的 hello_connect() 函数中,初始化 lwIP 后,您需要为以太网接口(interface)分配和初始化一个“struct netif”对象,并使用 netif_add() 将其注册到 lwIP。您还需要使用 netif_set_default() 将其设置为默认接口(interface)。我不确定其余代码。为什么不直接使用套接字 API?
关于tcp - lwip 初始化网络接口(interface),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24533089/
我正在尝试在我的代码库中为我正在编写的游戏服务器更多地使用接口(interface),并了解高级概念以及何时应该使用接口(interface)(我认为)。在我的例子中,我使用它们将我的包相互分离,并使
我有一个名为 Widget 的接口(interface),它在我的整个项目中都在使用。但是,它也用作名为 Widget 的组件的 Prop 。 处理此问题的最佳方法是什么?我应该更改我的 Widget
有一个接口(interface)可以是多个接口(interface)之一 interface a {x:string} interface b {y:string} interface c {z:st
我遇到了一种情况,我需要调用第三方服务来获取一些信息。这些服务对于不同的客户可能会有所不同。我的界面中有一个身份验证功能,如下所示。 interface IServiceProvider { bool
在我的例子中,“RequestHandlerProxy”是一个结构,其字段为接口(interface)“IAdapter”,接口(interface)有可能被调用的方法,该方法的输入为结构“Reque
我有一个接口(interface)Interface1,它已由类A实现,并且设置了一些私有(private)变量值,并且我将类A的对象发送到下一个接受输入作为Interface2的类。那么我怎样才能将
假设我有这样的类和接口(interface)结构: interface IService {} interface IEmailService : IService { Task SendAs
有人知道我在哪里可以找到 XML-RPC 接口(interface)的定义(在 OpenERP 7 中)?我想知道创建或获取对象需要哪些参数和对象属性。每个元素的 XML 示例也将非常有帮助。 最佳答
最近,我一直在阅读有关接口(interface)是抽象的错误概念的文章。一篇这样的帖子是http://blog.ploeh.dk/2010/12/02/InterfacesAreNotAbstract
如果我有一个由第三方实现的现有 IInterface 后代,并且我想添加辅助例程,Delphi 是否提供了任何简单的方法来实现此目的,而无需手动重定向每个接口(interface)方法?也就是说,给定
我正在尝试将 Article 数组分配给我的 Mongoose 文档,但 Typescript 似乎不喜欢这样,我不知道为什么它显示此警告/错误,表明它不可分配. 我的 Mongoose 模式和接口(
我有两个接口(interface): public interface IController { void doSomething(IEntity thing); } public inte
是否可以创建一个扩展 Serializable 接口(interface)的接口(interface)? 如果是,那么扩展接口(interface)的行为是否会像 Serilizable 接口(int
我试图在两个存储之间创建一个中间层,它从存储 A 中获取数据,将其转换为相应类型的存储 B,然后存储它。由于我需要转换大约 50-100 种类型,我希望使用 map[string]func 并根据 s
我正在处理一个要求,其中我收到一个 JSON 对象,其中包含一个日期值作为字符串。我的任务是将 Date 对象存储在数据库中。 这种东西: {"start_date": "2019-05-29", "
我们的方法的目标是为我们现有的 DAO 和模型类引入接口(interface)。模型类由各种类型的资源 ID 标识,资源 ID 不仅仅是随机数,还带有语义和行为。因此,我们必须用对象而不是原始类型来表
Collection 接口(interface)有多个方法。 List 接口(interface)扩展了 Collection 接口(interface)。它声明与 Collection 接口(int
我有一个 Java 服务器应用程序,它使用 Jackson 使用反射 API 对 DTO 进行一般序列化。例如对于这个 DTO 接口(interface): package com.acme.libr
如果我在 Kotlin 中有一个接口(interface): interface KotlinInterface { val id: String } 我可以这样实现: class MyCla
我知道Java中所有访问修饰符之间的区别。然而,有人问了我一个非常有趣的问题,我很难找到答案:Java 中的 private 接口(interface)和 public 接口(interface)有什
我是一名优秀的程序员,十分优秀!