服务器不同application之间的相互访问

ServletContext提供了一个方法getContext(uri)

如果有两个application,它们部署在同一个server下,那么它们之间可以通过这种方式进行相互通信。

ServletContext aContext = ....

ServletContext anotherContext = aContext.getContext("the uri")

但是tomcat默认不允许跨应用的访问,可以在context.xml中配置一下。

找到Context节点,添加属性 crossContext="true"

 

ServletContext有一个方法getRequestDispatcher

HttpServletRequest也有一个方法getRequestDispatcher

前者是必须以"/"开头,相对于当前ServletContext的根目录(http:localhost:8080/springmvc)。

后者不必以"/"开头,如果以"/"开头那么就是项目于当前ServletContext的根目录(http:localhost:8080/springmvc)。

如果不以"/"开头,那么就是相对于当前请求的路径。

 

下面是RequestDispatcher include方法的使用:

原文地址:http://hi.baidu.com/jlhaoran/item/b89bff0e5fcd0c2fa0312d1c

一:RequestDispatcher.include方法可以将RequestDispatcher封装的资源信息当作当前响应的一部分包含进来从而实现可编程的服务器端包含功能。

二:被包含的Servlet程序不能改变响应信息的状态码和响应头 如果它里面存在这些语句,这些语句的执行结果将被忽略。

下面是一个例子。有三个servlet 其中一个包含另外两个的内容。

//head.java

package cn.nyist.servlet;

public class ServletDemo9 extends HttpServlet {


public void doGet(HttpServletRequest request, HttpServletResponse response)
    throws ServletException, IOException {
          String data="head 你好";
         
          response.getWriter().write(data);
  
}


public void doPost(HttpServletRequest request, HttpServletResponse response)
    throws ServletException, IOException {

    doGet(request,response);
}

}
//foot.java

package cn.nyist.servlet;

public class ServletDemo10 extends HttpServlet {

public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
   String data="foot 你好";
       
         response.getWriter().write(data);

}


public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {

doGet(request,response);
}

}

//ServletDemo12包含了前面两个servlet的内容

package cn.nyist.servlet;

public class ServletDemo12 extends HttpServlet {

public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setContentType("text/html;charset=UTF-8");
    response.setCharacterEncoding("UTF-8");
     request.getRequestDispatcher("/servlet/ServletDemo9").include(request, response);
     response.getWriter().write("</br>");
     response.getWriter().write("hello");
     response.getWriter().write("</br>");
     request.getRequestDispatcher("/servlet/ServletDemo10").include(request, response);

}


public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {

doGet(request,response);
}


}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Cookie对象、Session对象和Application对象都是在Web开发中常用的对象,它们分别用于在客户端和服务器端存储和管理数据。 Cookie对象是存储在客户端的一小段文本信息,用于记录用户的一些状态和行为。Cookie对象的主要作用是在用户访问同一网站时,可以将存储在cookie中的信息传递给服务器,实现用户状态的保持。Cookie对象的生命周期可以通过设置过期时间来控制。 Session对象和Cookie对象的作用类似,也用于在客户端和服务器之间传递数据,但它是存储在服务器端的。Session对象的主要作用是在用户登录后,将用户的一些信息存储在服务器端,以便在用户访问其他页面时,能够方便地获取到这些信息。Session对象的生命周期可以通过设置超时时间来控制。 Application对象是在服务器端全局唯一的一个对象,用于存储和管理应用程序级别的数据。它的主要作用是在应用程序启动时,将需要共享的数据存储在Application对象中,以便在整个应用程序中都能够访问使用这些数据。Application对象的生命周期与应用程序的生命周期相同。 总的来说,Cookie对象和Session对象都是用于在客户端和服务器之间传递数据的,而Application对象是用于在服务器端全局共享数据的。它们之间的联系是都可以用于存储和管理数据,而区别在于存储的位置不同,以及生命周期的控制方式不同。同时,Session对象和Application对象可以相互交互使用,在Session对象中存储的数据可以被Application对象访问

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值