OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 6664|回复: 13

LWIP cgi更改成post, 造成死机。(web)

[复制链接]

2

主题

12

帖子

0

精华

新手上路

积分
36
金钱
36
注册时间
2017-11-15
在线时间
4 小时
发表于 2017-11-15 16:47:05 | 显示全部楼层 |阅读模式
2金钱
我买的是F429的板子, 然后通过光盘附送的代码, 然后进行通过LWIP搭建web_server, 原始的demo能够通, 但是只能支持cgi的get, 我想用post。web的html没有使用原始的。
我看里面有一个
#define LWIP_HTTPD_SUPPORT_POST   0   
然后我将值更改成1,
然后进行编译,发现httpd_post_begin(), httpd_post_receive_data(), httpd_post_finished()只有声明, 没有实现代码,然后我在网上找了下,
将代码抄了下。
链接地址为:
http://bbs.csdn.net/topics/390967955
http://blog.csdn.net/lijing198997/article/details/25987193
但是web可能有问题, 连接上网页后会发送两次cgi请求(主要是cgi响应函数里面的打印出现了两次,认为PC上的浏览器打开网页后,发送了两次,本来应该连接一次,后面再查找原因),
web_server在第二次cgi请求后,会出现死机的现象。 不知道什么原因造成,我进行跟踪,在http_recv() 函数里面最后一个return返回的时候加的打印信息,可以看见这个打印信息,
因此可以判断是http_recv()执行完了后面的代码造成的,具体是那个地方还没找到,因为http_recv是一个注册的回调函数。
不知道哪里出了问题。

httpd_post的begin, recvieve_data, finished三个函数代码如下:
代码如下:
err_t httpd_post_begin(void *connection, const char *uri, const char *http_request,
                       u16_t http_request_len, int content_len, char *response_uri,
                       u16_t response_uri_len, u8_t *post_auto_wnd)
{
#if LWIP_HTTPD_CGI
    int i = 0;
#endif
    struct http_state *hs = (struct http_state *)connection;

    if(!uri || (uri[0] == '\0'))

    {
        return ERR_ARG;
     }

     hs->cgi_handler_index = -1;   // 此变量为本人自己在struct http_state 添加 用于保存CGI handler 索引 为-1表示无CGI handler索引
    hs->response_file = NULL; // 此变量为本人自己在struct http_state 添加 用于保存 CGI handler 处理完后返回的响应uri.

#if LWIP_HTTPD_CGI
  if (g_iNumCGIs && g_pCGIs) {
    for (i = 0; i < g_iNumCGIs; i++) {
      if (strcmp(uri, g_pCGIs.pcCGIName) == 0) {

         hs->cgi_handler_index = i; // 找到响应的 CGI handler 将其保存在cgi_handler_index 以便在httpd_post_receive_data中使用
         break;
       }
    }
  }


  if(i == g_iNumCGIs) {
    return ERR_ARG; // 未找到CGI handler
  }
#endif

  return ERR_OK;
}

#define LWIP_HTTPD_POST_MAX_PAYLOAD_LEN     512
static char http_post_payload[LWIP_HTTPD_POST_MAX_PAYLOAD_LEN];
static u16_t http_post_payload_len = 0;

err_t httpd_post_receive_data(void *connection, struct pbuf *p)
{
    struct http_state *hs = (struct http_state *)connection;
    struct pbuf *q = p;
    int count;
    u32_t http_post_payload_full_flag = 0;

    while(q != NULL)  // 缓存接收的数据至http_post_payload
    {

      if(http_post_payload_len + q->len <= LWIP_HTTPD_POST_MAX_PAYLOAD_LEN) {
          MEMCPY(http_post_payload+http_post_payload_len, q->payload, q->len);
          http_post_payload_len += q->len;
      }
      else {  // 缓存溢出 置溢出标志位
        http_post_payload_full_flag = 1;
        break;
      }
      q = q->next;
    }

    pbuf_free(p); // 释放pbuf

    if(http_post_payload_full_flag) // 缓存溢出 则丢弃数据
    {
        http_post_payload_full_flag = 0;
        http_post_payload_len = 0;
        hs->cgi_handler_index = -1;
        hs->response_file = NULL;
    }
    else if(hs->post_content_len_left == 0) {  // POST数据已经接收完毕 则处理

        if(hs->cgi_handler_index != -1) {
            count = extract_uri_parameters(hs, http_post_payload);  // 解析
            hs->response_file = g_pCGIs[hs->cgi_handler_index].pfnCGIHandler(hs->cgi_handler_index, count, hs->params,
                                             hs->param_vals); // 调用解析函数
            http_post_payload_len = 0;
        }

        else {
            hs->response_file = NULL;
            http_post_payload_len = 0;
        }
    }

    return ERR_OK;
}

void httpd_post_finished(void *connection, char *response_uri, u16_t response_uri_len)
{
    struct http_state *hs = (struct http_state *)connection;
    if(hs->response_file != NULL) {
        strncpy(response_uri, hs->response_file,response_uri_len); // 拷贝uri 用于给浏览器响应相应的请求
    }
}

最佳答案

查看完整内容[请看2#楼]

早已经解决,因为没有启用外部sdram。
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

2

主题

12

帖子

0

精华

新手上路

积分
36
金钱
36
注册时间
2017-11-15
在线时间
4 小时
 楼主| 发表于 2017-11-15 16:47:06 来自手机 | 显示全部楼层
早已经解决,因为没有启用外部sdram。
回复

使用道具 举报

2

主题

12

帖子

0

精华

新手上路

积分
36
金钱
36
注册时间
2017-11-15
在线时间
4 小时
 楼主| 发表于 2017-11-15 17:23:56 来自手机 | 显示全部楼层
经过测试,发现是web端连续两次cgi请求造成的,改成一次就好了。问下,怎么返回cgi给pc端,用的post
回复

使用道具 举报

2

主题

12

帖子

0

精华

新手上路

积分
36
金钱
36
注册时间
2017-11-15
在线时间
4 小时
 楼主| 发表于 2017-11-15 17:46:39 来自手机 | 显示全部楼层
改动了,#define LWIP_HTTPD_SUPPORT_POST   0  
回复

使用道具 举报

2

主题

12

帖子

0

精华

新手上路

积分
36
金钱
36
注册时间
2017-11-15
在线时间
4 小时
 楼主| 发表于 2017-11-15 17:47:03 来自手机 | 显示全部楼层
忘记把 LWIP_HTTPD_SUPPORT_POST   改成1了。
回复

使用道具 举报

2

主题

12

帖子

0

精华

新手上路

积分
36
金钱
36
注册时间
2017-11-15
在线时间
4 小时
 楼主| 发表于 2017-11-15 18:02:02 来自手机 | 显示全部楼层
问题依旧。主要是不知道cgi函数(就是pfnCGIHandler指针的返回数据)
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165352
金钱
165352
注册时间
2010-12-1
在线时间
2108 小时
发表于 2017-11-16 01:09:39 | 显示全部楼层
帮顶
回复

使用道具 举报

2

主题

12

帖子

0

精华

新手上路

积分
36
金钱
36
注册时间
2017-11-15
在线时间
4 小时
 楼主| 发表于 2017-11-16 11:56:06 来自手机 | 显示全部楼层
正点原子 发表于 2017-11-16 01:09
帮顶

谢谢。
回复

使用道具 举报

2

主题

12

帖子

0

精华

新手上路

积分
36
金钱
36
注册时间
2017-11-15
在线时间
4 小时
 楼主| 发表于 2017-11-16 12:00:30 来自手机 | 显示全部楼层
现将问题描述如下:将LWIP_HTTPD_SUPPORT_POST 定义更改成1,然后在cgi响应函数中返回内容,执行后,会死机。哪位兄弟有没有demo让我参考参考,
回复

使用道具 举报

5

主题

37

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
209
金钱
209
注册时间
2016-11-24
在线时间
68 小时
发表于 2017-11-16 15:42:48 | 显示全部楼层
不知道什么原因,连接不上WEB服务器
捕获.PNG
回复

使用道具 举报

2

主题

12

帖子

0

精华

新手上路

积分
36
金钱
36
注册时间
2017-11-15
在线时间
4 小时
 楼主| 发表于 2017-11-18 14:30:13 来自手机 | 显示全部楼层
我弄了下,在CGI响应函数句柄中cgi_hander定义了 char tmp_buf[200],只要memset就会造成某个地方死机(里面有一个线程或者任务,会隔一段时间打印),没有打印,认为死机了,不知道原因。
回复

使用道具 举报

2

主题

12

帖子

0

精华

新手上路

积分
36
金钱
36
注册时间
2017-11-15
在线时间
4 小时
 楼主| 发表于 2017-11-18 14:31:21 来自手机 | 显示全部楼层
fengfeng865 发表于 2017-11-16 15:42
不知道什么原因,连接不上WEB服务器

我用的demo里面的web_server。第一次弄,不知道原因
回复

使用道具 举报

2

主题

12

帖子

0

精华

新手上路

积分
36
金钱
36
注册时间
2017-11-15
在线时间
4 小时
 楼主| 发表于 2017-11-19 14:23:02 来自手机 | 显示全部楼层
估计原因找到,是因为外部SDRAM没有启用,不知道怎么启用,
回复

使用道具 举报

42

主题

297

帖子

0

精华

高级会员

Rank: 4

积分
994
金钱
994
注册时间
2016-7-22
在线时间
318 小时
发表于 2017-12-5 14:31:20 | 显示全部楼层
楼主 给个Q呗 求交流
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2024-11-24 22:08

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表