实现起来非常简单,只是忘了更新这个问题。
我基本上按照此网站上给出的说明,也就是Raw/TCP“文档”。
基本上,HTTP请求被编码在TCP数据包中,所以为了向我的PHP服务器发送数据,我使用TCP数据包发送了一个HTTP请求(lwIP完成所有工作)。
我想要发送的HTTP数据包如下:
HEAD /process.php?data1=12& data2 = 5 HTTP/1.0
主机:mywebsite.com
要将此“翻译”为HTTP服务器能够理解的文本,您必须在代码中添加“\r\n”回车符/换行符。因此它看起来像这样:
char *string = "HEAD /process.php?data1=12&data2=5 HTTP/1.0\r\nHost: mywebsite.com\r\n\r\n "
请注意,结尾有两个“\r\n”。
你可以使用GET或HEAD,但由于我不关心PHP服务器返回的HTML网站,所以我使用了HEAD(它在成功时返回200 OK,或在失败时返回不同的代码)。
lwIP原始/ TCP基于回调函数。您基本上设置所有回调函数,然后将要发送的数据推送到TCP缓冲区(在本例中为上面指定的TCP字符串),然后告诉lwIP发送数据包。
用于建立TCP连接的函数(每次我想发送TCP数据包时,我的应用程序都会直接调用此函数):
void tcp_setup(void)
{
uint32_t data = 0xdeadbeef;
struct ip_addr ip;
IP4_ADDR(&ip, 110,777,888,999);
testpcb = tcp_new();
tcp_arg(testpcb, &data);
tcp_err(testpcb, tcpErrorHandler);
tcp_recv(testpcb, tcpRecvCallback);
tcp_sent(testpcb, tcpSendCallback);
tcp_connect(testpcb, &ip, 80, connectCallback);
}
一旦与我的PHP服务器建立连接,lwIP将调用“connectCallback”函数:
err_t connectCallback(void *arg, struct tcp_pcb *tpcb, err_t err)
{
UARTprintf("Connection Established.\n");
UARTprintf("Now sending a packet\n");
tcp_send_packet();
return 0;
}
该函数调用实际函数tcp_send_packet(),发送HTTP请求,如下:
uint32_t tcp_send_packet(void)
{
char *string = "HEAD /process.php?data1=12&data2=5 HTTP/1.0\r\nHost: mywebsite.com\r\n\r\n ";
uint32_t len = strlen(string);
error = tcp_write(testpcb, string, strlen(string), TCP_WRITE_FLAG_COPY);
if (error) {
UARTprintf("ERROR: Code: %d (tcp_send_packet :: tcp_write)\n", error);
return 1;
}
error = tcp_output(testpcb);
if (error) {
UARTprintf("ERROR: Code: %d (tcp_send_packet :: tcp_output)\n", error);
return 1;
}
return 0;
}
一旦TCP包已发送(如果您只想“碰运气”并且不在乎数据是否实际发送,则这就足够了),PHP服务器将返回一个TCP包(带有200 OK等以及HTML代码,如果使用GET而不是HEAD)。此代码可以在以下代码中读取和验证:
err_t tcpRecvCallback(void *arg, struct tcp_pcb *tpcb, struct pbuf *p, err_t err)
{
UARTprintf("Data recieved.\n");
if (p == NULL) {
UARTprintf("The remote host closed the connection.\n");
UARTprintf("Now I'm closing the connection.\n");
tcp_close_con();
return ERR_ABRT;
} else {
UARTprintf("Number of pbufs %d\n", pbuf_clen(p));
UARTprintf("Contents of pbuf %s\n", (char *)p->payload);
}
return 0;
}
p->payload包含实际的“200 OK”等信息。希望这可以帮助某些人。
我在上面的代码中省略了一些错误检查,以简化答案。