如果问题不相关,请移动/关闭此问题。
核心: Cortex-M4
微处理器: TI TM4C1294NCPDT。
IP堆栈: lwIP 1.4.1
我正在使用这个微处理器进行一些数据记录,并且我想通过HTTP请求将一些信息发送到一个单独的web服务器,请求的形式为:
http://123.456.789.012:8800/process.php?data1=foo&data2=bar&time=1234568789
我希望处理器能够看到响应头(即,如果它是200OK或出了什么问题)-它不必显示/接收实际内容。
lwIP为微处理器提供了一个http服务器,但我想要的正好相反(微处理器就是客户端)。
我不确定数据包如何与请求/响应头相关,因此我不确定如何实际发送/接收信息。
发布于 2015-01-23 16:35:54
这最终相当容易实现,忘记了更新这个问题。
我基本上遵循了this站点上的说明,也就是原始/TCP“文档”。
基本上,超文本传输协议请求被编码在TCP包中,所以为了将数据发送到我的PHP服务器,我使用TCP包发送超文本传输协议请求(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 (如果成功,它将返回200OK,如果失败,它将返回一个不同的代码)。
lwIP raw/tcp在回调上工作。您基本上设置了所有回调函数,然后将需要的数据推送到TCP buffer (在本例中,是上面指定的TCP字符串),然后告诉lwIP发送数据包。
用于建立TCP连接的函数(每当我想发送TCP数据包时,该函数都会被我的应用程序直接调用):
void tcp_setup(void)
{
uint32_t data = 0xdeadbeef;
/* create an ip */
struct ip_addr ip;
IP4_ADDR(&ip, 110,777,888,999); //IP of my PHP server
/* create the control block */
testpcb = tcp_new(); //testpcb is a global struct tcp_pcb
// as defined by lwIP
/* dummy data to pass to callbacks*/
tcp_arg(testpcb, &data);
/* register callbacks with the pcb */
tcp_err(testpcb, tcpErrorHandler);
tcp_recv(testpcb, tcpRecvCallback);
tcp_sent(testpcb, tcpSendCallback);
/* now connect */
tcp_connect(testpcb, &ip, 80, connectCallback);
}一旦与我的服务器建立了连接,lwIP就会调用'connectCallback‘函数:
/* connection established callback, err is unused and only return 0 */
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;
}此函数调用发送HTTP请求的实际函数tcp_send_packet(),如下所示:
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);
/* push to buffer */
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;
}
/* now send */
error = tcp_output(testpcb);
if (error) {
UARTprintf("ERROR: Code: %d (tcp_send_packet :: tcp_output)\n", error);
return 1;
}
return 0;
}一旦发送了TCP数据包(如果您想“抱最好的希望”,而不关心数据是否实际发送,则需要这样做),PHP服务器将返回一个TCP数据包(带有200OK等,如果您使用GET而不是HEAD,则返回HTML代码)。可以在以下代码中读取和验证此代码:
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->有效载荷包含实际的“200OK”等信息。希望这能帮助到一些人。
为了简化答案,我在上面的代码中省略了一些错误检查。
发布于 2014-10-07 02:46:15
看看维基百科上的HTTP example吧。客户端将发送GET和HOST行。服务器将使用多行响应来响应。第一行将包含响应代码。
https://stackoverflow.com/questions/26192758
复制相似问题