http协议的补充二
2018-02-03 20:11
741 查看
一,浏览器到服务器request
1.1,浏览器里面的内容
1 请求(浏览器-》服务器) 2 GET /day09/hello HTTP/1.1 3 Host: localhost:8080 4 User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:35.0) Gecko/20100101 Firefox/35.0 5 Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8 6 Accept-Language: zh-cn,en-us;q=0.8,zh;q=0.5,en;q=0.3 7 Accept-Encoding: gzip, deflate 8 Connection: keep-alive
1 GET /day09/hello HTTP/1.1 -请求行 2 Host: localhost:8080 --请求头(多个key-value对象) 3 User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:35.0) Gecko/20100101 Firefox/35.0 4 Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8 5 Accept-Language: zh-cn,en-us;q=0.8,zh;q=0.5,en;q=0.3 6 Accept-Encoding: gzip, deflate 7 Connection: keep-alive 8 --一个空行 9 name=eric&password=123456 --(可选)实体内容
1.2,解释说明
1 Accept: text/html,image/* -- 浏览器接受的数据类型 2 Accept-Charset: ISO-8859-1 -- 浏览器接受的编码格式 3 Accept-Encoding: gzip,compress --浏览器接受的数据压缩格式 4 Accept-Language: en-us,zh- --浏览器接受的语言 5 Host: www.it315.org:80 --(必须的)当前请求访问的目标地址(主机:端口) 6 If-Modified-Since: Tue, 11 Jul 2000 18:23:51 GMT --浏览器最后的缓存时间 7 Referer: http://www.it315.org/index.jsp -- 当前请求来自于哪里 8 User-Agent: Mozilla/4.0 (compatible; MSIE 5.5; Windows NT 5.0) --浏览器类型 9 Cookie:name=eric -- 浏览器保存的cookie信息 10 Connection: close/Keep-Alive -- 浏览器跟服务器连接状态。close: 连接关闭 keep-alive:保存连接。 11 Date: Tue, 11 Jul 2000 18:23:51 GMT -- 请求发出的时间
1.3,通过HttpServletRequest对象获得请求行的信息
1 /** 2 * 3.1 请求行 格式:(GET /day09/hello HTTP/1.1) 3 */ 4 System.out.println("请求方式:"+request.getMethod());//请求方式 5 System.out.println("URI:"+request.getRequestURI());//请求资源 6 System.out.println("URL:"+request.getRequestURL()); 7 System.out.println("http协议版本:"+request.getProtocol());//http协议
1.4,通过HttpServletRequest对象获得所有请求头的信息
1 /** 2 * 3.2 请求头 3 */ 4 String host = request.getHeader("Host"); //根据头名称的到头的内容 5 System.out.println(host); 6 7 //遍历所有请求头 8 Enumeration<String> enums = request.getHeaderNames(); //得到所有的请求头名称列表 9 while(enums.hasMoreElements()){//判断是否有下一个元素 10 String headerName = enums.nextElement(); //取出下一个元素 11 String headerValue = request.getHeader(headerName); 12 System.out.println(headerName+":"+headerValue); 13 }
1.5,通过HttpServletRequest对象浏览器的信息
1 response.setContentType("text/html;charset=utf-8"); 2 //获取请求头: user-agent 3 String userAgent = request.getHeader("user-agent"); 4 System.out.println(userAgent); 5 6 //判断用户使用的浏览器类型 7 if(userAgent.contains("Firefox")){ 8 response.getWriter().write("你正在使用火狐浏览器"); 9 }else if(userAgent.contains("Chrome")){ 10 response.getWriter().write("你正在使用谷歌浏览器"); 11 }else if(userAgent.contains("Trident")){ 12 response.getWriter().write("你正在使用IE浏览器"); 13 }else{ 14 response.getWriter().write("地球上没有这个浏览器,建议使用火狐浏览器"); 15 } 16 }
1.6,通过HttpServletRequest对象获得所有实体(get请求)的信息
1 /* System.out.println("GET方式"); 2 //接收GET方式提交的参数 3 String value = request.getQueryString(); 4 System.out.println(value);*/
1.7,通过HttpServletRequest对象获得所有实体(post请求)的信息
1 /*System.out.println("POST方式"); 2 InputStream in = request.getInputStream(); 3 byte[] buf = new byte[1024]; 4 int len = 0; 5 while( (len=in.read(buf))!=-1 ){ 6 System.out.println(new String(buf,0,len)); 7 }*/
1.8,通过HttpServletRequest对象获得所有实体(post请求和get请求通用)的信息
1 /*System.out.println("POST方式"); 2 //根据参数名得到参数值 3 String name = request.getParameter("name"); 4 String password = request.getParameter("password"); 5 System.out.println(name+"="+password); 6 7 System.out.println("============================="); 8 Enumeration<String> enums = request.getParameterNames(); 9 while( enums.hasMoreElements() ){ 10 String paramName = enums.nextElement(); 11 String paramValue = request.getParameter(paramName); 12 System.out.println(paramName+"="+paramValue); 13 }*/
1.9,通过HttpServletRequest对象获得所有实体内容name相同的情况,如下拉框都要传到后台的问题。
1 Enumeration<String> enums = request.getParameterNames(); 2 while( enums.hasMoreElements() ){ 3 String paramName = enums.nextElement(); 4 5 //如果参数名是hobit,则调用getParameterValues 6 if("hobit".equals(paramName)){ 7 /** 8 * getParameterValues(name): 根据参数名获取参数值(可以获取多个值的同名参数) 9 */ 10 System.out.println(paramName+":"); 11 String[] hobits = request.getParameterValues("hobit"); 12 for(String h: hobits){ 13 /* if("GET".equals(request.getMethod())){ 14 h = new String(h.getBytes("iso-8859-1"),"utf-8"); 15 }*/ 16 System.out.print(h+","); 17 } 18 System.out.println(); 19 //如果不是hobit,则调用getParameter 20 }else{ 21 String paramValue = request.getParameter(paramName); 22 /* 23 if("GET".equals(request.getMethod())){ 24 paramValue = new String(paramValue.getBytes("iso-8859-1"),"utf-8"); 25 }*/ 26 27 System.out.println(paramName+"="+paramValue); 28 } 29 }
1.10,HttpServletRequest常用的api
1 HttpServletRequest对象作用是用于获取请求数据。 2 3 核心的API: 4 请求行: 5 request.getMethod(); 请求方式 6 request.getRequetURI() / request.getRequetURL() 请求资源 7 request.getProtocol() 请求http协议版本 8 9 请求头: 10 request.getHeader("名称") 根据请求头获取请求值 11 request.getHeaderNames() 获取所有的请求头名称 12 13 实体内容: 14 request.getInputStream() 获取实体内容数据
二,服务器到浏览器response
2.1,通过HttpServletResponse对象来设置字符流还是字节流的输出
1 /** 2 * 3.3 实体内容(浏览器直接能够看到的内容就是实体内容) 3 */ 4 //response.getWriter().write("01.hello world"); //字符内容。 5 response.getOutputStream().write("02.hello world".getBytes());//字节内容
2.2,通过HttpServletResponse对象来设置重定向,相当于浏览器向服务器发送了两次请求
1 /** 2 * 需求: 跳转到adv.html 3 * 使用请求重定向: 发送一个302状态码+location的响应头 4 */ 5 /*response.setStatus(302);//发送一个302状态码 6 response.setHeader("location", "/day09/adv.html"); //location的响应头 7 */ 8 9 //请求重定向简化写法 10 response.sendRedirect("/day09/adv.html"); 11 12 13 }
2.3,通过HttpServletResponse对象来设置刷新页面,或者过几秒自动跳转到某个页面
1 /** 2 * 定时刷新 3 * 原理:浏览器认识refresh头,得到refresh头之后重新请求当前资源 4 */ 5 //response.setHeader("refresh", "1"); //每隔1秒刷新次页面 6 7 /** 8 * 隔n秒之后跳转另外的资源 9 */ 10 response.setHeader("refresh", "3;url=/day09/adv.html");//隔3秒之后跳转到adv.html
2.4,通过HttpServletResponse对象来设置发给服务器的数据类型和内容编码
1 //response.setHeader("content-type", "text/html"); 2 response.setContentType("text/html;charset=utf-8");//和上面代码等价。推荐使用此方法 3 response.getOutputStream().write("<html><head><title>this is tilte</title></head><body>this is body</body></html>".getBytes("utf-8"));
1 //response.setHeader("content-type", "text/html"); 2 response.getOutputStream().write("<html><head><title>this is tilte</title></head><body>this is body</body></html>".getBytes("utf-8"));
2.5,通过HttpServletResponse对象来设置设置以下载方式打开文件
1 /*File file = new File("e:/mm.jpg"); 2 *//** 3 * 设置以下载方式打开文件 4 *//* 5 response.setHeader("Content-Disposition", "attachment; filename="+file.getName()); 6 *//** 7 * 下载图片 8 *//* 9 *//** 10 * 发送图片 11 *//* 12 FileInputStream in = new FileInputStream(file); 13 byte[] buf = new byte[1024]; 14 int len = 0; 15 16 //把图片内容写出到浏览器 17 while( (len=in.read(buf))!=-1 ){ 18 response.getOutputStream().write(buf, 0, len); 19 }*/
相关文章推荐
- HTTP 协议详解 (补充)
- HTTP 协议详解 (补充)
- HTTP 协议详解 (补充)
- Restful Web Service - Http应用层的协议
- 解决这可能是由于服务终结点绑定未使用 HTTP 协议造成的
- 文章5:http协议中content-length 以及chunked编码分析
- http协议学习二
- HTTP协议2
- http协议详解
- http协议
- HTTP协议之缓存
- Servlet之Http协议(二)
- HTTP 协议中GET和POST到底有哪些区别
- Node.js与网络:Node.js对TCP、UDP、Socket、HTTP等协议的实现和支持
- 在Silverlight开发基于http协议客户端连接器(一)
- 转:【专题二】HTTP协议详解
- Http协议详解
- http协议--文章一
- loadrunner:Web(HTTP-HTML)协议的两种录制方式
- http协议入门