Cookie多应用共享使用

转自:http://blog.sina.com.cn/s/blog_8f61bd170100xe4d.html


正常的cookie只能在一个应用中共享,即一个cookie只能由创建它的应用获得。
1.可在同一应用服务器内共享方法:设置cookie.setPath("/");
 

    本机tomcat/webapp下面有两个应用:cas和webapp_b,
      1)原来在cas下面设置的cookie,在webapp_b下面获取不到,path默认是产生cookie的应用的路径。
      2)若在cas下面设置cookie的时候,增加一条cookie.setPath("/");或者cookie.setPath("/webapp_b/");就可以在webapp_b下面获取到cas设置的cookie了。
      3)此处的参数,是相对于应用服务器存放应用的文件夹的根目录而言的(比如tomcat下面的webapp),因此cookie.setPath("/");之后,可以在webapp文件夹下的所有应用共享cookie,而cookie.setPath("/webapp_b/");是指cas应用设置的cookie只能在webapp_b应用下的获得,即便是产生这个cookie的cas应用也不可以。
      4)设置cookie.setPath("/webapp_b/jsp")或者cookie.setPath("/webapp_b/jsp/")的时候,只有在webapp_b/jsp下面可以获得cookie,在webapp_b下面但是在jsp文件夹外的都不能获得cookie。
      5)设置cookie.setPath("/webapp_b");,是指在webapp_b下面才可以使用cookie,这样就不可以在产生cookie的应用cas下面获取cookie了
      6)有多条cookie.setPath("XXX");语句的时候,起作用的以最后一条为准。
      6)设置多个path的方法???

2.跨域共享cookie的方法:设置cookie.setDomain(".jszx.com");
      A机所在的域:home.langchao.com,A有应用cas
      B机所在的域:jszx.com,B有应用webapp_b
      1)在cas下面设置cookie的时候,增加cookie.setDomain(".jszx.com");,这样在webapp_b下面就可以取到cookie。
      2)这个参数必须以“.”开始。
      3)输入url访问webapp_b的时候,必须输入域名才能解析。比如说在A机器输入:http://lc-bsp.jszx.com:8080/webapp_b,可以获取cas在客户端设置的cookie,而B机器访问本机的应用,输入:http://localhost:8080/webapp_b则不可以获得cookie。
      4)设置了cookie.setDomain(".jszx.com");,还可以在默认的home.langchao.com下面共享。
      5)设置多个域的方法???
最近的工作经常用到cookie,看了一些资料,虽然原来依赖cookie比较多的方案已经改成现在这个了,但是当时看得一些东西还是最好记下来,免得过些天就一干二净了,怪可惜的。

补充:cookie如果不设置时效的话,在浏览器关闭后是自动丢失,如果加上时效在有效期内关闭浏览器是不丢失的


写COOKIE的操作

  1. public class TestCookie extends HttpServlet {  
  2.     protected void doGet(HttpServletRequest request,  
  3.             HttpServletResponse response) throws ServletException, IOException {  
  4.         // 如果不设置域,cookie不会写入  
  5.         // 如果设为localhost也不会写入  
  6.         // cookie.setDomain("localhost");  
  7.         // 设置域为IP时,写入IP的域中,利用http://172.20.40.73:8088/SSOAuth/TestCookie访问可以读出  
  8.         // 利用http://localhost:8088/SSOAuth/TestCookie访问读不出来。  
  9.         Cookie cookie = new Cookie("duanqftest""22222");  
  10.         cookie.setDomain("172.20.40.73");  
  11.         cookie.setMaxAge(60000);  
  12.         cookie.setPath("/");  
  13.         response.addCookie(cookie);  
  14.         javax.servlet.http.Cookie[] diskCookies = request.getCookies();  
  15.         response.sendRedirect("ReadCookie");  
  16.   
  17.     }  
  18. }
读COOKIE的操作

  1. public class ReadCookie extends HttpServlet{  
  2.       protected void doGet(HttpServletRequest request, HttpServletResponse response){  
  3.           javax.servlet.http.Cookie[] diskCookies = request.getCookies();      
  4.           for(int i=0;i<diskCookies.length;i++){  
  5.               Cookie cookie=diskCookies[i];  
  6.               System.out.println( "cookie[0].getName()== "+cookie.getName());   
  7.               System.out.println( "cookie[0].getValue()== "+cookie.getValue());   
  8.               System.out.println( "cookie[0].getDomain() "+cookie.getDomain());  
  9.                 
  10.           }  
  11.       }  
  12. }


你可能感兴趣的:(Cookie多应用共享使用)