JSP中的page,request,session,application
application:全局作用范围,整个应用程序共享,就是在部署文件中的同一个webApp共享,生命周期为:应用程序启动到停止。
session:会话作用域,当用户首次访问时,产生一个新的会话,以后服务器就可以记住这个会话状态。生命周期:会话超时,或者服务器端强制使会话失效。
session是针对单个客户和服务器进行会话的
aaplication是服务器所有客户和服务器会话的
用户独自的信息:Session
整个网站共享: Applicatinon
request:请求作用域,就是客户端的一次请求。
page:一个jsp(SUN企业级应用的首选)页面。
以上作用范围使越来越小, request和page的生命周期都是短暂的,他们之间的区别就是:一个request可以包含多个page页(include,forward以及filter)。举个简单的例子:
jsp(SUN企业级应用的首选)1.jsp(SUN企业级应用的首选)
<jsp(SUN企业级应用的首选):useBean id="beanID" class="xxx .xxx.BeanClass" scope="request" />
<jsp(SUN企业级应用的首选):include page="jsp(SUN企业级应用的首选)2.jsp(SUN企业级应用的首选)" />
jsp(SUN企业级应用的首选)2.jsp(SUN企业级应用的首选)
<jsp(SUN企业级应用的首选):getProperty name="beanID" property="sample" />
运行jsp(SUN企业级应用的首选)1.jsp(SUN企业级应用的首选)可以正常显示数据,因为作用范围是request,相当于调用了request.setAttribute()方法,
jsp(SUN企业级应用的首选)2页通过request.getAttribute来获得这个bean.如果把request改为page,就会抛出NullPointerExceptioin.
一个请求可以跨好几个jsp(SUN企业级应用的首选)(include和forword)和Servlet(如filter).不过这里有一个需要注意的就是区别
<jsp(SUN企业级应用的首选):include> 和<%@ include %>.如果上面的<jsp(SUN企业级应用的首选):include page="jsp(SUN企业级应用的首选)2.jsp(SUN企业级应用的首选)" />改为<%@ include file="jsp(SUN企业级应用的首选)2.jsp(SUN企业级应用的首选)" %>,即使scope为page也是正确的,<%@ include %>是编译时包含,<jsp(SUN企业级应用的首选):include>是运行时包含.前者就相当于宏,编译时替代,后者相当于函数,运行时返回.(SUN企业级应用的首选):include>(SUN企业级应用的首选):i
相关文档:
<%@page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%@page import="org.springframework.context.ApplicationContext"%>
<%@page import="org.springframework.web.context.support.WebApplicationContextUtils"%>
<%@page import="ccp.suddenattack.service.news.*"%>
......
<body>
<%
Cookie[] cookies = request.getCookies() ;
Cookie cookie = null ;
if(cookies!=null){
cookie = cookies[0] ;
out.print("上次访问的ip是: " + request.getRemoteAddr() +"<br>") ;&n ......
1、通过<s:form
action="跳转页面">提交值,但是在<s:form>标签中的action后面至多只能跟一个参数,并且还会报警告,所以如果
想传递参数可以用<s:hidden name=""
values="username"></s:hidden>来传值,但是正规的写法需要配合<s:set>标签来用
如:
......
源程序
<%String sConn="你的连接"
Class.forName("oracle.jdbc.driver.OracleDriver");
Connection conn=DriverManager.getConnection(sConn,"你的用户名","密码");
Statement stmt=conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_UPDATABLE);
Statement stmtcount=conn.createStat ......
今天又遇到乱码问题,可真烦.为什么TOMCAT就不能自动判断项目的编码,而一定要项目遵循TOMCAT的编码.
说说解决方法吧:
在TOMCAT的SERVER.XML配置文件中的connector中添加URIEncoding="UTF-8"属性,如
<Connector port="88" maxHttpHeaderSize="8192" maxThreads="20" minSpareThreads="5" maxSpareThreads="10"
e ......