http中的request的操作

首先,你要明白过滤bai器的原理。过滤器执du行完chain.dofilter(req,resp)后,放行到你所zhi在的servlet或jsp,执行完servlet或者daojsp后,或重新回到过滤器执zhuan行完剩余代码,要是你在剩余代码中又有请求发出,程序就会发生发出多次请求错误。总的来说,就是chain.dofilter(req,resp)下面的代码不能有请求,如果有,请加上return。
如果跳转写在方法里,记得让方法也一起跳转让
return层层跳转上去

request.getRequestDispatcher()之后一定要return
调用request的方法也request.
getRequestDispatcher(path).forward(),执行完,后面的代码居然还会执行!!!记得加return 啊亲
尽管HttpServletResponse.sendRedirect方法和RequestDispatcher.forward方法都可以让浏览器获得另外一个URL所指向的资源,但两者的内部运行机制有着很大的区别。下面是HttpServletResponse.sendRedirect方法实现的请求重定向与RequestDispatcher.forward方法实现的请求转发的总结比较:

(1)RequestDispatcher.forward方法只能将请求转发给同一个WEB应用中的组件;而 HttpServletResponse.sendRedirect 方法不仅可以重定向到当前应用程序中的其他资源,还可以重定向到同一个站点上的其他应用程序中的资源,甚至是使用绝对URL重定向到其他站点的资源。如果传递给HttpServletResponse.sendRedirect 方法的相对URL以“/”开头,它是相对于整个WEB站点的根目录 ;如果创建RequestDispatcher对象时指定的相对URL以“/”开头,它是相对于当前WEB应用程序的根目录 。

(2)调用HttpServletResponse.sendRedirect方法重定向的访问过程结束后,浏览器地址栏中显示的URL会发生改变,由初始的URL地址变成重定向的目标URL;而调用RequestDispatcher.forward 方法的请求转发过程结束后,浏览器地址栏保持初始的URL地址不变。

(3)HttpServletResponse.sendRedirect方法对浏览器的请求直接作出响应,响应的结果就是告诉浏览器去重新发出对另外一个URL的访问请求,这个过程好比有个绰号叫“浏览器”的人写信找张三借钱,张三回信说没有钱,让“浏览器”去找李四借,并将李四现在的通信地址告诉给了“浏览器 ”。于是,“浏览器”又按张三提供通信地址给李四写信借钱,李四收到信后就把钱汇给了“浏览器”。可见,“浏览器”一共发出了两封信和收到了两次回复,“ 浏览器”也知道他借到的钱出自李四之手。RequestDispatcher.forward方法在服务器端内部将请求转发给另外一个资源,浏览器只知道发出了请求并得到了响应结果,并不知道在服务器程序内部发生了转发行为。这个过程好比绰号叫“浏览器”的人写信找张三借钱,张三没有钱,于是张三找李四借了一些钱,甚至还可以加上自己的一些钱,然后再将这些钱汇给了“浏览器”。可见,“浏览器”只发出了一封信和收到了一次回复,他只知道从张三那里借到了钱,并不知道有一部分钱出自李四之手。

(4)RequestDispatcher.forward方法的调用者与被调用者之间共享相同的request对象和response对象,它们属于同一个访问请求和响应过程 ;而HttpServletResponse.sendRedirect方法调用者与被调用者使用各自的request对象和response对象,它们属于两个独立的访问请求和响应过程 。对于同一个WEB应用程序的内部资源之间的跳转,特别是跳转之前要对请求进行一些前期预处理,并要使用HttpServletRequest.setAttribute方法传递预处理结果,那就应该使用 RequestDispatcher.forward方法。不同WEB应用程序之间的重定向,特别是要重定向到另外一个WEB站点上的资源的情况,都应该使用HttpServletResponse.sendRedirect方法。

(5)无论是RequestDispatcher.forward方法,还是HttpServletResponse.sendRedirect方法,在调用它们之前,都不能有内容已经被实际输出到了客户端。如果缓冲区中已经有了一些内容,这些内容将被从缓冲区中清除。

(6) 代码的执行:

无论是 request.getRequestDispatcher(path).forward(request, response)还是response.sendRedirect,程序都会在执行完该句的情况下继续向下执行,因此在必要的时候应该使用return终止该方法.

对于 request.getRequestDispatcher(path).forward(request, response),在执行完该方法的时候再进行对request的操作已经没有任何意义,如果在该方法之后再进行request.setAttribute(),该值将不会被放进当前请求的request中.

response.setRedirect:该方法执行之后,接下来的方法也会被执行.但是使用该方法的时候,会发送一个全新的request,将不再使用原先的request,因此不论在该方法执行之前,还是在该方法执行之后,对request操作,都是无效的

request乱码指的是:浏览器向服务器发送的请求参数中包含中文字符,服务器获取到的请求参数的值是乱码;

response乱码指的是:服务器向浏览器发送的数据包含中文字符,浏览器中显示的是乱码;

一、乱码产生的原因

不管是request乱码还是response乱码,其实都是由于客户端(浏览器)跟服务器端采用的编码格式不一致造成的。

以request乱码为例:浏览器向服务器发送请求,因为浏览器与服务器之间的通信实质上是socket流,所以要先将请求参数(字符)转换成字节,也就是编码过程,服务器接收到请求参数后进行解码(字节转字符),然后封装到request对象中。如果客户端的编码与服务器端的解码不统一,就会导致通过request获取到的请求参数的值是乱码。

二、乱码分类及解决方案
(一)、response乱码
服务器发给浏览器的数据默认是按照ISO-8859-1编码,浏览器接收到数据后按照默认的字符集进行解码后显示,如果浏览器的默认解码字符集不是ISO-8859-1,就出现乱码。

对于response乱码,只需要在服务器端指定一个编码字符集,然后通知浏览器按照这个字符集进行解码就可以了。
有三种方式:
1、response.setCharacterEncoding("utf-8”);//设置服务器端的编码,默认是ISO-8859-1;该方法必须在response.getWriter()之前进行设置
response.setHeader(“contentType”, "text/html; charset=utf-8”);//通知浏览器服务器发送的数据格式是text/html,并要求浏览器使用utf-8进行解码。

2、response.setContentType("text/html;charset=utf-8”);//等同于response.setHeader(“contentType”, "text/html; charset=utf-8”);
而且,它会覆盖response.setCharacterEncoding("utf-8”) ,
在开发中只需要设置response.setContentType("text/html;charset=utf-8”)就可以了。意思是通知浏览器服务器发送的数据格式是text/html,服务器采用utf-8编码,并要求浏览器使用utf-8进行解码。

3、response.setCharacterEncoding(“utf-8”);//设置服务器端的编码为utf-8
response.getWriter().println(””);//要求浏览器使用utf-8进行解码

可以看出,第二种方式是最简便的,这也是我们在开发中最常使用的方式。

(二)、request乱码
从浏览器发起的访问方式有三种:在地址栏直接输入URL访问、点击页面中的超链接访问、提交表单访问。

【 在服务器端,通过request.setCharacterEncoding("XXX”)即可设置服务器的解码为XXX(默认是ISO-8859-1)。
只要服务器的解码字符集和请求参数的编码字符集一致,就不会产生乱码】

1、post方式:表单提交
post方式属于表单提交,参数存在于请求体中,
其编码方式和 <%@ page language=“java” contentType=“text/html;charset=UTF-8”
pageEncoding="GBK%> 中的charset=UTF-8的编码方式一致。
通过request.setCharacterEncoding("UTF-8”)即可解决乱码。

2、get方式:超链接、在地址栏输入URL
get方式提交的参数会跟在请求行中的uri后边,服务器按照默认的iso-8859-1进行解码(注意:是服务器对URI参数进行编码,且一律采用ISO8859-1进行解码),
这时候解决乱码有两种办法:

·办法一:修改服务器端对uri参数的默认编码

在tomcat的server.xml中,
(1)设置<Connector ….>元素的属性URIEncoding="UTF-8”即可。(默认没有设置此属性),指定URI使用“UTF-8”编码方式。
注意:其要求 <%@ page language=“java” contentType=“text/html; charset=UTF-8”
pageEncoding=“GBK” %> 中的charset的值为UTF-8,否则依旧乱码。
【例如:<Connector connectionTimeout=“20000” port=“8080” protocol=“HTTP/1.1” redirectPort=“8443” URIEncoding="UTF-8”/>】

(2)设置<Connector ….>元素的属性useBodyEncodingForURI=“true”,(默认没有设置此属性),意思是URI使用和请求体一样的编码方式,以请求体的为准。
即URI和 <%@ page language=“java” contentType=“text/html; charset=XXX”
pageEncoding=“GBK” %> 中的charset=XXX的编码方式一致。(可以是GBK,也可以是UTF-8)
【例如:<Connector connectionTimeout=“20000” port=“8080” protocol=“HTTP/1.1” redirectPort="8443"useBodyEncodingForURI=“true”/>】

注意:同时设置这两个属性(URIEncoding="UTF-8” 与 useBodyEncodingForURI=“true”),则URI还是使用和请求体一样的编码方式,useBodyEncodingForURI=“true”有效,URIEncoding="UTF-8”无效。

一步到位
1、通过修改server.xml指定服务器对get和post统一按照utf-8解码,即同时设置(URIEncoding="UTF-8” 与 useBodyEncodingForURI=“true”)
2、要求tomcat管理下的所有web应用都要使用utf-8编码,即所有的jsp、html页面都使用utf-8编码。
比如 JSP页面的头信息是这样的:
<%@ page language=“java” contentType=“text/html; charset=utf-8”
pageEncoding=“utf-8”%>

这样,应该就不会出现request和response的中文乱码问题了。

·办法二:回退重编
根据ISO-8859-1进行回退
1、超链接:根据 <%@ page language=“java” contentType=“text/html;charset=XXX” pageEncoding=“XXX”%> 中的charset的值 进行重编,即可得到正常的参数值。

2、在地址栏直接输入URL:根据UTF-8进行重编。

例如:
<%@ page language=“java” contentType=“text/html;charset=UTF-8” pageEncoding=“UTF-8”%>
String name = request.getParameter("name”);//得到乱码
name = new String(name.getBytes(“iso-8859-1”),"utf-8”);//得到正常的name值
注意:name.getBytes();如果不指定编码,默认按照gb2312进行编码。

request和respon
程序员通过request对象获取消息,获取知识(获取情况)根据response回复处理方式
request和respones都是由tomcat创建的

request对象功能,有点像信访等级

1.以下是获取请求行的数据

请求行中包含:

  1. 请求申请的资源
  2. 请求方式
  3. get方法还包含了请求参数
  4. 请求的版本号http 1.0 1.1 2.0

请求消息数据,1.获取请求行
1.getMethod获取请求方式
2.获取请求虚拟目录getContextPath
3/获取servlet路径 getServletPath
4.getQureyString
5.getRequestURL 获取申请访问的地址
6.getRemoveAddr()访问人员地址

URL和URI区别:URI比URL小,但是权限更大,uri是共和国,url是中华人民共和国

request的一些基本操作

package com.company.Demo;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
@WebServlet("/demo02")
public class Demo extends HttpServlet {
   
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
   
        super.doGet(req, resp);
        String method = req.getMethod();//返回请求方式
        System.out.println(method);

        String contextPath = req.getContextPath();//返回虚拟目录
        System.out.println(contextPath);

        String queryString = req.
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值