请求的产生:
1. 一个网页上面可能有很多链接 好多可以点的按钮 其实很一个按钮或是链接 当点击了它们以后浏览器都会将我们点击后产生的数据 包装好 另外封装一个消息头 就是这样的消息头:
GET Friend/index.php HTTP/1.1\r\n"
"Host: 61.135.169.105:80\r\n"
"Accept: image/gif, image/x-xbitmap, image/jpeg, image/pjpeg, application/x-shockwave-flash, application/vnd.ms-excel, application/vnd.ms-powerpoint, application/msword, */*\r\n"
"Accept-Language: zh-cn\r\n"
"Accept-Encoding: deflate\r\n"
"User-Agent: Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1)\r\n"
"Connection: Keep-Alive\r\n" 可别小看了这个消息头 这里面包含的信息可不少 当然我写出来的这上消息头只是常见的一些数据 有时也会比这些再多出几条 这里面标识着你这个请求发给的服务器Ip及Port 然后是服务器上的应用名及你要访问的页面或是请求。
2.服务器第一步
1.寻找请求的数据或请求对应的处理
当这个请求到达目标服务器的时候,服务器会检查你请求的数据,是固定的页面还是一点请求 ,如果是页面便查找出页面将页面的内容发送回浏览器, 如果是请求的话,那么服务器会按照规则到这个应用中找出web.xml里的配置信息进行匹配 这时如果找到匹配的请求信息便调用配置信息中指定的servlet 类来进行处理 如果找不到 那么这时服务器会包装一个消息头 当然这个消息头的号便是常见的404 也就是没有资源 那么如果找到了servlet进行了调用 那么servlet都做什么了呢
2.调用servlet进行处理
调用servlet之后首先会调用servlet的service方法 然后调用完之后才会调用和请求类型对应的doGet或doPost进行处理 当然即然都会首先调用service那么也可以service方法中直接进行处理便可以了 这样就省了很多事 至于servlet的init和destroy方法是什么时候调用请参考servlet的生命周期
3.处理完成响应给浏览器
当这个请求的数据都处理完成后,剩下的也就是该怎么向浏览器返回数据了,如果请求的数据在这个servlet中并没处理完成也可以使用转发请求继续进行处理(在这期间使用的request对象和response对象是一个对象),当然不管是发请求还是返回给浏览器数据了 都会有两种方式 一种是重定向另一种叫做转发 那么重定向和转发又有什么区别呢?
重定向:
重定向首先之前请求中使用的request和response对象,会被销毁,并重新创建,那么所有在request对象中存放的数据也一并消失
在客户浏览器上面地址栏也会发生变化,变成新的请求或新的页面字段
转 发:
转发并不会将之前请求的request和response对象销毁而是继续使用,那么之前在request对象中存放的数据都可以继续使用,这样的话转发也可以使用在一个请求多个servlet进行数据的处理最终再返回给浏览器数据,
在客户浏览器上面地址栏不会发生变化,还是显示之前的字段,但页面却发生了变化
那么到此为止一个请求的完整处理便完成了