HTTP 请求转发、重定向和包含
使Web应用程序如此强大的原因之一是它们彼此链接和聚合信息资源。J2EE 平台为特定URL的 Web组件提供三种相互关联、但是有区别的方式,以便使用其他URL的数据来创建响应。本技巧讨论了如何使用Java Servlet API来实现请求转发、URL重定向和包含。
请求转发
请求转发允许组件发送请求到某个应用程序中的URL,并通过同一应用程序中的不同URL 中的组件来处理该请求。这种技术通常用于Web层控制器servlet,它检查Web请求中的数据,并将请求定向到合适的组件,以便进行处理。
Servlet可以使用javax.servlet.RequestDispatcher.forward方法来转发它所收到的HTTP 请求。接收转发请求的组件能够处理该请求并生成一个响应,或者它还可以将请求转发到另一个组件。最初请求的ServletRequest 和ServletResponse 对象被传递给转发目标组件。这允许目标组件访问整个请求上下文。请求可以只转发给同一应用程序上下文根中的组件,而不在应用程序之间转发。
表单通过POST方法发送给 DispatchDemoServlet,将完成本技巧中三个例子的处理。请求转发由servlet 的doForward 方法处理,代码如下。
protected void doForward(HttpServletRequestreq,
HttpServletResponse res)
throws IOException, ServletException {
String name = req.getParameter("name");
// Look up the site by name
String url = (String)_p.get(name);
if (url == null) {
url = "errorPage.html";
}
// Get the request dispatcher -- request will be
// dispatched to this URL.
RequestDispatcherrd =
req.getRequestDispatcher(url);
// Forward to requested URL
rd.forward(req, res);
}
POST参数“name”指出用户请求的文件的符号名。方法在散列表中查找该文件的URL (散列表从应用归档文件中的属性文件装载) 。然后方法从 HttpServletRequest 对象中获
得 RequestDispatcher 对象。 RequestDispatcher 由Web容器来实现。调用rd.forward指示Web容器调用指定URL的Web组件。请求的结果是该URL的组件返回的任何内容。
URL重定向
URL 重定向类似于请求转发,但也有一些重要的区别。Web组件可以将请求重定向到任一URL,而不仅仅是同一应用上下文中的URL。但最初请求的内容(比如POST参数)丢失了。这是因为服务器与重定向请示的过程无关,这与请求转发的情况是一样的。URL通过使用HTTP META头部的Refresh功能来完成重定向工作。本质上就是,服务器返回一个META标记,告诉浏览器直接去其他地方。这时,最初URL所附带POST数据就会丢失。
URL 重定向可以直接通过操作HTTP 头部来完成,但首选的方式还是使用方法
javax.servlet.ServletResponse.sendRedirect。这个方法的唯一参数就是重定向的目标URL 。
URL 重定向的示例代码使用了示例应用程序中index.html 文件的第二个表单。用户从https://www.360docs.net/doc/8a10192872.html,网站的几个URL中选择一个,然后单击GO。本例子对应于Tip 2 表单中的第2项。
该表单将选定的表单名作为POST方法的参数发送给 DispatchDemoServlet,它再调用方
法doRedirect,代码如下所示:
protected void doRedirect(HttpServletRequestreq,
HttpServletResponse res)
throws IOException, ServletException {
String name = req.getParameter("name");
// Look up the site by name
String url = (String)_p.get(name);
if (url == null) {
url = "errorPage.html";
}
// Redirect request
res.sendRedirect(url);
}
以上是使用doForward 方法来完成请求转发的例子, doRedirect 方法使用用户从表单中选择的符号名来查找重定向的URL。然后doRedirect 方法调用 HttpServletResponse
的 sendRedirect 方法,这就在请求中构造和设置了一个HTTP头部,并立即返回。浏览器将收到空的响应,但因为有META头部,浏览器迅速发出另一个新URL的请求。
虽然servlet产生一个空响应,但如果能在响应中包含一条消息,以解释请求正在重定向,这是一个不错的方法。还有一个好办法是在重定向失败时提供一个到重定向目标的链接。较老的浏览器可能无法实现Refresh功能,或者可能出于安全的原因,该功能已经关闭。链接最好放在例子servlet之外,以简化代码。
包含
到目前为止,您已经学习了响应请求的两种方式:请求转发和URL 重定向。相反,包含允许一个Web组件聚集来自几个其他Web组件的数据,并使用被聚集的数据来创建响应。这种技术通常用于模板处理器。这里一个结构化的模板(通常是JSP 页面)用于控制响应的布局。模板中每个页面区域的内容来自不同的URL,从而组成单个页面。这种技术能够为应该程序提供一致的外观和感觉。
多个Web组件的内容可以被包含在单个响应中。要包含响应中另一个URL的数据,先获得该UML的RequestDispatcher,然后调用 RequestDispatcher的包含方法。
包含的示例代码使用了一组复选框,每个复选框指明一个应用程序归档案中的HTML 文件。每个HTML 文件对应于一种包含在输出中颜色。用户可以通过选中复选框来选择多个文件,然后单击GO。这对应于Tip 2 表单中的第3项。
DispatchDemoServlet 使用了doInclude 方法来处理请求,如下所示:
// Given a list of checked files, include each one of
// them in the output to form a compound document
protected void doInclude(HttpServletRequestreq,
HttpServletResponse res)
throws IOException, ServletException {
String name = req.getParameter("name");
// Get the request dispatcher -- request will be
// dispatched to this URL.
RequestDispatcherrd;
if ((rd = req.getRequestDispatcher("/header.html")) != null) {
rd.include(req, res);
}
if ((rd = req。getRequestDispatcher("/footer。html")) != null) {
rd。include(req, res);
}
String[] names = req.getParameterValues("color");
String url;
for (inti = 0; names != null &&
i if ((url = (String)_p.get(names[i])) == null) { continue; } if ((rd = req.getRequestDispatcher(url)) != null) { rd.include(req, res); } } if ((rd = req.getRequestDispatcher("/footer.html")) != null) { rd.include(req, res); } } } 注意doInclude方法如何多次调用包含。每次调用包含时,doInclude 必须获得合适URL 的 RequestDispatcher。方法首先包含文件 /header.html。然后获得列表中的复选框的名字,再查找散列表中相应的URL。对于找到的每个URL, doInclude为该URL 获取一 个 RequestDispatcher,然后在输出中包含该URL的内容。对包含方法的调用将该URL的输出写入 HttpServletResponse 对象。最后, doInclude 将URL /footer.html (相对上下文根)的内容写入输出。 请求重定向与请求转发 请求重定向与请求转发 在Servlet程序中,有时需要调用服务器端的另外一个资源来对浏览器的请求进行响应,这可以通 两种方式来实现;其中一种就是调用RequestDispatcher.forward方法与include 方法实现的 请求转发;另外一种则是调用HttpServletResponse.sendRedirect方法实现的请求重定向. 1: RequestDispatcher接口(请求转发) RequestDispatcher接口中定义了两个方法: forward 方法和include 方法,它们分别用于将请求转发到RequestDispatcher对象封装的资源和将RequestDispatcher对象封装的资 源作为当前响应内容的一部分包含进来. 1) RequestDispatcher对象的获取[通过ServletContext对象]: ServletContext接口中定义了两个用于获取RequestDispatcher对象的方法 (1) getRequestDispatcher(String param) (2) getNamedDispatcher(String param) ServletContextsc = this.getServletContext(); //ServletContext对象的获取 //RequestDispatcher对象的获取 --RequestDispatcher dis = sc.getRequestDispatcher("/servlet2"); --RequestDispatcher dis = sc.getRequestDispatcher("/servlets/targetservlet"); --RequestDispatcher dis = sc.getRequestDispatcher("/servlets/targetservlet?userName=" + uName); [注: 传递给该方法的路径字符串必须以"/"开头,这个"/"代表当前WEB应用程序的根目录] ServletContextsc = this.getServletContext(); //ServletContext对象的获取 //RequestDispatcher对象的获取 --RequestDispatcher dis = sc.getNamedDispatcher("/servlet2"); --RequestDispatcher dis = sc.getNamedDispatcher("/servlets/targetservlet"); --RequestDispatcher dis = sc.getNamedDispatcher("/servlets/targetservlet?userName=" + uName); [注: 传递给该方法的参数是在WEB应用程序部署描述符中声明过的Servlet或jsp的 映射名称] 2) RequestDispatcher对象的获取[通过ServletRequest对象]: 在ServletRequest接口中也定义了一个getRequestDispatcher(String param) 方法来 获取 RequestDispatcher对象,它与ServletContext.getRequestDispatcher()方法的区别在于: 传递给这个方法的参数除了可以采用以"/"开头的路径字符串,还可以采用非"/"开头的相 对路径. (1) getRequestDispatcher(String param) --RequestDispatcher dis = request.getRequestDispatcher("/servlet2"); --RequestDispatcher dis = request.getRequestDispatcher("servlet2"); --RequestDispatcher dis = request.getRequestDispatcher("servlets/targetservlet"); --RequestDispatcher dis = request.getRequestDispatcher("servlets/targetservlet?userName=" + uName); 3) 用forward方法实现请求转发 dis.forward(request, response); //[两个页面中的request与response是相同的] 4) 用include方法实现资源包含 dis.include(request, response); //[两个页面中的request与response是相同的] 2: HttpServletResponse接口(请求重定向) HttpServletResponse接口中定义了一些用于将请求再次定向到新的资源下的方法,最主 要的是 (1) sendRedirect(String url) 该方法不仅可以重定向到当前应用程序中的其他资源,它还可以重定向到同一个站点上的 其他 应用程序中的资源,甚至是使用绝对URL重定向到其他站点的资源.而RequestDispatcher.forward 方法只能在同一个WEB应用程序内资源之间转发请求.如果传递给sendRedirect方法的相对URL不 是以"/"开头,则表示是相对于当前请求的URL;如果该相对URL是以"/"开头,则是相对于整个WEB站 点的根目录,而不是相对于当前WEB应用程序的根目录,例如,下面的语句表示重定向到当前站点中 的APTECH应用程序根目录下的index.html页面; response.sendRedirect("/APTECH/index.html"); 请求转发和请求包含都表示由多个Servlet共同处理一个请求。例如,客户端请 求服务器的AServlet,而AServlet处理不了当前的请求,就转发或包含给BServlet, 由BServlet处理或共同处理该请求。具体如图1-1所示: 图1-1 请求转发和请求包含原理图 由图1-1可知,请求转发和请求包含都是一次请求中,那么服务器只会创建一个 request对象和一个response对象,因此AServlet的request和response与BServlet 中的request和response是同一个request和response。我们知道request对象是 一个域对象,既然AServlet和BServlet的request对象是同一个,那么就可以在 AServlet中向request域中存放数据,然后在BServlet中从request域中获取。这 就是request域的域范围,在一个请求链中。 1.请求转发 请求转发是Servlet将请求转发给别的Servlet或服务器其他资源,无需客户端任 何行为。可以通过以下方式实现请求转发: request.getRequestDispatcher(“转发资源路径”).forward(request,response) ?getRequestDispatcher(String path):该方法的返回值类型是RequestDispatcher,可以理解它是一个调度器,该方法的参数是指明要转发或包含的资源路径; ?forward(ServletRequestreq,ServletResponse res):该方法是RequestDispatcher接口的方法,将请求从一个 servlet 转发到服务器上的另一个资源(servlet、JSP 文件或 HTML 文件)。此方法允许一个 servlet 对请求进行初步处理,并使另一个资源生成响应。需要传递两个参数,这两个参数是当前Servlet的request对象和response对象传递过去的。 通过下图形象理解请求转发,如图1-2所示: 图1-2 请求转发 图1-2满足java_ee_api文档对forward()方法的定义,客户端请求AServlet,而 最终是由BServlet做出响应。 2.请求包含 请求包含是指多个Servlet共同处理一个请求。以下方式可以实现请求包含: request.getRequestDispatcher(“包含资源路径”).include(request,response) ?include(ServletRequestrequest,ServletResponse response):该方法是RequestDispatcher接口的方法,表示包含。它的参数同forward()方法的参数一样都是由当前Servlet传递过去的。 通过下图来形象理解请求包含,如图1-3所示: 图1-3 请求包含 3.请求转发和请求包含的比较 (1)相同点 请求转发和请求包含都是在一个请求范围内,多个Servlet之间使用的同一个 request对象和response对象。 (2)不同点 ?如果在AServlet中请求转发到BServlet,那么在AServlet中不允许再输出响应体,即不能使用response.getWriter()和response.getOutputStream()向客户端输出,这一工作交由BServlet来完成;如果是由AServlet请求包含BServlet,则没有这个限制。 ?请求转发不能设置响应体,但是可以设置响应头,简单来说就是“留头不留体”,例如: response.setContentType("text/html;charset=utf-8”); 而请求包含不仅可以设置响应头,还可以设置响应体,简单来说就是“留头又留体“; ?请求包含大多应用在jsp页面中,完成多页面的合并; ?请求转发大多应用在Servlet中,转发目标大多是jsp页面。 集中式网络管理和分布式网络管理的区别及优缺点 集中式网络管理模式是在网络系统中设置专门的网络管理节点。管理软件和管理功能主要集中在网络管理节点上,网络管理节点与被管理节点是主从关系。 优点:便于集中管理 缺点: (1)管理信息集中汇总到管理节点上,信息流拥挤 (2)管理节点发生故障会影响全网的工作 分布式网络管理模式是将地理上分布的网络管理客户机与一组网络管理服务器交互作用,共同完成网络管理的功能。 优点: (1)可以实现分部门管理:即限制每个哭户籍只能访问和管理本部门的部分网络资源,而由一个中心管理站实施全局管理。 (2)中心管理站还能对客户机发送指令,实现更高级的管理 (3)灵活性和可伸缩性 缺点: 不利于集中管理 所以说采取集中式与分布式相结合的管理模式是网络管理的基本方向 snmp安装信息刺探以及安全策略 一、SNMP的概念,功能 SNMP(Simple Network Management Protocol)是被广泛接受并投入使用的工业标准,它的目标是保证管理信息在任意两点中传送,便于网络管理员在网络上的任何节点检索信息,进行修改,寻找故障;完成故障诊断,容量规划和报告生成。它采用轮询机制,提供最基本的功能集。最适合小型、快速、低价格的环境使用。它只要求无证实的传输层协议UDP,受到许多产品的广泛支持。 本文将讨论如何在Win2K安装使支持SNMP功能,SNMP技术对于提升整体安全水准是有益的,但也可能存在风险,本文将同时检验这两个方面。另外,除了介绍一些开发工具外,还将图解通过SNMP收集信息的可能用法,以及如何提高安全性。 二、在Win2K中安装SNMP 提供一个支持SNMP的Win2K设备与增加一个额外的Windows组件同样简单,只需要进入"开始/设置/控制面板/", 选择"添加/删除程序",然后选择"添加/删除Windows组件",随之出现一个对话框,在其中选择"管理和监视工具", 最后点击"下一步",依照提示安装: OK,现在Win2K就可以通过SNMP来访问了. 三、对snmp信息的刺探方法 1、Snmputil get 下面我们在命令行状态下使用Win2K资源工具箱中的程序 来获取安装了SNMP的Win2K机器的网络接口数目,命令参数是get: 前提是对方snmp口令是public 提供基本的、低级的SNMP功能,通过使用不同的参数和变量,可以显示设备情况以及管理设备。 ****************************************************************** ******************************************************************* Windows操作系统中的IIS负责提供互联网服务,一台运行了IIS的计算机可以看成是一台Web服务器。 Windows XP SP2 中IIS主版本号为5,Windows 2003 Server为6,Vista和Windows Server 2008为7。对于Windows 2003 Server,其默认支持的https://www.360docs.net/doc/8a10192872.html,版本为1.1,因此必须单独安装.NET Framework 2.0以上版本[1]。 目前,IIS 6是使用最为广泛的版本,IIS 5已基本不在Web服务器上部署, IIS 6与IIS 5相比在系统架构上有着较大的差异,IIS 7与IIS 6相比,基本架构并没有根本性的变化,但在许多方面有新的增强和改进。本书选择IIS 6/7进行介绍,大部分内容也适合于IIS 5,但IIS 5一些已过时的特性就不介绍了。 首先,我们来仔细分辨一下三个很容易混淆的基本概念。 8.1.1网站、Web应用程序和虚拟目录 在IIS中可以创建网站、Web 应用程序和虚拟目录,以便与计算机网络上的用户共享信息。“网站”、“Web 应用程序”和“虚拟目录”这三个概念的关系如图 8?1所示。 图 8?1 网站,应用程序与虚拟目录 简而言之,一个“网站(Web Site)”包含一个或多个“ Web 应用程序(Web Application)”,一个Web 应用程序包含一个或多个“虚拟目录(Virtual Directory)”,而虚拟目录则映射到 Web 服务器或远程计算机上的物理目录。 图 8?2所示为运行IIS 7的一个Web服务器。 图 8?2 IIS 7中的网站,应用程序与虚拟目录 图 8?2中可以清楚地看到此Web服务器上有两个“网站”:Default Web Site和NewWebSite,其中Default Web Site网站中有三个“Web 应用程序”:HappyBookShopService、HappyBookShopWebSite和OnlineAlbum。而HappyBookShopWebSite应用程序下的每一个子文件夹都是一个“虚拟目录”。最顶层的虚拟目录称为“根虚拟目录”,图8?2中Web应用程序HappyBookShopWebSite的根虚拟目录为“/HappyBookShopWebSite”。 servlet请求转发的三种方式 servlet中的请求转发主要有三种方式: 1、 forward:是指转发,将当前request和response对象保存,交给指定的url 处理。并没有表示页面的跳转,所以地址栏的地址不会发生改变。 2、 redirect:是指重定向,包含两次浏览器请求,浏览器根据url请求一个新的页面,所有的业务处理都转到下一个页面,地址栏的地址会变发生改变。 3、 include:意为包含,即包含url中的内容,进一步理解为,将url中的内容包含进当前的servlet当中来,并用当前servlet的request和respose来执行url中的内容处理业务.所以不会发生页面的跳转,地址栏地址不会发生改变。 测试如下: 首先编写三个html界面:分别是登录界面:login.html;登录成功界面:success.html;登录失败界面:fail.html. 之后,处理登录逻辑的servlet类如下: Java代码 运行后如果输入正确的用户名密码,则执行include方法,界面显示:include 包含。登录成功!并且地址栏地址未改变,若是输入错误登录名或者密码,界面显示:登录失败!并且地址栏地址改变。其中要注意的是sendRedirect方法中在要跳转的页面url前必须加上当前web程序路径名,这个路径通过request.getContextPath()可以得到。 如果吧其中include方法改为forward方法: Java代码 登录时输入正确信息,则跳转的页面地址不变,显示:登录成功!不包含url中的内容。 总结如下: redirect与include、forward的区别在于是不是同一个Request,redirect会有两次交互。 include与forward的区别在于输出的内容,include包含本身servlet与跳转页面内容的结果,而forward不包含本身servlet的内容。 HTTP协议报文格式 HTTP协议(Hypertext Transfer Protocol――超文本传输协议)浏览器端(客户端)向WEB 服务器端访问页面的过程和HTTP协议报文的格式。 基于HTTP协议的客户机访问包括4个过程,分别是建立TCP套接字连接、发送HTTP请求报文、接收HTTP应答报文和关闭TCP套接字连接: 1. 创建TCP套接字连接 客户端与WEB服务器创建TCP套接字连接,其中WEB端服务器的地址可以通过域名解析确定,WEB端的套接字侦听端口一般是80。 2. 发送HTTP请求报文 客户端向WEB服务端发送请求报文,HTTP协议的请求报文格式为: 请求消息= 请求行(实体头信息)CRLF[实体内容] 请求行= 方法URL HTTP版本号CRLF 方法= GET|HEAD|POST|扩展方法 URL = 协议名称+宿主名+目录与文件名 其中"CRLF"表示回车换行。 "请求行"中的"方法"描述了对指定资源执行的动作,常用的方法"GET"、"HEAD"和"POST"等3种,它们的含义如表15-8所示: 请求报文 一个HTTP请求报文由请求行(request line)、请求头部(header)、空行和请求数据4个部分组成,下图给出了请求报文的一般格式。 (1)请求行 请求行由请求方法字段、URL字段和HTTP协议版本字段3个字段组成,它们用空格分隔。例如,GET /index.html HTTP/1.1。 HTTP协议的请求方法有GET、POST、HEAD、PUT、DELETE、OPTIONS、TRACE、CONNECT。这里介绍最常用的GET方法和POST方法。 GET:当客户端要从服务器中读取文档时,使用GET方法。GET方法要求服务器将URL定位的资源放在响应报文的数据部分,回送给客户端。使用GET方法时,请求参数和对应的值附加在URL后面,利用一个问号(“?”)代表URL的结尾 与请求参数的开始,传递参数长度受限制。例如,/index.jsp?id=100&op=bind。POST:当客户端给服务器提供信息较多时可以使用POST方法。POST方法将请求参数封装在HTTP请求数据中,以名称/值的形式出现,可以传输大量数据。 表15-8 HTTP请求方法 HTTP头字段包括4类: general-header ; request-header ; response-header ; entity-header . ********************************************************************* ********** General Header Fields ============================= general header是request、response都可用的, 但是不能用于entity. --Cache-Control --Connection --Date --Pragma --Trailer --Transfer-Encoding --Upgrade --Via --Warning ********************************************************************* ********** Request Header Fields ====================== request-header fields 允许客户端传递关于request和客户端的附加信息到服务端, --Accept --Accept-Charset --Accept-Encoding --Accept-Language --Authorization --Expect --From --Host --If-Match --If-Modified-Since --If-None-Match --If-Range --If-Unmodified-Since 管道命令操作符是:”|”,它仅能处理经由前面一个指令传出的正确输出信息,也就是standard output 的信息,对于stdandard error 信息没有直接处理能力。然后,传递给下一个命令,作为标准的输入standard input. 先看下下面图: command1正确输出,作为command2的输入然后comand2的输出作为,comand3的输入,comand3输出就会直接显示在屏幕上面了。 通过管道之后:comand1,comand2的正确输出不显示在屏幕上面 注意: 1、管道命令只处理前一个命令正确输出,不处理错误输出 2、管道命令右边命令,必须能够接收标准输入流命令才行。 实例: [chengmo@centos5 shell]$ cat test.sh | grep -n 'echo' 5: echo "very good!"; 7: echo "good!"; 9: echo "pass!"; 11: echo "no pass!"; #读出test.sh文件内容,通过管道转发给grep 作为输入内容 [chengmo@centos5 shell]$ cat test.sh test1.sh | grep -n 'echo' cat: test1.sh: 没有那个文件或目录 5: echo "very good!"; 7: echo "good!"; 9: echo "pass!"; 11: echo "no pass!"; #cat test1.sh不存在,错误输出打印到屏幕,正确输出通过管道发送给grep [chengmo@centos5 shell]$ cat test.sh test1.sh 2>/dev/null | grep -n 'echo' 5: echo "very good!"; 7: echo "good!"; 9: echo "pass!"; 11: echo "no pass!"; #将test1.sh 没有找到错误输出重定向输出给/dev/null 文件,正确输出通过管道发送给grep [chengmo@centos5 shell]$ cat test.sh | ls catfile httprequest.txt secure test testfdread.sh testpipe.sh testsh.sh testwhile2.sh envcron.txt python sh testcase.sh testfor2.sh testselect.sh test.txt text.txt env.txt release sms testcronenv.sh testfor.sh test.sh testwhile1.sh #读取test.sh内容,通过管道发送给ls命令,由于ls 不支持标准输入,因此数据被丢弃 这里实例就是对上面2点注意的验证。作用接收标准输入的命令才可以用作管道右边。否则传递过程中数据会抛弃。常用来作为接收数据管道命令有:sed,awk,cut,head,top,less,more,wc,join,sort,split 等等,都是些文本处理命令。 管道命令与重定向区别 区别是: 1、左边的命令应该有标准输出| 右边的命令应该接受标准输入 左边的命令应该有标准输出> 右边只能是文件 左边的命令应该需要标准输入< 右边只能是文件 转发与重定向的区别 我们知道,请求转发和请求包含都是在一个请求内,涉及到多个Servlet 。既然转发和包含都在一个请求内,那么说明多个Servlet 共用同一个request 对象和response 对象。这个时候就存在request 域。 1. request 域 Servlet 的三大域对象:request ,session ,application 。其中request 域是三大域对象中范围最小的域对象,application 对象其实就是ServletContext 对象,在ServletContext 功能详解中我们对它的域功能做了详细的介绍;session 域会在后面学习。 request 域只会在请求转发和请求包含时存在。它的域范围就是整个请求链,如图1-1所示。例如:由AServlet 请求转发到BServlet ,这时在AServlet 中向request 域中存放数据,然后在BServlet 中从request 域中获取数据。如果BServlet 又转发给其他的Servlet ,那么在其他Servlet 中也可以从request 域中获取数据。转发过程中经过的这些Servlet 都在一个请求链中。 客户端AServlet BServlet CServlet 请求AServlet 转发转发 响应 请求链 图1-1 请求转发 2. request 域相关方法介绍 以后只要是域对象,那么它必然会有以下三个方法: ● void setAttribute(String name,Object value) 该方法是向域中保存域属性,例如:setAttribute(“username ”,”zhangsan ”),其中,username 是域属性的名称,zhangsan 是域属性的值。如果多次调用该方法,且属性名称相同,那么后保存的数据会覆盖先保存的数据。 ● Object getAttribute(String name) 该方法是根据属性名称从域中获取域属性的值,如果之前没有调用setAttribute()方法保存数据,那么调用getAttribute()方法返回值是null 。 ● void removeAttribute(String name) 该方法是从域中移出指定名称的域属性,如果该名字的域属性不存在,则该方法什么都不 第8章Servlet技术 一、选择题: (1)下列关于Servlet的功能描述正确的是。 A)Servlet可以创建并返回一个包含基于客户请求性质的动态内容的完整的HTML页面B)Servlet可以创建可嵌入到现有HTML页面中的一部分HTML页面 C)Servlet可以与其它服务器资源(包括数据库和基于Java的应用程序)进行通信 D)Servlet可以用多个客户端处理连接,接收多个客户端的输入,并将结果广播到多个客户端上。 E)Servlet对特殊的处理采用MIME类型过滤数据,例如图像转换或者Word文档转换ABCDE (2)下列关于Servlet技术的特点说法正确的是。 A)可移植性好 B)功能强大 C)安全,简洁,和服务器紧密集成 D)高效耐用 E)Java语言能实现的功能,Servlet基本都能实现 ABDE (3)Servlet的生命周期包括下列哪几个阶段。 A)装载Servlet B)创建一个Servlet实例 C)调用init()方法 D)激活Service()方法,并传递请求和响应对象 E)调用destroy()方法来销毁Servlet BCDE (4)下列对HttpServlet类描述错误的是。 A)HttpServlet类是针对使用Http协议的Web服务器的Servlet类 B)HttpServlet类通过执行Servlet借口,能够提供Http协议的功能 C)HttpServlet的子类实现了doGet()方法去响应HTTP的Get请求 D)HttpServlet的子类实现了doPost()方法去响应HTTP的Post请求 E)HttpServlet类通过init()方法和destory()方法管理Servlet自身的资源 E (5)下列对于web.xml的配置说法错误的是。 A)在web.xml描述中,首先要声明Servlet B)在web.xml描述中,要指定这个Servlet的名字 C)在web.xml描述中,要指定这个Servlet的类 D)在web.xml描述中,要为Servlet做URI映射 E)在web.xml中不可同时指定多个Servlet E servlet的两种重定向方法的区别及应用 一问题:在servlet/JSP编程学习中,发现有两种方法可以实现服务端输出重定向,一种是通过forward方法(例如JSP中的 HTTP是一个属于应用层的面向对象的协议,由于其简捷、快速的方式,适用于分布式超媒体信息系统。它于1990年提出,经过几年的使用与发展,得到不断地完善和扩展。目前在WWW中使用的是HTTP/1.0的第六版,HTTP/1.1的规范化工作正在进行之中,而且HTTP-NG(Next Generation of HTTP)的建议已经提出。 HTTP协议的主要特点可概括如下: 1.支持客户/服务器模式。 2.简单快速: 客户向服务器请求服务时,只需传送请求方法和路径。请求方法常用的有GET、H EAD、POST。每种方法规定了客户与服务器联系的类型不同。由于HTTP协议简单,使得HTTP服务器的程序规模小,因而通信速度很快。 3.灵活: HTTP允许传输任意类型的数据对象。正在传输的类型由Content-Type加以标记。 4.无连接: 无连接的含义是限制每次连接只处理一个请求。服务器处理完客户的请求,并收到客户的应答后,即断开连接。采用这种方式可以节省传输时间。 5.无状态: HTTP协议是无状态协议。无状态是指协议对于事务处理没有记忆能力。缺少状态意味着如果后续处理需要前面的信息,则它必须重传,这样可能导致每次连接传送的数据量增大。另一方面,在服务器不需要先前信息时它的应答就较快。 一、HTTP协议(URL) http(超文本传输协议)是一个基于请求与响应模式的、无状态的、应用层的协议,常基于TCP的连接方式,HTTP1.1版本中给出一种持续连接的机制,绝大多数的Web开发,都是构建在HTTP协议之上的Web应用。 HTTP URL (URL是一种特殊类型的URI,包含了用于查找某个资源的足够的信息)的格式如下: http: //host[": "port][abs_path] 二、HTTP协议的请求 http请求由三部分组成,分别是: 请求行、消息报头、请求正文 1、请求行以一个方法符号开头,以空格分开,后面跟着请求的URI和协议的版本,格式如下: Method Request-URI HTTP-Version CRLF 其中Method表示请求方法;Request-URI是一个统一资源标识符;HTTP-Version表示请求的HTTP协议版本;CRLF表示回车和换行(除了作为结尾的CRLF外,不允许出现单独的CR或LF字符)。 请求方法(所有方法全为大写)有多种,各个方法的解释如下: GET 请求获取Request-URI所标识的资源 POST 在Request-URI所标识的资源后附加新的数据 HEAD 请求获取由Request-URI所标识的资源的响应消息报头 PUT 请求服务器存储一个资源,并用Request-URI作为其标识 填空题 . Java作为默认的脚本语言1.JSP把2.HTTP的中文含义是超文本传输协议,它 的作用是用于传输超文本标记语言编写的文件。 3.网站一般分为三层,分别是用户界面交互层,应用程序层,数据库层。 4.Servlet的生命周期可以分为4个阶段:载入,初始化,执行,删除(销毁。 5.在JSP文件中使用〈!————〉对HTML文本进行注释,使用〈%————%〉符号对JSP语句进行注释。 6.JSP页面在使用Jag标记来调用一个标签文件之前,必须使用Taglib指令标记引入该Web服务目录下的标记库。 7.在JSP中当执行了查询结果保存在Resultset对象中。 8.在JSP中,连接数据库的方式通常有两种:一种是通过JDBC驱动程序连接;另一种是通过JDBC-ODBC桥连接。 9.HTML是超文本标记语言,作用是WWW页面内容的格式进行说明。在HTML中加入CSS的方法主要有嵌入式样式表,内联式样式表,外联式样式表。 10.Request对象的作用是表示客户端对网页的请求,并使用HTTP协议处理客户端的请求,一个常用的方法是getParameter();其作用为设置作为响应生成内容的类型和字符编码。 11.Reponse对象的作用是处理jsp生成的响应发送给客户端: setContentType(),其作用为设置作为响应生成内部的类型和字符编码。 12.JSP中的五个常见内建对象是out: application: request:reponse:session 13.Servlet中的4个常用方法分别是init():doGet():doPost():destor() 14.在JSP页面中显示用户信息的两种方法是out.println()和〈%= %〉 15.Servlet中实现页面跳转的两种方法是response.sendRedirect()和request.getRequestDispatcher().forward() 16.JSP开发网站的两种模式分为Jsp+javabean和jsp+javabean+servlet 17.一个JSP页面可由5种元素组合而成,分别是普通的HTML.标记,JSP标记,JAVA程序片,JAVA表达式和变量和方法的声明。 application,request,sussion. 和page,request分别scope,个4有JavaBean18. 19.内置对象session的setAttribute()方法可将数据存入session, getAttribute()方法可从session中将数据取出。 20.MVC将应用程序分为3个核心模块,分别是模型,视图和控制器。 21.异常的处理,可在该方法的代码段中包含3类代码:try.catch和finally 22.Servlet的生命周期由三个方法控制,这三个方法分别为:init();service();和destroy(). 23.使用Statement对象的executeQuery()方法执行查询语句,使用executeUpdate()方法执行更新语句,使用execute()方法执行动态的未知操作。 24.JSP中使用reponse的sendRedirect()方法实现页面的跳转。 25.JSP的英文全称是Java Servet Page. 26.将JSP与JavaBean配合使用是通过JSP中的三个动作指令实现 的:jsp:useBean: jsp:getProperty:jsp:setProperty. HTTP是Web协议集中的重要协议,它是从客户机/服务器模型发展起来的。客户机/服务器是运行一对 相互通信的程序,客户与服务器连接时,首先,向服务器提出请求,服务器根据客户的请求,完成处理 并给出响应。浏览器就是与Web服务器产生连接的客户端程序,它的端口为TCP的80端口,。浏览器 与Web 服务器之间所遵循的协议就是HTTP。 HTTP的早期版本为HTTP/0.9,它适用于各种数据信息的简洁快速协议,但是其远不能满足日益发展各 种应用的需要。但HTTP/0.9作为HTTP协议具有典型的无状态性:每个事务都是独立进行处理的,当 一个事务开始就在客户与服务器之间建立一个连接,当事务结束时就释放这个连接。HTTP/0.9包含Simple-Request&Simple-Responsed的报文结构。但是客户无法使用内容协商,所以服务器也无法 返回实体的媒体类型。 1982年,Tim Berners-Lee提出了HTTP/1.0,在此后的不断丰富和发展中,HTTP/1.0成为最重要 的面向事务的应用层协议。该协议对每一次请求/响应,建立并拆除一次连接。其特点是简单、易于管理,所以它符合了大家的需要,得到了广泛的应用。其缺点是仍会发生下列问题:对用户请求响应慢、网络拥 塞严重、安全性等。 1997年形成的HTTP/1.1,也就是现在普遍使用的协议,在持续连接操作机制中实现流水方式,即客户 端需要对同一服务器发出多个请求时,其实现在多数的网页都是有多部分组成(比如多张图片),可用 流水线方式加快速度,流水机制就是指连续发出多个请求并等到这些请求发送完毕,再等待响应。这样 就大大节省了单独请求对响应的等待时间,使我们得到更快速的浏览。 另外,HTTP/1.1服务器端处理请求时按照收到的顺序进行,这就保证了传输的正确性。当然,服务器端 在发生连接中断时,会自动的重传请求,保证数据的完整性。 HTTP/1.1还提供了身份认证、状态管理和Cache缓存等机制。这里,我想特别提一下关于HTTP/1.1 中的Cache缓存机制对 HTTP/1.0的不足之处的改进,它严格全面,既可以减少时间延迟、又节省了带宽。HTTP/1.1采用了内容协商机制,选择最合适的用户的内容表现形式。 现在,很多地方都有用到的虚拟主机技术在HTTP/1.1中也可以实现。所谓的虚拟主机技术,就是同一 主机地址实际对应多台主机。通俗的讲,当你同时在一个网站申请两个主页时,用协议分析仪可以发现 其实这两个主页对应的是同一个IP地址。这样用多台完全相同的机器形成WWW服务器就可以提高处 理的吞吐量。 传统的解决方案是改造域名服务器使其可以根据一定的算法将同一域名解释成不同的IP地址。分别对应 虚拟主机的每台机器,其缺点是要求每台机器占用完全独立的IP地址,这与IP地址的缺乏是相矛盾的。HTTP/1.1提供的解决方案在HTTP协议自身中加入了指定不同主机的功能,从而多台主机可以共享一个IP地址,既提高了性能又便于管理。 因为HTTP/1.1是Internet现行的标准协议,这里详细介绍其相关语法。 首先,HTTP/1.1格式可写为: 其中请求方法是请求一定的Web页面的程序或用于特定的URL。可选用下列几种: GET:请求指定的页面信息,并返回实体主体。 HEAD:只请求页面的首部。 POST:请求服务器接受所指定的文档作为对所标识的URI的新的从属实体。 PUT:从客户端向服务器传送的数据取代指定的文档的内容。 . ;. A. HttpServletRequest、getSession B. HttpServletResponse、newSession C. HtttpSession、newInstance D. HttpSession、getSession 7、给定一个Servlet 的doGet方法中的代码片段,如下: request.setAttribute(“name”,”zhang”); response.sendRedirect(“http://localhost:8080/servlet/MyServlt”); 那么在Servlet 中可以使用()方法把属性name的值取出来。 A. String str=request.getAttribute(“name”); B. String str=(String)request.getAttribute(“name”); C. Object str=request.getAttribute(“name”); D. 无法取出来 8、下边哪个不是JSP的内置对象?() A. session B. request C. cookie D. out 9、关于get和post两种请求,下列说法正确的是?() A. Form表单默认请求是get请求。 B. get请求处理的数据量大小不受到限制。 C. post请求地址栏里是能看到数据的,所以传送用户信息尽量避免使用。 D. post请求可以由doGet方法处理。 10、下面哪一个是正确使用JavaBean的方式?() A. 1.格式 这是一个链接 这是一个段落 集中式网络管理和分布式网络管理的区别及优缺点
IIS架构与HTTP请求处理流程
servlet请求转发的三种方式
http协议请求响应报文格式及状态码详解
HTTP请求报头详解
管道与重定向
转发与重定向的区别
JAVA试题_4
servlet的两种重定向方法的区别及应用
HTTP协议分析
web技术应用基础应用 复习
HTTP请求方法及响应码详解(http get post head)
太原理工大学_WEB系统与技术试卷
转发和重定向
换行
在网页中加一条横线 :这是定义了一个???.css格式文件 =============================================== 1、转发和重定向的区别: 1)地址: 转发的地址必须是同一个应用内部的各个组建。 重定向的地址没有限制。 2)能否共享request 转发可以 重定向不行 3)浏览器地址栏的地址是否变化 转发不变 重定向不会 4)事件是否处理完毕 转发是一件事未做完。 重定向是一件事已经做完。 2、状态管理: 2)怎样进行状态管理: 第一种方式:在客户端管理用户的状态 (cookie) 第二种方式:在服务器端管理用户的状态 (session) 3)cookie: a,什么是cookie? 浏览器在访问服务器时,服务器将一些数据以set—cookie消息头的形式发送给浏览器,浏览器会将这些数据(内存或者硬盘)保存起来,当浏览器再次访问服务器时,会将保存的数据会以cookie的消息头的形式发送给浏览器。通过这种方式可以管理用户的状态。 b,怎样去创建cookie? Cookie cookie=new Cookie(String name, String value);cookie中保存键值对 response.addCookie(cookie);服务器从cookie中读取数据 c,查询cookie //如果没有cookie,则返回null Cookie[] cookies=request.getCookies(); String name=cookie.getName();
java Servlet请求转发和重定向
?请求转发 ?请求转发是指将请求再转发到另一资源(一般为JSP或Servlet)。此过程依然在同一个请求范围内,转发后浏览器地址栏内容不变 ?请求转发使用RequestDispatcher接口中的forward()方法来实现,该方法可以把请求转发到另外一个资源,并让该资源对浏览器的请求进行响应 RequestDispatcher rd = request.getRequestDispatcher(path); rd.forward(request,response); 或 request.getRequestDispatcher(path) .forward(request,response); ?重定向 ?重定向是指页面重新定位到某个新地址,之前的请求失效,进入一个新的请求,且跳转后浏览器地址栏内容将变为新的指定地址 ?重定向是通过HttpServletResponse对象的sendRedirect()来实现,该方法相当于浏览器重新发送一个请求 response.sendRedirect(path); ?请求转发和重定向区别如下: ?forward()只能将请求转发给同一个Web应用中的组件,而sendRedirect()方法不仅可以重定向到当前应用程序中的其他资源,还可以重定向到其他站点的资源。
?sendRedirect()方法重定向的访问过程结束后,浏览器地址栏中显示的URL会发生改变,由初始的URL地址变成重定向的目标URL;而调用forward()方法的请 求转发过程结束后,浏览器地址栏保持初始的URL地址不变。 ?forward()方法的调用者与被调用者之间共享相同的request对象和response对象;而sendRedirect()方法调用者和被调用者使用各自的request对象和response 对象,它们属于两个独立的请求和响应过程。 ?使用请求对象(request)存储数据(在servlet中存,在JSP中取)request. setAttribute(“score”,score); int score=(INTEGER)request. getAttribute(“score”); ?HttpServletRequest接口的方法: public void setAttribute(String name, Object obj) public Object getAttribute(String name) public Enumeration getAttributeNames() public void removeAttribute(String name) ?使用HttpSession对象存储数据 HttpSession session=request.getSession(); session. setAttribute(“score”,score); int score=(Integer) session. getAttribute(“score”); ?HttpSession接口的方法 public void setAttribute(String name, Object obj) public Object getAttribute(String name) public Enumeration getAttributeNames()
运行时创建HTTP请求及请求的处理
1、发起请求 下面这个方法的作用就是接收要发送的数据及数据要发送到的URL,然后返回响应数据 protected string SendRequest(string data,string url) { WebRequest req = WebRequest.Create(url); req.Method = "POST"; req.ContentType = "application/x-www-form-urlencoded"; byte[] sendBytes = Encoding.UTF8.GetBytes(data); req.ContentLength = sendBytes.Length; Stream reqStream = req.GetRequestStream(); reqStream.Write(sendBytes, 0, sendBytes.Length); reqStream.Close(); WebResponse res = req.GetResponse(); Stream resStream = res.GetResponseStream(); StreamReader sr = new StreamReader(resStream, Encoding.UTF8); string resData = sr.ReadToEnd(); sr.Close(); resStream.Close(); return resData; } 使用示例: protected void btnSubscribe_Click(object sender, EventArgs e) { string FileName = Server.MapPath("订购.xml");
服务器重定向方法
以前也没怎么关注301重定向,第一因为没有网站要重定向,第二对于不带www的域名我都是用的转发到带www的域名。不过一场风波之后,很多服务商已经不提供转发服务了,虽说易名现在还可以享用到免费的转发服务,但是却不能不带www的转发到带www的同时进行MX记录解析,这对于需要MX解析的朋友也是一大烦恼。 而且有些域名在国外,转发更是用不了,也只能进行301永久重定向了,不然搜索引擎是把不带www 的站和带www的站分开对待的,只是我们习惯于用带www的域名罢了。 在网络上看了些教程,再根据自己的实践,也终于搞定了IIS服务器上的301永久重定向设置问题。实现方法如下: 1.新建一个站点,对应目录如E:\wwwroot\301web。该目录下只需要1个文件,即index.html或者加个404.htm。绑定要跳转的域名,如图: 2.在IIS中选中刚才我们建立的站点,右键,属性,主目录,选择重定向到,输入网址如: https://www.360docs.net/doc/8a10192872.html,,同时注意选中下面的资源的永久重定向选项。如下图:
3.到此,我们已经完成了将https://www.360docs.net/doc/8a10192872.html,这个域名301重定向到https://www.360docs.net/doc/8a10192872.html,的工作。 注意问题: “上面输入准确的URL(X)”这个选项建议不要选。 不选的结果是: 当输入https://www.360docs.net/doc/8a10192872.html,转到了https://www.360docs.net/doc/8a10192872.html,, 当输入https://www.360docs.net/doc/8a10192872.html,/sanwen/suibi/时,转到了https://www.360docs.net/doc/8a10192872.html,/sanwen/suibi/。 选上的结果是: 当你输入https://www.360docs.net/doc/8a10192872.html,或者https://www.360docs.net/doc/8a10192872.html,/sanwen/suibi/都会转到https://www.360docs.net/doc/8a10192872.html,。 好了,如果只是想把不带www的转到带www的或者其他没有用过的域名转到正在使用的域名,这样就可以了。但是如果你要的域名已经做过网站,想要把权重传递给新网站,可以参考下面这个方法: 第一步同上,主要是第二步,如图: