JSP之response对象

页面自动刷新

<%@page contentType="text/html;charset=gb2312"%>

<HTML>

       <HEAD>

              <TITLE>页面自动刷新</TITLE>

       </HEAD>

       <BODY>

       <%!

              int i = 0 ;

       %>

       <%

              response.setHeader("refresh","1") ;

       %>

       <h1><%=i++%></h1>

       </BODY>

</HTML>

 

这里,我们只有将i定义为全局变量,才能看到自增效果。上例中,我们设置为每一秒钟自动刷新一次。

页面自动跳转

<%@page contentType="text/html;charset=gb2312"%>

<HTML>

       <HEAD>

              <TITLE>页面自动跳转</TITLE>

       </HEAD>

       <BODY>

       <%

              response.setHeader("refresh","3;URL=common.jsp") ;

       %>

       三秒后跳转!!!<br>

       如果没有跳转,请按<a href="common.jsp">这里</a>!!!

       </BODY>

</HTML>

 

在自动跳转的过程中,可以将参数添加到URL的尾部用来传递参数值,例如:

 

index.jsp

<%@page contentType="text/html;charset=gb2312"%>

<HTML>

       <HEAD>

              <TITLE>自动跳转并传参数</TITLE>

       </HEAD>

       <BODY>

       <%

              response.setHeader("refresh","3;URL=common.jsp?ref=aaa") ;

       %>

       三秒后跳转!!!<br>

       如果没有跳转,请按<a href="common.jsp">这里</a>!!!

       </BODY>

</HTML>

 

common.jsp

<%@page contentType="text/html;charset=gb2312"%>

<HTML>

       <HEAD>

              <TITLE>自动跳转并传参数</TITLE>

       </HEAD>

       <BODY>

       <h1>参数:<%=request.getParameter("ref")%></h1>

       </BODY>

</HTML>

页面跳转

index.jsp

<%@page contentType="text/html;charset=gb2312"%>

<HTML>

       <HEAD>

              <TITLE>页面跳转</TITLE>

       </HEAD>

       <BODY>

       <h1>这里是index.jsp</h1>

       <%

              System.out.println("** 跳转之前...") ;

              response.sendRedirect("common.jsp") ;

              System.out.println("** 跳转之后...") ;

       %>

       </BODY>

</HTML>

 

common.jsp

<%@page contentType="text/html;charset=gb2312"%>

<HTML>

       <HEAD>

              <TITLE>页面跳转</TITLE>

       </HEAD>

       <BODY>

       <h1>这里是common.jsp</h1>

       </BODY>

</HTML>

 

运行上例,我们发现地址栏显示的是跳转后的页面,并且位于跳转语句之后的剩余代码也得到了执行。

另外,可以如前所述,在URL的尾部添加参数,以实现参数的传递。

设置Cookie

cookie是客户端保存的一种资源,常用来自动登录网站等。

 

index.jsp

<%@page contentType="text/html;charset=gb2312"%>

<HTML>

       <HEAD>

              <TITLE>Cookie的使用</TITLE>

       </HEAD>

       <BODY>

       <%

              Cookie c1 = new Cookie("name","aaa") ;

              Cookie c2 = new Cookie("password","111") ;

 

              // 最大保存时间为60

              c1.setMaxAge(60) ;

              c2.setMaxAge(60) ;

 

              // 通过response对象将Cookie设置到客户端

              response.addCookie(c1) ;

              response.addCookie(c2) ;

       %>

       </BODY>

</HTML>

 

common.jsp

<%@page contentType="text/html;charset=gb2312"%>

<HTML>

       <HEAD>

              <TITLE>Cookie的使用</TITLE>

       </HEAD>

       <BODY>

       <%

              // 通过request对象,取得客户端设置的全部Cookie

              // 实际上客户端的Cookie是通过HTTP头信息发送到服务器端上的

              Cookie c[] = request.getCookies() ;

       %>

       <%

              for(int i=0;i<c.length;i++)

              {

                     Cookie temp = c[i] ;

       %>

                     <h1><%=temp.getName()%> --> <%=temp.getValue()%></h1>

       <%

              }

       %>

       </BODY>

</HTML>

 

先后执行上面的两个页面,我们可以看到,客户端所保存的cookie会被服务器读取。如果超过了cookie保存时间,则第二个页面就会出错。

另外,如果上面的两个页面是在同一窗口中执行,则我们会看到JSESSIONID,这是服务设置一个默认的cookie到客户端。如果我们另外开窗口执行common.jsp,就不会看到它了,因为sessionID号只对同一窗口有效。

禁用页面缓存

index.jsp

<%@page contentType="text/html;charset=gb2312" import="java.util.Date"%>

<HTML>

       <HEAD>

              <TITLE>禁用页面缓存</TITLE>

       </HEAD>

       <BODY>

       <%

              Date d = new Date();

              System.out.println(d.toLocaleString());

       %>

       </BODY>

</HTML>

 

common.jsp

<%@page contentType="text/html;charset=gb2312"%>

<HTML>

       <HEAD>

              <TITLE>禁用页面缓存</TITLE>

       </HEAD>

       <BODY>

       <H1>这里是common.jsp</H1>

       </BODY>

</HTML>

 

先运行这个例子,我们在同一窗口中先后执行这两个网页,会看到后台输出了时间字符串,且窗口停留在common.jsp上。然后我们点浏览器的后退按钮,窗口会回到index.jsp,但是,我们观察后台,没有新的字符串输出了,这是怎么回事呢?

这说明,我们通过后退按钮虽然回到了index.jsp,但是页面的代码并没有被执行,我们看到的是浏览器的缓存页面。

 

在实际的项目开发工程中,往往会用到禁用缓存技术,即如果通过后退按钮回到了某一页,也必须从服务器上重新读取,例如:

 

index.jsp

<%@page contentType="text/html;charset=gb2312" import="java.util.Date"%>

<HTML>

       <HEAD>

       <%

       response.setHeader("Cache-Control","no-cache");

       response.setHeader("Pragma","no-cache"); 

       response.setDateHeader ("Expires", 0);

       %>

              <TITLE>禁用页面缓存</TITLE>

       </HEAD>

       <BODY>

       <%

              Date d = new Date();

              System.out.println(d.toLocaleString());

       %>

       </BODY>

</HTML>

 

common.jsp

<%@page contentType="text/html;charset=gb2312"%>

<HTML>

       <HEAD>

              <TITLE>禁用页面缓存</TITLE>

       </HEAD>

       <BODY>

       <H1>这里是common.jsp</H1>

       </BODY>

</HTML>

 

    我们运行修改过后的这个例子,就会发现当我们点击后退按钮回到index.jsp时,页面代码都会被执行一次。

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值