这是我正在学习的服务器:http://blog.abhijeetr.com/2010/04/very-simple-http-server-writen-in-c.html。
我完全不明白get请求服务器之类的东西如何发送get请求我不知道如何做到这一点的原因是,所有的教程都指向从一个网站请求,而这是从我当前的目录或至少从我所了解的。
这是一个学校作业,我们可以复制此作业的代码,但我们必须找到作者关键是要了解web服务器是如何工作的,而我不了解Get请求的作用以及如何在这个特定的服务器中实现一个Get请求,因此我可以研究它的效果。
谢谢,下面是我要点击的具体代码我想测试不同的get请求,看看我能得到什么响应或错误。
if ( (fd=open(path, O_RDONLY))!=-1 )
{
send(clients[n], "HTTP/1.0 200 OK\n\n", 17, 0);
while ( (bytes_read=read(fd, data_to_send, BYTES))>0 )
write (clients[n], data_to_send, bytes_read);
}
else write(clients[n], "HTTP/1.0 404 Not Found\n", 23); //FILE NOT FOUND
最佳答案
查看HTTP 1.1 RFC #GET了解get请求是什么当您使用浏览器访问网站(所有网站都在某种HTTP服务器上运行)时,您的浏览器充当客户端,网站充当服务器客户端发起请求,服务器响应该请求。
请求的主要类型(由浏览器响应用户试图查看的URL而发起)是GET请求。
例如,如果用户想要访问URLhttp://www.example.com/index.htm,浏览器将连接到服务器www.example.com的TCP端口80(默认情况下)建立连接后,浏览器将使用标准GET请求启动“对话”,该请求可能如下所示:
GET /index.htm HTTP/1.1
Host: www.example.com
User-Agent: Mozilla/5.0 (X11; U; Linux x86_64; sv-SE; rv:1.8.1.12) Gecko/20080207 Ubuntu/7.10 (gutsy) Firefox/2.0.0.12
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Language: en-US,en;q=0.5
Accept-Encoding: gzip, deflate
Connection: keep-alive
第一行(请求行)之后的任何标题都是可选的,尽管任何浏览器都希望包含“主机”标题,因为没有它大多数网站都无法工作(这允许多个网站共享一个IP地址)在这种情况下,如果不在这里指定主机名,服务器就无法知道您要访问哪个网站。
在该服务器上获取index.htm的最小GET请求应该是:
GET /index.htm HTTP/1.1
请注意,请求的结尾由一个双CRLF序列(ASCII码13和10)终止,一个用于最新的标题行,另一个用于标记请求标题的结尾一旦服务器接收到双CRLF序列,服务器就会相应地用一个状态行和代码(是否找到文档?)。如果找到文档,则在响应中返回,通常HTTP状态代码为200,响应头(与请求头的格式相同),双CRLF序列,然后是请求文件的正文HTTP标准将其称为“实体”在这种情况下,返回的实体将是index.htm的内容使用上面的示例,服务器可能会做出如下响应:
HTTP/1.1 200 OK
Content-Type: text/html
Content-Length: 66
Last-Modified: Wed, 14 Sep 2016 13:05:21 GMT
<html>
<body>
Welcome to my example page
</body>
</html>
因此,这是一个简单的HTTP GET/response会话示例,简而言之,尽管您可以猜测,根据请求和响应头的不同,事情可能会变得更加复杂。
为了回答您关于如何手动向运行中的服务器发送GET请求的问题,我喜欢在linux机器上使用“curl-I”Curl充当client/broswer,允许您指定要获取的URL(下载)例如:
curl -i http://localhost/test.htm
i选项使curl显示整个web服务器响应(包括HTTP响应头),而不仅仅是在本例中为test.htm内容的实体您只需要调整上面的URL,使之与正在运行的web服务器的URL相匹配,不管它是在同一台计算机上还是在网络上的其他地方。