Web前段JSP面试题
1.response.sendRedirct("跳转到页面");
该方法通过修改HTTP协议的HEADER部分,对浏览器下达重定向指令的,使浏览器显示重定向网页的内容.
request无法传值过去.
执行完该页所有代码,然后再跳转到页面.
跳转地址栏改变.
可以跳转到其他服务器上的页面response.sendRedirct(http://www.sun.com).
2.response.setHeader();
该方法和response.sendRedirect一样,通过修改HTTP协议的HEADER部分.
<%
response.setStatus(HttpServletResponse.SC_MOVED_PERMANENTLY);
StringnewLocn="/index.html";
response.setHeader("Location",newLocn);
%>
3.<jsp:forwardpage="跳转页面"/>
该方法是利用服务器端先将数据输出到缓冲区的机制,在把缓冲区的内容发送到客户端之前,原来的不发送,改为发送该页面的内容,如果在<jsp:forward>之前有很多输出,前面的输出已使缓冲区满,将自动输出到客户端,那么该语句将不起作用,这一点应该特别注意.
request可以传值过去.
直接跳转到页面,后面的代码不执行.
跳转后地址栏不变.
无法跳转到其他服务器上的页面.
图片不是绝对路径无法显示.
例子1:
from.jsp
<%@pagecontentType="text/html;charset=gb2312"%>
<%@pagebuffer="1kb"%>
<%
longi=0;
intj=0;
for(i=0;i<60;i++)
{
out.println(j++);
}
%>
<jsp:forwardpage="to.jsp"/>
结果:跳到to.jsp上.
例子2
from.jsp
<%@pagecontentType="text/html;charset=gb2312"%>
<%@pagebuffer="1kb"%>
<%
longi=0;
intj=0;
for(i=0;i<600;i++)
{
out.println(j++);
}
%>
<jsp:forwardpage="to.jsp"/>
报错:
java.lang.IllegalStateException:Error:Attempttoclearabufferthat'salreadybeenflushed
org.apache.jasper.runtime.PageContextImpl.doForward(PageContextImpl.java:648)
org.apache.jasper.runtime.PageContextImpl.forward(PageContextImpl.java:637)
org.apache.jsp.forward.from02_jsp._jspService(from02_jsp.java:58)
org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:94)
javax.servlet.http.HttpServlet.service(HttpServlet.java:802)
org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:324)
org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:292)
org.apache.jasper.servlet.JspServlet.service(JspServlet.java:236)
javax.servlet.http.HttpServlet.service(HttpServlet.java:802)
org.pcvit.pan.filter.EncodingFilter.doFilter(EncodingFilter.java:19)
例子3:
from.jsp
<%@pagecontentType="text/html;charset=gb2312"%>
<%@pagebuffer="1kb"%>
<%
longi=0;
intj=0;
for(i=0;i<6000;i++)
{
out.println(j++);
}
%>
<jsp:forwardpage="to.jsp"/>
结果:没有跳到to.jsp上.但是却显示出了from.jsp页面的代码执行结果.
4.request.getRequestDispatcher("跳转页面");
request可以传值过去.
执行完该页所有代码,然后再跳转到页面.
跳转地址栏不变.
不可以跳转到其他服务器上的页面
<%
RequestDispatcherrd=request.getRequestDispatcher("to.jsp");
rd.forward(request,response);
%>
服务端的输出缓冲区
缺省情况下:服务端要输出到客户端的内容,不直接写到客户端,而是先写到一个输出缓冲区中.只有在下面三中情况下,才会把该缓冲区的内容输出到客户端上:
该JSP网页已完成信息的输出
输出缓冲区已满
JSP中调用了out.flush()或response.flushbuffer()
输出缓冲区的大小可以用:或response.setBufferSize()设置,如下:
设置输出缓冲区的大小为1KB。或response.setBufferSize(1);
设置输出缓冲区的大小为0,即不缓冲。或response.setBufferSize(0);
用response.getBufferSize()或out.getBufferSize()可取的输出缓冲区的大小,单位为字节.用response.isCommitted()可检查看服务端是否已将数据输出到客户端.如果返回值是true则已将数据输出到客户端,是false则还没有.
有以下3种方法可以做到输出重定向:
RESPONSE.SETREDERECT("URL")该方法通过修改HTTP协议的HEADER部分,对浏览器下达重定向指令的,使浏览器显示重定向网页的内容.response.sendRedirect("http://localhost:7001/index.html");
下面的方法也能改变HTTPHEADER属性,它的原理和1是一样的.
<%
response.setStatus(HttpServletResponse.SC_MOVED_PERMANENTLY);
StringnewLocn="/index.html";
response.setHeader("Location",newLocn);
%>
采用<JSP:FORWORD>该方法是利用服务器端先将数据输出到缓冲区的机制,在把缓冲区的内容发送到客户端之前,原来的不发送,改为发送该页面的内容,如果在<JSP:FORWORD>之前有很多输出,前面的输出已使缓冲区满,将自动输出到客户端,那么该语句将不起作用,这一点应该特别注意.
说明:
1.方法(1),(2)可以使用变量表示重定向的地址;方法(3)不能使用变量表示重定向的地址。
Stringadd="./index.html";
<jsp:forwardpage=add/>
无法重定向到index.html中去
Stringadd=http://localhost:7001/index.html
response.sendRedirect(add);
可以重定向到http://localhost:7001/index.html中去。
2.采用方法(1),(2)request中的变量(通过request.setAttribute()保存到request中的值)不能在新的页面中采用,采用方法(3)能.综上,我们应该采用(1),(2)重定向比较好.
使用ResponseBuffering
通过打开“responsebuffering”可以缓冲一个值得输出的整个页面内容,这将最小化输出到浏览器的数据量,从而提高了整体性能。每一次输出都耗费许多,所以写得越少,效果越好。TCP/IP在发送少量大的数据包时,要比发送大量小的数据包工作效率高,因为它是慢速启动并不断发送的。
有2种方法打开ResponseBuffering。首先,可以使用InternetServicesManager为整个应用程序打开responsebuffering,这是推荐的方式,而且在IIS4.0和IIS5.0中,默认状态下,responsebuffering是打开的。其次,在每一页面上,可以在头部放置如下代码开打开responsebuffering:
<%Response.Buffer=True%>
这段代码必须在任何数据输出到浏览器前被执行(就是说,在任何html内容显示前和在任何cookie被设置前)。通常情况下,为整个应用程序打开responsebuffering是很好的方案,这么做后就不用在每个页面头部设置如上的代码。
关于打开responsebuffering的一个通用问题是:用户必须要等待整个页面全部产生后,才能看到内容。对于一个长时间运行的页面来说,可以设置Response.Buffer=False关闭缓冲。然后,好的策略是利用Response.Flush方法,它将输出所有已被ASP描述的HTML内容到浏览器。比如,在描述了一个1,000行表格的100行后,ASP就可以使用Response.Flush来强迫输出这100行的内容到浏览器,这时用户就可以看到前100行数据,同时其余的行数据正在准备生成。
注意,关于上面的1,000行表格输出的例子,对于一些浏览器器来说,除非遇到</table>标记,它们不会输出表格的任何内容。如果这样,可以将表格分割成许多含有少量行的多个表格,然后在每一个表格产生后,调用Response.Flush输出。新版的InternetExplorer在整个表格下载后才显示内容,并且,如果定义了表格的列宽度,生成表格的速度将特别快。
关于打开responsebuffering的另外一个问题是:当生成非常大的页面时,将消耗非常大的服务器内存。
1,在<head>和</head>之间加入这句就可以了:<metaHTTP-EQUIV=REFRESHCONTENT="10;URL=http://www.ccb.cn">
CONTENT后面的10表示秒数,URL后面可以是相对路径文件名,也可以是http的绝对路径。
这种方法属于客户端的跳转。
2,JS自动跳转
<table>
<tr>
<tdid="go_title">3秒后自动跳转到论坛首页</td>
</tr>
</table>
vartime=0;
functiongotoBbsIndex(){
time++;
if(time==3){
document.location.href="bbs/main/index.html";
}
document.getElementByIdx_x("go_title").innerHTML=(3-time)+"秒后自动跳转到论坛首页";
}
window.setInterval("gotoBbsIndex()",1000);
</script>