概述
页面自动刷新
<%@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,就不会看到它了,因为session的ID号只对同一窗口有效。
禁用页面缓存
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时,页面代码都会被执行一次。
最后
以上就是发嗲野狼为你收集整理的JSP之response对象的全部内容,希望文章能够帮你解决JSP之response对象所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复