如何利用C語言實現(xiàn)最簡單的HTTP服務(wù)器詳解
此段代碼的特點
<h1>Hello!</h1>
如何編譯運行?
編譯: gcc -o hello_server hello_server.c
運行: ./hello_server
請求: 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;
}
后記
為什么要寫這篇博文?
原因是,在使用公司里的自動化平臺部署c++服務(wù)時,拿這個簡單的示例來測試平臺是否有問題。俗稱趟一遍坑兒。
在網(wǎng)上也搜索了很多不少博文,發(fā)現(xiàn)里面的代碼有幾個問題,第一個問題就是編譯不過,第二個問題則是有的代碼應(yīng)答必須要有文件,這對我的測試也造成了些許麻煩。
所以就自己參考別人的列子,在自己的博客里寫一個簡單的吧。以后再去趟別的自動化部署系統(tǒng)的坑的時候,順手就能拿來用。
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對腳本之家的支持。
相關(guān)文章
c語言之char*和unsigned?char*的區(qū)別及說明
這篇文章主要介紹了c語言之char*和unsigned?char*的區(qū)別及說明,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-08-08
關(guān)于C++中定義比較函數(shù)的三種方法小結(jié)
下面小編就為大家?guī)硪黄P(guān)于C++中定義比較函數(shù)的三種方法小結(jié)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-10-10
C++實現(xiàn)LeetCode(189.旋轉(zhuǎn)數(shù)組)
這篇文章主要介紹了C++實現(xiàn)LeetCode(189.旋轉(zhuǎn)數(shù)組),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下2021-07-07

