标签:response request 编码 路径 servlet
内容: 
* response 
* request 
* 编码 
* 路径
服务器处理请求的流程: 
  服务器每次收到请求时,都会为这个请求开辟一个新的线程。 
  服务器会把客户端的请求数据封装到request对象中,request就是请求数据的载体!(袋子) 
  服务器还会创建response对象,这个对象与客户端连接在一起,它可以用来向客户端发送响应。(手机)
response:其类型为HttpServletResponse 
  ServletResponse–>与协议无关的类型 
  HttpServletResponse–>与http协议相关的类型
  回忆一下http协议!http协议中响应的内容包含哪些东西呢? 
  * 状态码:200表示成功、302表示重定向、404表示客户端错(访问的资源不存在)、500表示服务器端错 
    > sendError(int sc) –> 发送错误状态码,例如404、500 
    > sendError(int sc, String msg) –> 也是发送错误状态码,还可以带一个错误信息! 
    > setStatus(int sc) –> 发送成功的状态码,可以用来发送302 
    案例: 
    > 发送404 
  * 响应头:Content-Type、Refresh、Location等等 
    头就是一个键值对!可能会存在一个头(一个名称,一个值),也可能会存在一个头(一个名称,多个值!)
*****setHeader(String name, String value):适用于单值的响应头,例如:response.setHeader(“aaa”, “AAA”);
> addHeader(String name, String value):适用于多值的响应头
response.addHeader(“aaa”, “A”);
response.addHeader(“aaa”, “AA”);
response.addHeader(“aaa”, “AAA”);
> setIntHeader(String name, int value):适用于单值的int类型的响应头
` response.setIntHeader(“Content-Length”, 888);
> addIntHeader(String name, int value):适用于多值的int类型的响应头
> setDateHeader(String name, long value):适用于单值的毫秒类型的响应头
response.setDateHeader(“expires”, 1000 * 60 * 60 * 24);
> addDateHeader(String name, long value):适用于多值的毫秒类型的响应头
案例:
> 发送302,设置Location头,完成重定向!
> 定时刷新:设置Refresh头,你可以把它理解成,定时重定向!
> 禁用浏览器缓存:Cache-Control、pragma、expires
    > 标签可以代替响应头: 
  * 响应体:通常是html、也可以是图片! 
    > response的两个流: 
      <> ServletOutputStream,用来向客户端发送字节数据。ServletOutputStream out = response.getOutputStream(); 
      <> PrintWriter,用来向客户端发送字符数据!需要设置编码。PrintWriter writer = response.getWriter(); 
      <> 两个流不能同时使用!否则抛illegalStateException异常 
    案例: 
    > 使用PrintWriter发送字符数据 
    > 使用ServletOutputStream发送字节数据(图片) 
  * 重定向:设置302,设置Location!其中变化的只有Location,所以java提供了一个快捷方法,完成重定向! 
   > sendRedirect(String location)方法
request –> 封装了客户端所有的请求数据! 
请求行 
请求头 
空行 
请求体(GET没体,请求参数在URL中)
  回忆一下http协议!请求协议中的数据都可以通过request对象来获取! 
  * 获取常用信息 
    > 获取客户端IP,request.getRemoteAddr(), 案例:封IP。 
    > 请求方式,request.getMethod(),可能是POST也可能是GET 
  * 获取HTTP请求头 
    > *****String getHeader(String name),适用于单值头 
    > int getIntHeader(String name),适用于单值int类型的请求头 
    > long getDateHeader(String name),适用于单值毫秒类型的请求头 
    > Enumeration getHeaders(String name),适用于多值请求头
   案例: 
    > 通过User-Agent识别用户浏览器类型 
    > 防盗链:如果请求不是通过本站的超链接发出的,发送错误状态码404。Referer这个请求头,表示请求的来源! 
  * 获取请求URL 
    http://localhost:8080/day10_2/AServlet?username=xxx&password=yyy 
    > String getScheme():获取协议,http 
    > String getServerName():获取服务器名,localhost 
    > String getServerPort():获取服务器端口,8080 
    > *****String getContextPath():获取项目名,/day10_2 
    > String getServletPath():获取Servlet路径,/AServlet 
    > String getQueryString():获取参数部分,即问号后面的部分。username=xxx&password=yyy 
    > String getRequestURI():获取请求URI,等于项目名+Servlet路径。/day10_2/AServlet 
    > String getRequestURL():获取请求URL,等于不包含参数的整个请求路径。http://localhost:8080/day10_2/AServlet
  * 获取请求参数:请求参数是由客户端发送给服务器的!有可能是在请求体中(POST),也可能是在URL之后(GET) 
    请求参数:有一个参数一个值的,还有一个参数多个值! 
    > *****String getParameter(String name):获取指定名称的请求参数值,适用于单值请求参数 
    > String[] getParameterValues(String name):获取指定名称的请求参数值,适用于多值请求参数 
    > Enumeration getParameterNames():获取所有请求参数名称 
    > *****Map
常见字符编码:iso-8859-1(不支持中文)、gb2312、gb18030,gbk(系统默认编码,中国的国标码)、utf-8(万国码,支持全世界的编码,所以我们使用这个)
响应编码
  * 当使用response.getWriter()来向客户端发送字符数据时,如果在之前没有设置编码,那么默认使用iso,因为iso不支持中文,一定乱码 
  * 在使用response.getWriter()之前可以使用response.setCharaceterEncoding()来设置字符流的编码为gbk或utf-8,当然我们通常会选择utf-8。这样使用response.getWriter()发送的字符就是使用utf-8编码的。但还是会出现乱码!因为浏览器并不知道服务器发送过来的是什么编码的数据!这时浏览器会使用gbk来解码,所以乱码! 
  * 在使用response.getWriter()之前可以使用response.setHeader(“Content-type”,”text/html;charset=utf-8”)来设置响应头,通知浏览器服务器这边使用的是utf-8编码,而且在调用setHeader()后,还会自动执行setCharacterEncding()方法。这样浏览器会使用utf-8解码,所以就不会乱码了! 
  * setHeader(“Content-Type”, “text/html;charset=utf-8”)的快捷方法是:setContentType(“text/html;charset=utf-8)。 
总结:想不乱码,在使用getWriter()方法之前,先调用下面方法 
response.setContentType(“text/html;charset=utf-8”);就不会乱码
请求编码
  * 客户端发送给服务器的请求参数是什么编码: 
    客户端首先要打开一个页面,然后在页面中提交表单或点击超链接!在请求这个页面时,服务器响应的编码是什么,那么客户端发送请求时的编码就是什么。 
  * 服务器端默认使用什么编码来解码参数: 
    服务器端默认使用ISO-8859-1来解码!所以这一定会出现乱码的!因为iso不支持中文! 
  * 请求编码处理分为两种:GET和POST:GET请求参数不在请求体中,而POST请求参数在请求体中,所以它们的处理方式是不同的! 
  * GET请求编码处理: 
    方式一:需要在tomcat下的conf下的server.xml文件中进行配置,在设置端口处 添加 URIEncoding=”utf-8”(但这种方式不提倡) 
    > String username = new String(request.getParameter(“iso-8859-1”), “utf-8”); 
  * POST请求编码处理: 
    方式一:只需要在获取参数之前调用request的setCharacterEncoding(“utf-8”)方法即可,然后再使用getParameter()等方法获取参数 
    > String username = new String(request.getParameter(“iso-8859-1”), “utf-8”); 
   
URL编码
  表单的类型:Content-Type: application/x-www-form-urlencoded,就是把中文转换成%后面跟随两位的16进制。 
  为什么要用它:在客户端和服务器之间传递中文时需要把它转换成网络适合的方式。
  * 它不是字符编码! 
  * 它是用来在客户端与服务器之间传递参数用的一种方式! 
  * URL编码需要先指定一种字符编码,把字符串解码后,得到byte[],然后把小于0的字节+256,再转换成16进制。前面再添加一个%。 
  * POST请求默认就使用URL编码!tomcat会自动使用URL解码! 
  * URL编码:String username = URLEncoder.encode(username, “utf-8”); 
  * URL解码:String username = URLDecoder.decode(username, “utf-8”);
最后我们需要把链接中的中文参数,使用url来编码!今天不行,因为html中不能给出java代码,但后面学了jsp就可以了。
  * web.xml中路径,(叫它Servlet路径!) 
    > 要么以“*”开关,要么为“/”开头 
  * 转发和包含路径 
    > *以“/”开头:相对当前项目路径,例如:http://localhost:8080/项目名/ request.getRequestdispacher(“/BServlet”).for…(); 
    > 不以“/”开头:相对当前Servlet路径。 request.getRequestdispacher(“BServlet”).for…();,假如当前Servlet是:http://localhost:8080/项目名/servlet/AServlet, 就是http://localhost:8080/项目名/servlet/BServlet 
  * 重定向路径(客户端路径) 
    > 以“/”开头:相对当前主机,例如:http://localhost:8080/, 所以需要自己手动添加项目名,例如;response.sendRedirect(“/day10_1/Bservlet”); 
  * 页面中超链接和表单路径 
    > 与重定向相同,都是客户端路径!需要添加项目名
,如果不以“/”开头,那么相对当前页面所在路径。如果是http://localhost:8080/day10_1/html/form.html。 即:http://localhost:8080/day10_1/html/ASevlet
*建立使用以“/”开头的路径,即绝对路径!
* ServletContext获取资源路径
> 相对当前项目目录,即当然index.jsp所在目录
* ClassLoader获取资源路径不能以”/”开头
> 相对classes目录
* Class获取资源路径
> 以“/”开头相对classes目录
> 不以“/”开头相对当前.class文件所在目录。
servlet中response,request,编码和路径问题
标签:response request 编码 路径 servlet
原文地址:http://blog.csdn.net/u013033038/article/details/44925601