如何利用C語言實(shí)現(xiàn)最簡(jiǎn)單的HTTP服務(wù)器詳解
此段代碼的特點(diǎn)
<h1>Hello!</h1>
如何編譯運(yùn)行?
編譯: gcc -o hello_server hello_server.c
運(yùn)行: ./hello_server
請(qǐng)求: curl http://localhost:8888/any
源文件 hello_server.c
#include <stdio.h> #include <stdlib.h> #include <sys/types.h> #include <sys/socket.h> #include <netinet/in.h> #include <arpa/inet.h> #include <unistd.h> #include <string.h> #define PORT 8888 #define BUFFER_SIZE 4096 #define RESPONSE_HEADER "HTTP/1.1 200 OK\r\nConnection: close\r\nAccept-Ranges: bytes\r\nContent-Type: text/html\r\n\r\n" #define RESPONSE_BODY "<h1>Hello!</h1>" int handle(int conn){ int len = 0; char buffer[BUFFER_SIZE]; char *pos = buffer; bzero(buffer, BUFFER_SIZE); len = recv(conn, buffer, BUFFER_SIZE, 0); if (len <= 0 ) { printf ("recv error"); return -1; } else { printf("Debug request:\n--------------\n%s\n\n",buffer); } send(conn, RESPONSE_HEADER RESPONSE_BODY, sizeof(RESPONSE_HEADER RESPONSE_BODY), 0); close(conn);//關(guān)閉連接 } int main(int argc,char *argv[]){ int port = PORT; struct sockaddr_in client_sockaddr; struct sockaddr_in server_sockaddr; int listenfd = socket(AF_INET,SOCK_STREAM,0); int opt = 1; int conn; socklen_t length = sizeof(struct sockaddr_in); setsockopt(listenfd, SOL_SOCKET, SO_REUSEADDR, &opt, sizeof(int)); server_sockaddr.sin_family = AF_INET; server_sockaddr.sin_port = htons(port); server_sockaddr.sin_addr.s_addr = htonl(INADDR_ANY); if(bind(listenfd,(struct sockaddr *)&server_sockaddr,sizeof(server_sockaddr))==-1){ printf("bind error!\n"); return -1; } if(listen(listenfd, 10) < 0) { printf("listen failed!\n"); return -1; } while(1){ conn = accept(listenfd, (struct sockaddr*)&client_sockaddr, &length); if(conn < 0){ printf("connect error!\n"); continue; } if (handle(conn) < 0) { printf("connect error!\n"); close(conn); continue; } } return 0; }
后記
為什么要寫這篇博文?
原因是,在使用公司里的自動(dòng)化平臺(tái)部署c++服務(wù)時(shí),拿這個(gè)簡(jiǎn)單的示例來測(cè)試平臺(tái)是否有問題。俗稱趟一遍坑兒。
在網(wǎng)上也搜索了很多不少博文,發(fā)現(xiàn)里面的代碼有幾個(gè)問題,第一個(gè)問題就是編譯不過,第二個(gè)問題則是有的代碼應(yīng)答必須要有文件,這對(duì)我的測(cè)試也造成了些許麻煩。
所以就自己參考別人的列子,在自己的博客里寫一個(gè)簡(jiǎn)單的吧。以后再去趟別的自動(dòng)化部署系統(tǒng)的坑的時(shí)候,順手就能拿來用。
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
一文帶你了解C語言中的0長(zhǎng)度數(shù)組(可變數(shù)組/柔性數(shù)組)
眾所周知,?GNU/GCC?在標(biāo)準(zhǔn)的?C/C++?基礎(chǔ)上做了有實(shí)用性的擴(kuò)展,?零長(zhǎng)度數(shù)組(Arrays?of?Length?Zero)?就是其中一個(gè)知名的擴(kuò)展,本文就來聊聊零長(zhǎng)度數(shù)組的相關(guān)知識(shí)吧2023-03-03C語言對(duì)堆排序一個(gè)算法思路和實(shí)現(xiàn)代碼
這篇文章主要介紹了C語言對(duì)堆排序一個(gè)算法思路和實(shí)現(xiàn)代碼,堆排序是一種樹形選擇排序,是對(duì)直接選擇排序的有效改進(jìn),需要的朋友可以參考下2014-06-06C++如何計(jì)算結(jié)構(gòu)體與對(duì)象的大小
這篇文章主要給大家介紹了關(guān)于C++如何計(jì)算結(jié)構(gòu)體與對(duì)象大小的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-05-05Visual Studio Code 從簡(jiǎn)介、安裝到配置所需插件詳細(xì)介紹
這篇文章給大家介紹到vs與vs code的區(qū)別,并且會(huì)詳細(xì)介紹vscode的安裝步驟,和我所了解過的插件配置,感興趣的朋友跟隨小編一起看看吧2020-03-03