1. 程式人生 > >lwip1.4.0 http server實現及POST 實現

lwip1.4.0 http server實現及POST 實現

lwip1.4.0http server實現及POST 實現

一、HTTP SERVER的實現

 lwip預設的http server 在 apps/httpserver_raw 主要核心檔案為 fs.c fs.h(讀取相關html相關資源), httpd.c httpd.h httpd_structs.h http協議核心檔案

首先在LWIP協議棧正常執行後 需要在main函式中呼叫httpd_init() 初始化Http 正常情況下般還需要實現SSICGI回撥函式的初始工作 本人寫在一個函式中 如下:

void http_start(void)

{

   http_set_ssi_handler(SSIHandler, g_pcConfigSSITags, sizeof(g_pcConfigSSITags)/sizeof (char *));

   http_set_cgi_handlers(g_psConfigCGIURIs, sizeof(g_psConfigCGIURIs)/sizeof(tCGI));

}

然在httpd_init()下呼叫http_start() 完成初始化SSICGI的工作。

其次 要使用makefsfile.exe 對網頁進行編譯 這個小工具可以從網上下載一個本人將編譯命令寫在一個makefsfile.bat批處理檔案中 每次編譯只要執行一下makefsfile.bat 具體命令如下:

echo off

makefsfile -i web_pages -o ../lwip-1.4.0/src/apps/httpserver_raw/fsdata.h -r -h

echo on

其中 web_pages為所包含的網頁資料夾 產生的網頁資料放在fsdata.h中 用於跟工程檔案一起編譯, -r 表示每次編譯網頁時重寫fsdata.h  -h 表示產生的網頁資料中不包含http協議頭部 因為本人在HTTP中使用的是動態產生HTTP協議頭。

至此 網頁完成 在瀏覽器中敲入板子的IP地址 便可以看到網頁了

二、POST方案實現

LWIP HTTP 協議中預設只支援GET方法 但是一般提交表單時都用POST方法 而LWIPPOST方案需要自己實現 不過LWIP已經需要實現的函式申明在httpd.h中了

首先將巨集 LWIP_HTTPD_SUPPORT_POST 

設定成表示支援HTTP POST 方法需要實現的函式分別為: httpd_post_begin(當接收到一個POST請求時會呼叫此函式), httpd_post_receive_data(接收HTTP POST 資料), httpd_post_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[i].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 用於給瀏覽器響應相應的請求

    }

}

至此 HTTP SERVER 和 HTTP POST 方法實現完成


相關推薦

lwip1.4.0 http server實現POST 實現

lwip1.4.0之http server實現及POST 實現 一、HTTP SERVER的實現  lwip預設的http server 在 apps/httpserver_raw 主要核心檔案為 fs.c fs.h(讀取相關html相關資源), httpd.c htt

【MySQL進階】Keepalived1.4.0結合MySQL 5.7.19實現主備高可用

port 腳本 amp ado roo ins log openss net 1、基本環境 數據庫安裝及主備同步接上一篇文章:http://blog.51cto.com/13946719/2309514JDK 1.8_171MySQL 5.7.19CentOS 7.4Kee

windows下 hadoop2.4.0 eclipse 外掛安裝配置

一、環境說明 hadoop 版本:2.4.0 hadoop 安裝環境:centos6 centos主機IP地址:192.168.0.207 eclipse版本:Luna eclipse 安裝環境:windows10

swoolefy 4.0.7 釋出,基於 swoole 實現的輕量級框架

swoolefy是一個基於swoole實現的輕量級、高效能、協程級、開放性的API和MVC應用服務框架。簡單易用,效能穩定,支援企業級應用,本次主要更新如下: 將應用層寄存在整個服務生命週期中,之前寄存在每次的訪問生命週期 廢棄 swoole_serialize 以便相容php7.3,使用ser

http-server安裝執行

既然你知道http-server那麼node和npm的安裝我就不說了,當然你也可以實用Yarn安裝. 重點:請實用管理員許可權安裝 server . npm install http-server -g  pm i http-server yarn -g http-serv

《NETTY官方文件》4.0的新特性注意點

原文連結 譯者:裘卡 此文件涵蓋了此次Netty大版本中值得關注的變更點及新特性,以幫助你將自己的應用順利移植到新版本。 專案結構變更 基於netty已經不再是JBoss.org的一部分,我們將包名從 org.jboss.netty 變更為 io.netty。 二進位制jar包也被分割成了

OSG3.4.0+VS2010+WIN10編譯二次開發環境搭建

         這是我的第一篇博文,最近在學習QGIS和OSG,在開源軟體編譯及環境搭建中遇到了一系列的問題,因此也查詢學習了網上的很多教程,在幾次試驗後終於完成了原始碼的編譯和環境配置,寫下這篇

fetch跨域實現post傳參問題

fetch跨域有兩種方法: 1.前端jsonp跨域 2.後端設定cors跨域 首先,嘗試了jsonp跨域,可以輕鬆成功連線上豆瓣API 引入包 fetch-jsonp try{ const url = `https://api.douban.

移動端搭建Http Server(五)—— 實現URL路由模組

在前面幾篇文章中已經實現了移動端Server的關鍵前兩步:監聽遠端連線和解析HTTP Headers中的資料,本文將要設計一下路由規則 1.URL路由規則 簡單來講就是客戶端請求一個URL,伺服器分發給哪個服務來處理 移動端Server要實現兩個功能:

android ble 藍芽4.0多機通訊客戶端實現

自從進入軟體開發行業,都是一直在CSDN上索取無數資料,一直沒有貢獻過,今天突然想寫點什麼,第一次寫,寫點簡單的吧,不知道有沒有人看。 藍芽從4.0開始,支援了多裝置通訊,android 4.3開始支援了藍芽4.0,即 android ble關於ble 網上資料很多,也講的

fibonacii數列(斐波那契數列)的遞迴實現迴圈實現

public class Fibonacii { public static long fibo(int num){ //遞迴方法 if(num==1||num==2) //定義出口 return 1; return fibo(num-1)+fibo(

棧ADT鏈式實現陣列實現

棧ADT  棧的名詞就不解釋了 先是鏈式實現: 三個程式碼  測試 標頭檔案 及函式實現原始碼 stack.h: /* 棧型別的標頭檔案 */ #ifndef STAC

.net 4.0以下版本,MVVM模式ViewModel基類:使用StackTrace實現INotifyPropertyChanged介面

using System; using System.ComponentModel; namespace SSMart_Model {     public class VModelBase: INotifyPropertyChanged, IDisposable    

用NodeJS/express-4.0實現的靜態檔案伺服器(serveStatic外掛直接支援HTTP Range請求,因此可用來做mp4流媒體伺服器)

var express = require('express'), serveIndex = require('serve-index'), //只能列表目錄,不能下載檔案? serveStatic = require('serve-stat

netty原始碼解解析(4.0)-10 ChannelPipleline的預設實現--事件傳遞處理 netty原始碼解解析(4.0)-2 Chanel的介面設計 netty原始碼解解析(4.0)-8 ChannelPipeline的設計

  事件觸發、傳遞、處理是DefaultChannelPipleline實現的另一個核心能力。在前面在章節中粗略地講過了事件的處理流程,本章將會詳細地分析其中的所有關鍵細節。這些關鍵點包括: 事件觸發介面和對應的ChannelHandler處理方法。 inbound事件的傳遞。  outbou

人工智能工業4.0

智能機器人 人工智能 工業機器人 工業4.0   信息化時代對工業提出了新的要求,物聯網、雲計算等技術是新一代自動化產品擴展的方向。本屆展會特設了工業機器人及智慧工廠展區、自動化產品展區、智能機器人展區、機器視覺與傳感器展區、自動化設備及智能裝配展區等五大展區,匯集了眾多國內外頂級品牌展商。在

python 基礎 4.0 函數的一般形式傳參

hit lin style 參數 odi 你好 value weight 入參 #/usr/bin/python #coding=utf-8 #@Time :2017/10/23 15:58 #@Auther :liuzhenchuan #@File :函數的一般形

Flink1.4.0中反序列化序列化類變化

繼承 tde post 變化 flink ted 標記 api col Flink1.4.0中,反序列化及序列化時繼承的類,有一些被標記為了“@deprecated”,路徑上也有變化: 1.AbstractDeserializationSchema 以前路徑 org

Centos 7.4http-2.4 的基本實現和 https 的實現

http-2.4 https 1.建立httpd服務,要求: 1) 提供兩個基於名稱的虛擬主機www1, www2;要求每個虛擬主機都有單獨的錯誤日誌和訪問日誌; 2) 通過www1的/server-status提供狀態信

編譯安裝Apache HTTP Server 2.4.23 以及配置HTTP/HTTPS反向代理

chan .so har 替換 quest pre and for 大小 編譯安裝Apache HTTP Server 2.4.23以及配置HTTP/HTTPS反向代理一,依賴軟件: 1.1 GCC和C++編譯器 GCC C++ Compiler 1.1.1 如果沒有安