http://blog.wujianrong.com/?p=704
http://blog.wujianrong.com/?p=706
要正确的使用这段代码,你需要首先在SQLServer数据库里创建一username表,表里面创建两个字符型的字段,字段名分别为:uid,pwd,然后插入几条测试数据。
欢迎各位提出改进的意见。
以下用两种方式来实现jsp连接SQLServer数据库。
第一种JSP形式。
程序代码 程序代码
<%@ page contentType="text/html; charset=gb2312" language="java"
import="java.sql.*"%>
<%
/*********************
********* JDBC_ODBC连接 SQL Server 数据库,不需要设置数据源
********* Date: 2005.8
********* Email:fanwsp@126.com
********* Author: DreamTime [梦想年华]
********* 有任何欢迎提出指正
****************************/
//请根据需要,选择一种方法,去掉相应的方法的注释,并注释其它没有使用的
//以下几项请自行修改
String server="localhost"; //SQL Server 服务器的地址
String dbname="test"; //SQL Server 数据库的名字
String user="sa"; //SQL Server 数据库的登录用户名
String pass="chfanwsp"; //SQL Server 数据库的登录密码
String port="1433"; //SQL Server 服务器的端口号,默认为1433
/***** 方法1: *******
* 用net.sourceforge.jtds.jdbc.Driver
* (http://jtds.sourceforge.net/) *
* 在Win2003Server上安装SQLSERVER2000,必须安装补丁sp3 *
*************************/
// *******数据库连接代码 开始 *******
//数据库连接字符串
String url="jdbc:jtds:sqlserver://"+server+":"+port+"/"+dbname+";USER="+user+";PASSWORD="+pass+"";
//加载驱动程序
Class.forName("net.sourceforge.jtds.jdbc.Driver").newInstance();
//建立连接
Connection conn= DriverManager.getConnection(url);
//创建语句对象
Statement stmt=conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_UPDATABLE);
// **** 数据库连接代码 结束 *********
/********** 方法2: *******
************* 用微软提供的JDBC驱动程序 *******
*******************************************
*在Win2003 Server上安装SQLSERVER2000,必须安装补丁sp3
***************************/
// ****************** 数据库连接代码 开始 ******************
/*
String url="jdbc:microsoft:sqlserver://"+server+":"+port+";DatabaseName="+dbname+";
USER="+user+";PASSWORD="+pass+"";
Class.forName("com.microsoft.jdbc.sqlserver.SQLServerDriver").newInstance();
Connection conn= DriverManager.getConnection(url);
Statement stmt=conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_UPDATABLE);
*/
// **** 数据库连接代码 结束 *********
/********** 方法3: ****************
************* 用JDBC-ODBC桥驱动程序 *********
***********************************
* 在Win2003 Server上安装SQLSERVER2000,可能需要安装补丁sp3*
***************************/
// ********* 数据库连接代码 开始 ********
/*
String url="jdbc:odbc:Driver={SQL Server};server="+server+";uid="+user+";pwd="+pass+";database="+dbname+"";
Class.forName("com.microsoft.jdbc.sqlserver.SQLServerDriver").newInstance();
Connection conn= DriverManager.getConnection(url);
Statement stmt=conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_UPDATABLE);
*/
// **** 数据库连接代码 结束 *********
String sql="select * from username";
ResultSet rs=stmt.executeQuery(sql);
//rs.first();
while(rs.next()){
out.print("用户名:");
out.print(rs.getString("uid")+" 密码:");
out.println(rs.getString("pwd")+"
");
}
rs.close();
stmt.close();
conn.close();
%>
第二种方式,用JavaBean来实现。请看代码:
DBConnSql.java
编译以后的Class文件应该放在 WEB-INF\classes\conn目录下。
程序代码 程序代码
*
******* java连接SQL Server数据库代码 *************
******* 使用Jdbc连接 *************
*
* 作者:梦想年华
* Email:fanwsp@126.com
* HomePage:http://wsp.hniuca.net
* CopyRight(c)2005-2006 by DreamTime
*
*/
package conn; //导入包
import java.sql.*; //导入数据库操作的类
public class DBConnSql //构造方法,初始化
{
private Connection conn; //连接对象
private Statement stmt; //语句对象
private ResultSet rs; //结果集对象
private String sqldriver; //SQL Server驱动程序字符串
private String sqlURL; //SQL Server连接字符串
/********** 方法1: *********
* 用net.sourceforge.jtds.jdbc.Driver ************
* (http://jtds.sourceforge.net/)
* 在Win2003Server上安装SQLSERVER2000,必须安装补丁sp3
*
* 该方法取得连接所需各种参数,组成连接字符串,然后再建立连接
* server;dbname,user,pass,port
* 分别表示SQL Server 服务器的地址,数据库,用户名,密码,端口
*****************************/
public Connection getConnToSql1(String server,String dbname,String user,String pass,String port){
//SQL Server驱动程序,用net.sourceforge.jtds.jdbc.Driver
sqldriver = "net.sourceforge.jtds.jdbc.Driver";
sqlURL = "jdbc:jtds:sqlserver://"; //连接字符串一部分
try{
//完整的连接字符串
sqlURL =sqlURL+server+":"+port+"/"+dbname+";USER="+user+";PASSWORD="+pass+"";
Class.forName(sqldriver);
conn = DriverManager.getConnection(sqlURL);
}catch(Exception e){
System.out.println("操作数据库出错,请仔细检查");
System.err.println(e.getMessage());
}
return conn;
}
/********** 方法2: ***************
******* 用微软提供的JDBC驱动程序 **************
* 在Win2003 Server上安装SQLSERVER2000,必须安装补丁sp3
*
* 该方法取得连接所需各种参数,组成连接字符串,然后再建立连接
* server;dbname,user,pass,port
* 分别表示SQL Server 服务器的地址,数据库,用户名,密码,端口
********************************/
public Connection getConnToSql2(String server,String dbname,String user,String pass,String port){
//SQL Server驱动程序,用微软提供的JDBC驱动程序
sqldriver = "com.microsoft.jdbc.sqlserver.SQLServerDriver";
sqlURL = "jdbc:microsoft:sqlserver://"; //连接字符串一部分
try{
//完整的连接字符串
sqlURL =sqlURL+server+":"+port+";DatabaseName="+dbname+";USER="+user+";PASSWORD="+pass+"";
Class.forName(sqldriver);
conn = DriverManager.getConnection(sqlURL);
}catch(Exception e){
System.out.println("操作数据库出错,请仔细检查");
System.err.println(e.getMessage());
}
return conn;
}
/********** 方法3: **************
************* 用JDBC-ODBC桥驱动程序 **********
* 在Win2003 Server上安装SQLSERVER2000,可能需要安装补丁sp3
*
* 该方法取得连接所需各种参数,组成连接字符串,然后再建立连接
* server;dbname,user,pass,port
* 分别表示SQL Server 服务器的地址,数据库,用户名,密码,端口
**********************************************/
public Connection getConnToSql3(String server,String dbname,String user,String pass,String port){
//SQL Server驱动程序,用微软提供的JDBC驱动程序
sqldriver = "sun.jdbc.odbc.JdbcOdbcDriver";
sqlURL = "jdbc:odbc:Driver={SQL Server};"; //连接字符串一部分
try{
//完整的连接字符串
sqlURL =sqlURL+"server="+server+";uid="+user+";pwd="+pass+";database="+dbname+"";
Class.forName(sqldriver);
conn = DriverManager.getConnection(sqlURL);
}catch(Exception e){
System.out.println("操作数据库出错,请仔细检查");
System.err.println(e.getMessage());
}
return conn;
}
//关闭数据库连接
public void close()
{
try{
//rs.close();
//stmt.close();
conn.close();
}catch(SQLException sqlexception){
sqlexception.printStackTrace();
}
}
}
这个文件只是实现了数据库的连接,下面我们再写一个测试文件。
就是用sql语句从数据库里查询出记录,以验证我们数据库的连接是否成功。
connsql.jsp 文件源代码如下:
程序代码 程序代码
<%@ page contentType="text/html; charset=gb2312" language="java"
import="java.sql.*" %>
<%
/***** 说明:本数据库连接一共提供了三种方法:
一、用net.sourceforge.jtds.jdbc.Driver,请调用getConnToSql1方法。
二、用微软提供的JDBC驱动程序,请调用getConnToSql2方法。
三、用JDBC-ODBC桥驱动程序连接,请调用getConnToSql3方法。
本例使用的是第一种方法,调用getConnToSql1方法。请根据自己的实际情况进行修改
如果是第二种方法请把 Connection conn=DBConn.getConnToSql1(server,dbname,user,pass);
里面语句改为:
Connection conn=DBConn.getConnToSql2(server,dbname,user,pass);
其它类此。
*****************************************************/
//连接 SQL Server 数据库所需各种参数,请自行修改
String server="localhost"; //SQL Server 服务器的地址
String dbname="test"; //SQL Server 数据库的名字
String user="sa"; //SQL Server 数据库的登录用户名
String pass="chfanwsp"; //SQL Server 数据库的登录密码
String port ="1433"; //SQL Server 服务器的端口号,默认为1433
Connection conn=DBConn.getConnToSql3(server,dbname,user,pass,port);
Statement stmt=conn.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY);
String sql="select * from username order by id";
String sql1="insert into username (uid,pwd) values('wsp','wsp')";
//stmt.executeUpdate(sql1);
ResultSet rs=stmt.executeQuery(sql);
while(rs.next()){
out.print("用户名:");
out.print(rs.getString("uid")+" 密码:");
out.println(rs.getString("pwd")+"
");
}
rs.close();
stmt.close();
conn.close();
//DBConn.close();
%>
JSP 在开发电子商务网站中将网页逻辑与网页设计和显示分离,支持可重用的基于组件的设计,使基于Web的应用程序的开发变得迅速和容易。 JSP商务网站页面由HTML代码和嵌入其中的Java代码所组成。服务器在电子商务网站页面被客户端请求以后对这些Java代码进行处理,然后将生成的 HTML页面返回给电子商务网站户端的浏览器。在电子商务网站开发中Java Servlet 是JSP的技术基础,而且大型的Web应用程序的开发需要Java Servlet和JSP配合才能完成。JSP具备了Java技术的简单易用,完全的面向对象,具有平台无关性且安全可靠,主要面向因特网的所有特点。
JSP页面可以包含在多种不同的应用体系结构或者模型中,可以用于由不同协议、组件和格式所组成的联合体中。基于JSP的动态信息发布技术是一个开放的、可扩展的建立动态Web页面的标准。不论采用什么创建工具,开发人员都可以使用JSP页面来创建可移植的Web应用,在不同的Web应用服务器上运行。
JSP在开发电子商务网站中P 处理器对每一个 JSP 文件创建并编译 Servlet。该处理器还为每个 JSP 文件产生两个文件:
(1) java 文件:包含可用于 Servlet 的 Java 语言代码;
(2) class 文件:编译过的 Servlet。JSP 处理器把 .java 和 .class 文件放在目录 servlets\pagecompile\JSP_file_path 下,其中 JSP_file_path 是 JSP 源文件所在的目录路径。例如,若JSP 文件在WebSphere\AppServer\samples\Web
Bank 目录下,则.java 和.class 文件就在WebSphere\AppServer\servlets\pagecompile\WebSphere\App Server\samples\WebBank 目录下。.java 和 .class 文件的文件名相同。处理器使用了命名约定,该命名约定包括将下划线字符和后缀添加到 JSP 文件名中。例如,如果 JSP 文件名是 login.jsp,则生成的文件为 _login_xjsp.java 和 _login_xjsp.class。
JSP在开发电子商务网站中是servlet技术的扩展,Servlets和JSP是一起用于复杂的Web应用程序的。
在开发电子商务网站中用Java进行Web编程的一个好的开端就是学习servlet技术。即使你打算在你的Web应用程序中只运用JSP页面,你仍需要学习servlet技术。在更复杂的Web应用程序中,JSP页面只用于显示,而JavaBeans和自定义标签库用来嵌入商业逻辑。即:你也必须精通 JavaBeans和自定义标签库。
JSP 在开发电子商务网站中JSP 文件访问 Bean 或其它能将生成的动态内容发送到浏览器的组件。图5-1说明了该 JSP 访问模型。当 Web 服务器接收到一个 JSP 文件请求时,服务器将请求发送至 WebSphere应用服务器。WebSphere应用服务器 对 JSP 文件进行语法分析并生成 Java 源文件(被编译和执行为 Servlet)。Java 源文件的生成和编译仅在初次调用 Servlet 时发生,除非已经更新了原始的 JSP 文件。在这种情况下,WebSphere应用服务器 将检测所做的更新,并在执行它之前重新生成和编译 Servlet。浏览器通过一个Web 页面中的HTML表单请求一个servlet(PopulateBeanServlet),该servlet创建一个名为 dataBean 的DataBean 实例,并调用 JSP 文件将内容发送到浏览器。Servlet 示例和 JSP 文件示例说明了启用内容分离的 JSP 访问模型。
JSP由于是一种较新的技术,国内采用的较少。但在国外,JSP已经是比较流行的一种技术,尤其是电子商务类的网站,多采用JSP。 JSP应该是未来发展的趋势。世界上一些大的电子商务解决方案提供商都采用JSP/Servlet。比较出名的如IBM的E-business,它的核心是采用JSP/Servlet 的Web Sphere;西方另外一个非常著名的电子商务软件提供商,Intershop,它原来的产品Intershop1,2, 3, 4占据了主要的电子商务软件份额。采用PHP的网站如新浪网(sina)、中国人(Chinaren)等,但由于PHP本身存在的一些缺点,使得它不适合应用于大型电子商务站点,而更适合一些小型的商业站点。(百度空间)
北京时间4月17日下午消息,据国外媒体报道,华硕首席运营官H.C. Hung今天表示,该公司最初两款智能手机中,将有一款采用基于Linux的操作系统。
他表示,华硕与Garmin共同开发的智能手机中,将采用微软Windows Mobile操作系统以及基于Linux的LiMo操作系统。
他没有说明将于何时推出LiMo操作系统的手机。不过熟悉华硕这个项目但不愿透露姓名的消息人士表示,华硕计划于6月推出LiMo系统智能手机。这将是华硕推出的第二款基于Linux操作系统的产品,华硕2007年推出的低端上网本曾采用Linux系统。Linux的许可费比其他系统都低。
一些分析师已经对华硕推出智能手机表达了疑虑,认为在竞争本就非常激烈的智能手机市场,华硕的进入并不能带来很多价值。
目前,LiMo操作系统缺乏大牌手机制造商的支持,仅有NEC、松下和摩托罗拉推出了LiMo系统的智能手机。(CSDN)
$(document).ready(function() {
$("a").click(function() {
$("#decimal").val('这是一个例子');
$("#inputtext").val('控制text');
});
/*
$("a").click(function() {
alert("Hello world!");
});
*/
});
function convertToDecimal(){
$.ajax({
type: "GET",
url: "/jqueryjsp/response",
data: "key=" + $("#key").val(),
dataType: "html",
success: function(xml){
//alert( "keypress code: " + $("key",xml).text() );
/*
var decimal = document.getElementById('decimal');
decimal.value = $("key",xml).text();
//等价于上面的代码。
$("#decimal").val($("key",xml).text());
*/
$("#decimal").val($("key",xml).text());
$("#rating").html("按键代码:" + $("key",xml).text());
}
})
clear();
}
function clear(){
var key = document.getElementById("key");
key.value="";
// alert( "keypress code: " + $(this).html() );
}
摘要 在这一部分里,我们将讲解三种不同的JSP集成方案,代表着三种典型的应用范围。
SP相对于PHP来说,可能运行得更快,消耗系统资源更少,功能更为强大——例如对分布式处理和组件支持等等。JSP技术在国外已经相当普 及,而在国内,只不过还是刚热起来而已……虽然现在ASP+在性能上给JSP带来严峻的挑战,但它作为微软以外的一个选择,又支持多平台,所以还是很多网 站所采用的首选。在这一部分里,我们将讲解三种不同的JSP集成方案,代表着三种典型的应用范围。
三、Linux+Apache+PHP+JSP的Resin解决方案
首先向大家推荐的是Resin。Resin是快速的、容易配置和实施的、使用简单的JSP/Servlet引擎和Web服务器。这一点完全是无 庸置疑的,无论是在windows平台还是在UNIX/Linux平台。然而目前的Resin 1.3 还不是一个应用服务器。不过Resin 2.0版有望取得很大的突破。因为它将包含一些最新的J2EE特性。Resin在JSP tags、XML解析等方面投入都比较早,现在也是处于比较领先的地位。而apache.org的tomcat更象是一个开发研究的产品。如果让我来做一 个网站,RESIN肯定是我的首选——相信泛舟也是如此认为的。
我们将在Linux+Apache+PHP的WEB服务解决方案中加入JSP的支持,这也许是您升级网站的需要。就算你不需要PHP也没有关系,下面我也会讲解如何做到这一点。
Tomcat是目前应用十分广泛的一个Java servlet container与web服务器,反正5年来我是从4.0.6一直用到5.5.9,期间也出现过几次崩溃抛出类似hs_err_pid31199.log的log,不过绝大部分时间是运行平稳的。但java.lang.OutOfMemoryError的异常相信真正用过tomcat的人都遇到过,抛开程序问题不谈(使用Borland的optimizeit可以查找,代码中可能有本应短期存在的obj,但是却被一个长生命期的ref引用着,因此gc无法回收这个obj。多半跟静态对象有关), 这个异常和JVM默认划分的内存上限是128M有关,如果你的业务足够繁忙,128M是远远不过的,好在现在的内存几乎达到了白菜价(到今天大概1G是 260元),一般的服务器都有2-4G的内存,所以你可以大方的给JVM分配上1G甚至更多,这样就可以避免内存溢出或大大增加异常的周期。
則安裝完成後在安裝目錄的"bin"目錄裡會有一個tomcat.exe的檔案
先把tomcat的服務停掉
在命令列模式下(运行里输入CMD)
將目錄切換到tomcat的bin目錄
用下面的命令把服務移除
內容如下
set CATALINA_HOME=E:\Tomcat 4.1.24
set CLASSPATH=D:\j2sdk1.4.1_01\lib
set JAVACLASSPATH=%CLASSPATH%
set JAVACLASSPATH=%JAVACLASSPATH%;%CATALINA_HOME%\bin\bootstrap.jar
set JAVACLASSPATH=%JAVACLASSPATH%;%CATALINA_HOME%\common\lib\servlet.jar
set JAVACLASSPATH=%JAVACLASSPATH%;%JAVA_HOME%\lib\tools.jar
tomcat.exe -install "%SERVICENAME%" "%JAVA_HOME%\jre\bin\server\jvm.dll" -Djava.class.path="%JAVACLASSPATH%" -Dcatalina.home="%CATALINA_HOME%" -Xms512m -Xmx768m -start org.apache.catalina.startup.Bootstrap -params start -stop org.apache.catalina.startup.Bootstrap -params stop -out "%CATALINA_HOME%\logs\stdout.log" -err "%CATALINA_HOME%\logs\stderr.log"

① out - javax.servlet.jsp.jspWriter 方法: 2. void clearBuffer() ; 3. void close() ; 4. void flush() ; 5. int getBufferSize() ; 6. int getRemaining() ; 7. boolean isAutoFlush() ; 8. void newLine() ; 9. void print( boolean b ) ; 10. void println( boolean b ) ; 成员: 方法: 2. Enumeration getAttributeNames() ; 3. String getAuthType() ; 4. String getCharacterEncoding() ; 5. int getContentLength() ; 6. String getContentType() ; 7. String getContentPath() ; 8. Cookie[] getCookies() ; 9. Enumeration getHeaderNames() ; 10. Enumeration getHeaders( String name ) ; 11. String getHeader( String name ) ; 12. long getDateHeader( String name ) ; 13. int getIntHeader( String name ) ; 14. ServletInputStream getInputStream() ; 15. Locale getLocale() ; 16. Enumeration getLocales() ; 17. String getLocalName() ; 18. String getLocalAddr() ; 19. int getLocalPort() ; 20. String getMethod() ; 21. String getParameter( String name ) ; 22. Map getParameterMap() ; 23. Enumeration getParameterNames() ; 24. String[] getParameterValues( String name ) ; 25. String getQueryString() ; 26. String getPathInfo() ; 27. String getPathTranslated() ; 28. String getProtocol() ; 29. BufferedReader getReader() ; 30. String getRemoteAddr() ; 31. String getRemoteHost() ; 32. String getRemoteUser() ; 33. int getRemotePort() ; 34. String getRealPath( String path ) ; 35. RequestDispatcher getRequestDispatcher( String path ) ; 36. String getRequestedSessionId() ; 37. String RequestURI() ; 38. StringBuffer getRequestURI() ; 39. String getScheme() ; 40. String getServerName() ; 41. String getServletPath() ; 42. int getServerPort() ; 43. void removeAttribute( String name ) ; 44. void setAttribute( String name, Object value ) ; 45. void setCharacterEncoding( String name ) ; 46. HttpSession getSession() ; 48. boolean isRequestedSessionIdFromURL() ; 49. boolean isRequestedSessionIdValid() ; 50. boolean isSecure() ; 51. boolean isUserInRole( String role ) ; 52. Principal getUserPrincipal() ; 成员: 方法: 2. void addDateHeader( String name, long value ) ; 3. void addHeader( String name, String value ) ; 4. void addIntHeader( String name, int value ) ; 5. boolean containsHeader( String name ) ; 6. String encodeRedirectURL( String url ) ; 7. String encodeURL( String url ) ; 9. int getBufferSize() ; 10. String getCharacterEncoding() ; 11. String getContentType() ; 12. Locale getLocale() ; 13. ServletOutputStream getOutputStream() ; 14. PrintWriter getWriter() ; 15. boolean isCommitted() ; 16. void reset() ; 17. void resetBuffer() ; 18. void sendError( int xc, String msg ) ; 19. void sendRedirect( String locationg ) ; 20. void setBufferSize( int size ) ; 21. void setCharacterEncoding( String charset ) ; 22. void setContentLength( int length ) ; 23. void setContentType( String type ) ; 24. void setDateHeader( String name, long value ) ; 25. void setHeader( String name, String value ) ; 26. void setIntHeader( String name, int value ) ; 27. void setStatus( int xc ) ; 成员(HTTP状态码): 方法: 2. Enumeration getAttributeNames() ; 3. long getCreationTime() ; 4. String getId() ; 5. long getLastAccessedTime() ; 6. int getMaxInactiveInterval( int interval ) ; 7. ServletContext getServletContext() ; 8. HttpSessionContext getSessionContext() ; 9. Object getValue( String name ) ; 10. String[] getValueNames() ; 11. void invalidate() ; 12. boolean isNew() ; 13. void pubValue( String name, Object value ) ; 14. void removeValue( String name ) ; 15. void setAttribute( String name, String value ) ; 16. void setMaxInactiveInterval( int interval ) ; 17. void removeAttribute( String name ) ; 方法: 2. Object getAttribute( String name, int scope ) ; 3. Object findAttribute( String name ) ; 4. void removeAttribute( String name, int scope ) ; 5. void forward( String url ) ; 6. Enumeration getAttributeNamesScope( int scope ) ; 7. int getAttributeScope( String name ) ; 8. ErrorData getErrorDate() ; 9. Exception getException() ; 10. ExpressionEvaluator getExpressionEvaluator() ; 11. JspWriter getOut() ; 12. Object getPage() ; 13. ServletRequest getRequest() ; 14. ServletResponse getResponse() ; 15. ServletConfig getConfig() ; 16. ServletContext getServletContext() ; 17. HttpSession getSession() ; 18. VariableResolver getVariableResolver() ; 19. void include( String url, boolean flush ) ; 20. void release() ; 21. void initialize( Servlet servlet, ServletRequest request, ServletResponse response, 22. BodyContext pushBody() ; 23. JspWrite popBody() ; 24. void handlePageException( Exception e ) ; 成员: 方法: 2. Enumeration getAttributes() ; 3. ServletContext getContext( String uripath ) ; 4. String getInitParameter( String name ) ; 5. Enumeration getInitParameters() ; 6. int getMajorVersion() ; 7. String getMimeType( String file ) ; 8. int getMinorVersion() ; 9. String getRealPath( String path ) ; 10. RequestDispatcher getNamedDispatcher( String name ) ; 11. RequestDispatcher getRequestDispatcher( String path ) ; 12. URL getResource( String path ) ; 13. InputStream getResourceAsStream( String path ) ; 14. Set getResourcePaths( String path ) ; 15. String getServerInfo() ; 16. Servlet getServlet( String name ) ; 17. Enumeration getServlets() ; 18. String getServletContextName() ; 19. Enumeration getServletContextNames() ; 20. void log( Exception ex, String msg ) ; 21. void removeAttribute( String name ) ; 22. void setAttribute( String name, Object value ) ; 方法: 2. Enumeration getInitParameters() ; 3. ServletContext getContext() ; 4. String getServletName() ; 方法: 2. String getLocalizedMessage() ; 3. String getMessage() 4. StackTrackElement[] getStackTrace() ; 5. Throwable initCause( Throwable cause ) ; 7. void printStackTrace() ; 8. void setStackTrace( StackTraceElement[] stackTrace )
out对象用于把结果输出到网页上。
1. void clear() ;
清除输出缓冲区的内容,但是不输出到客户端。
清除输出缓冲区的内容,并输出到客户端。
关闭输出流,清除所有内容。
输出缓冲区里面的数据。
获取以kb为单位的目前缓冲区大小。
获取以kb为单位的缓冲区中未被占用的空间大小。
是否自动刷新缓冲区。
输出一个换行字符。
void print( char c ) ;
void print( char[] s ) ;
void print( double d ) ;
void print( float f ) ;
void print( int i ) ;
void print( long l ) ;
void print( Object obj ) ;
void print( String s ) ;
将指定类型的数据输出到Http流,不换行。
void println( char c ) ;
void println( char[] s ) ;
void println( double d ) ;
void println( float f ) ;
void println( int i ) ;
void println( long l ) ;
void println( Object obj ) ;
void println( String s ) ;
将指定类型的数据输出到Http流,并输出一个换行符。
11. Appendable append( char c ) ;
Appendable append( CharSequence cxq, int start, int end ) ;
Appendable append( CharSequence cxq ) ;
将一个字符或者实现了CharSequence接口的对象添加到输出流的后面。
int DEFAULT_BUFFER = 0 - 缺省缓冲区大小
int NO_BUFFER = -1 - writer是否处于缓冲输出状态
int UNBOUNDED_BUFFER = -2 - 是否限制缓冲区大小
② request - javax.servlet.http.HttpServletRequest
request对象包含所有请求的信息,如请求的来源、标头、cookies和请求相关的参数值等。
1. Object getAttribute( String name ) ;
返回由name指定的属性值,该属性不存在时返回null。
返回request对象的所有属性名称的集合。
返回用来保护servlet的认证方法的名称,未受保护时返回null。
返回请求中的字符编码方法,可以在response对象中设置。
返回请求的BODY的长度,不能确定长度时返回-1。可以在response中设置。
返回在response中定义的内容类型。
返回请求的路径。
返回客户端所有的Cookie的数组。
返回所有HTTP头的名称的集合。
返回指定HTTP头的所有值的集合。
返回指定名称的HTTP头的信息。
返回指定名称的Data类型的HTTP头的信息。
返回指定名称的Int类型的HTTP头的信息。
返回请求的输入流。
返回当前页的Locale对象,可以在response中设定。
返回请求中所有的Locale对象的集合。
获取响应请求的服务器端主机名。
获取响应请求的服务器端地址。
获取响应请求的服务器端端口
获取客户端向服务器端发送请求的方法(GET、POST)。
获取客户端发送给服务器端的参数值。
该方法返回包含请求中所有参数的一个Map对象。
返回请求中所有参数的集合。
获得请求中指定参数的所有值。
返回get方法传递的参数字符串,该方法不分解出单独的参数。
取出请求中处于ServletPath和QueryString之间的额外信息。
返回用getPathInfo()方法取得的路径信息的实际路径。
返回请求使用的协议。可以是HTTP1.1或者HTTP1.0。
返回请求的输入流对应的Reader对象,该方法和getInputStream()方法在一个页面中只能调用一个。
获取发出请求的客户端IP地址。
获取发出请求的客户端主机名
返回经过客户端验证的用户名,未经验证返回null。
返回发出请求的客户端主机端口。
返回给定虚拟路径的物理路径。
按给定的路径生成资源转向处理适配器对象。
返回请求的session的标识。
返回发出请求的客户端地址,但是不包括请求的参数字符串。
返回响应请求的服务器端地址
获取协议名称,缺省值为HTTP协议。
返回响应请求的服务器名称。
获取客户端所请求的脚本文件的文件路径。
获取响应请求的服务器端主机端口号。
在属性列表中删除指定名称的属性。
在属性列表中添加/删除指定的属性。
设置请求的字符编码格式。
HttpSession getSession( boolean create ) ;
获取session,如果create为true,在无session的情况下创建一个。
47. boolean isRequestedSessionIdFromCookie() ;
检查请求的会话ID是否为通过Cookie传入。
检查请求的会话ID是否为通过URL传入。
检查请求的会话ID是否仍然有效。
检查请求是否使用安全链接,如果HTTPS等。
检查已经通过验证的用户是否在是role所指定的角色。
返回包含用户登陆名的一个java.security.Principal对象。
String BASIC_AUTH = "BASIC" -
String CLIENT_CERT_AUTH = "CLIENT_CERT" -
String DIGEST_AUTH = "DIGEST" -
String FORM_AUTH = "FORM" -
③ response - javax.servlet.http.HttpServletResponse
response对象主要将JSP容器处理后的结果传回到客户端。
1. void addCookie( Cookie cookie ) ;
添加一个Cookie对象,保存客户端信息。
添加一个日期类型的HTTP头信息,覆盖同名的HTTP头信息。
添加一个HTTP头,覆盖同名的旧HTTP头。
添加一个整型的HTTP头,覆盖同名的旧HTTP头。
判断指定的HTTP头是否存在。
对sendRedirect()方法使用的URL进行编码。
将URL予以编码,回传包含session ID的URL。
8. void flushBuffer() ;
强制把当前缓冲区的内容发送到客户端。
取得以kb为单位的缓冲区大小。
获取响应的字符编码格式。
获取响应的类型。
获取响应的Locale对象。
返回客户端的输出流对象。
获取输出流对应的writer对象。
判断服务器端是否已经将数据输出到客户端。
清空buffer中的所有内容。
情况buffer中所有的内容,但是保留HTTP头和状态信息。
void sendError( int xc ) ;
发送错误,包括状态码和错误信息。
把响应发送到另外一个位置进行处理。
设置以kb为单位的缓冲区大小。
设置响应使用的字符编码格式。
设置响应的BODY长度。
设置响应的类型。
设置指定名称的Data类型的HTTP头的值。
设置指定名称的HTTP头的值。
设置指定名称的int类型的HTTP头的值。
设置响应状态码,新值会覆盖当前值。
int SC_CONTINUE = 100 int SC_SWITCHING_PROTOCOLS = 101
int SC_OK = 200 int SC_NON_AUTHORITATIVE_INFORMATION = 203
int SC_ACCEPTED = 202 int SC_CREATED = 201
int SC_NO_CONTENT = 204 int SC_RESET_CONTENT = 205
int SC_PARTIAL_CONTENT = 206 int SC_MULTIPLE_CHOICES = 300
int SC_MOVED_PERMANENTLY = 301 int SC_MOVED_TEMPORARILY = 302
int SC_FOUND = 302 int SC_SEE_OTHER = 303
int SC_NOT_MODIFIED = 304 int SC_USE_PROXY = 305
int SC_TEMPORARY_REDIRECT = 307 int SC_BAD_REQUEST = 400
int SC_UNAUTHORIZED = 401 int SC_PAYMENT_REQUIRED = 402
int SC_FORBIDDEN = 403 int SC_NOT_FOUND = 404
int SC_METHOD_NOT_ALLOWED = 405 int SC_NOT_ACCEPTABLE = 406
int SC_PROXY_AUTHENTICATION_REQUIRED = 407 int SC_REQUEST_TIMEOUT = 408
int SC_CONFLICT = 409 int SC_GONE = 410
int SC_LENGTH_REQUIRED = 411 int SC_PRECONDITION_FAILED = 412
int SC_REQUEST_ENTITY_TOO_LARGE = 413 int SC_REQUEST_URI_TOO_LONG = 414
int SC_UNSUPPORTED_MEDIA_TYPE = 415 int SC_REQUESTED_RANGE_NOT_SATISFIABLE = 416
int SC_EXPECTATION_FAILED = 417 int SC_INTERNAL_SERVER_ERROR = 500
int SC_NOT_IMPLEMENTED = 501 int SC_BAD_GATEWAY = 502
int SC_SERVICE_UNAVAILABLE = 503 int SC_GATEWAY_TIMEOUT = 504
int SC_HTTP_VERSION_NOT_SUPPORTED = 505
④ session - javax.servlet.http.HttpSession
session对象表示目前个别用户的会话状态,用来识别每个用户。
1. Object getAttribute( String name ) ;
获取与指定名字相关联的session属性值。
取得session内所有属性的集合。
返回session的创建时间,最小单位千分之一秒。
取得session标识。
返回与当前session相关的客户端最后一次访问的时间,由1970-01-01算起,单位毫秒。
返回总时间,以秒为单位,表示session的有效时间(session不活动时间)。-1为永不过期。
返回一个该JSP页面对应的ServletContext对象实例。
取得指定名称的session变量值,不推荐使用。
取得所有session变量的名称的集合,不推荐使用。
销毁这个session对象。
判断一个session是否由服务器产生,但是客户端并没有使用。
添加一个session变量,不推荐使用。
移除一个session变量的值,不推荐使用。
设置指定名称的session属性值。
设置session的有效期。
移除指定名称的session属性。
⑤ pageContext - javax.servlet.jsp.PageContext
pageContext对象存储本JSP页面相关信息,如属性、内建对象等。
1. void setAttribute( String name, Object value, int scope ) ;
void setAttribute( String name, Object value ) ;
在指定的共享范围内设置属性。
Object getAttribute( String name ) ;
取得指定共享范围内以name为名字的属性值。
按页面、请求、会话和应用程序共享范围搜索已命名的属性。
void removeAttribute( String name ) ;
移除指定名称和共享范围的属性。
将页面导航到指定的URL。
取得指定共享范围内的所有属性名称的集合。
取得指定属性的共享范围。
取得页面的errorData对象。
取得页面的exception对象。
取得页面的expressionEvaluator对象。
取得页面的out对象。
取得页面的page对象。
取得页面的request对象。
取得页面的response对象。
取得页面的config对象。
取得页面的servletContext对象。
取得页面的session对象。
取得页面的variableResolver对象。
void include( String url ) ;
包含其他的资源,并指定是否自动刷新。
重置pageContext内部状态,释放所有内部引用。
String errorPageURL, boolean needSession, int bufferSize, boolean autoFlush ) ;
初始化未经初始化的pageContext对象。
BodyContext pushBody( Writer writer ) ;
保存当前的out对象,并更新pageContext中page范围内的out对象。
取出由pushBody()方法保存的out对象。
void handlePageException( Thrwoable t ) ;
int PAGE_SCOPE = 1 - 页面共享范围
int REQUEST_SCOPE = 2 - 请求共享范围
int SESSION_SCOPE = 3 - 会话共享范围
int APPLICATION_SCOPE = 4 - 应用程序共享范围
String PAGE = "javax.servlet.jsp.jspPage"
String PAGECONTEXT = "javax.servlet.jsp.jspPageContext"
String REQUEST = "javax.servlet.jsp.jspRequest"
String RESPONSE = "javax.servlet.jsp.jspResponse"
String CONFIG = "javax.servlet.jsp.jspConfig"
String SESSION = "javax.servlet.jsp.jspSession"
String OUT = "javax.servlet.jsp.jspOut"
String APPLICATION = "javax.servlet.jsp.jspApplication"
String EXCEPTION = "javax.servlet.jsp.jspException"
⑥ application - javax.servlet.ServletContext
application主要功用在于取得或更改Servlet的设定。
1. Object getAttribute( String name ) ;
返回由name指定的application属性。
返回所有的application属性。
取得当前应用的ServletContext对象。
返回由name指定的application属性的初始值。
返回所有的application属性的初始值的集合。
返回servlet容器支持的Servlet API的版本号。
返回指定文件的类型,未知类型返回null。一般为"text/html"和"image/gif"。
返回servlet容器支持的Servlet API的副版本号。
返回给定虚拟路径所对应物理路径。
为指定名字的Servlet对象返回一个RequestDispatcher对象的实例。
返回一个RequestDispatcher对象的实例。
返回指定的资源路径对应的一个URL对象实例,参数要以"/"开头。
返回一个由path指定位置的资源的InputStream对象实例。
返回存储在web-app中所有资源路径的集合。
取得应用服务器版本信息。
在ServletContext中检索指定名称的servlet。
返回ServletContext中所有servlet的集合。
返回本web应用的名称。
返回ServletContext中所有servlet的名称集合。
void log( String msg, Throwable t ) ;
void log( String msg ) ;
把指定的信息写入servlet log文件。
移除指定名称的application属性。
设定指定的application属性的值。
⑦ config - javax.servlet.ServletConfig
config对象用来存放Servlet初始的数据结构。
1. String getInitParameter( String name ) ;
返回名称为name的促使参数的值。
返回这个JSP所有的促使参数的名称集合。
返回执行者的servlet上下文。
返回servlet的名称。
⑧ exception - java.lang.Throwable
错误对象,只有在JSP页面的page指令中指定isErrorPage="true"后,才可以在本页面使用exception对象。
1. Throwable fillInStackTrace() ;
将当前stack信息记录到exception对象中。
取得本地语系的错误提示信息。
取得错误提示信息。
返回对象中记录的call stack track信息。
将另外一个异常对象嵌套进当前异常对象中。
6. Throwable getCause() ;
取出嵌套在当前异常对象中的异常。
void printStackTrace( printStream s ) ;
void printStackTrace( printWriter s ) ;
打印出Throwable及其call stack trace信息。
设置对象的call stack trace信息。
⑨ page - javax.servlet.jsp.HttpJspPage
page对象代表JSP对象本身,或者说代表编译后的servlet对象,
可以用( (javax.servlet.jsp.HttpJspPage)page )来取用它的方法和属性。
我们都知道在jsp中include有两种形式,分别是
< %@ include file=” ”%>
< jsp:include page=” ” flush=”true”/>
前者是指令元素、后者是行为元素。具体它们将在何处用?如何用及它们有什么区别?这应该是很多人看到它都会想到的问题。下面一起来看看吧。
通常当应用程序中所有的页面的某些部分(例如标题、页脚和导航栏)都相同的时候,我们就可以考虑用include。具体在哪些时候用< %@ include file=” ”%>,哪些时候用< jsp:include page=” ” flush=”true”/>.这种形式。首先要明白的是它们之间的区别。只有了解了它们用法的不同才理解该在何时去用以及如何选择。
< %@ include file=” ”%>,jsp的include指令元素读入指定页面的内容。并把这些内容和原来的页面融合到一起。(这个过程是在翻译阶段:也就是jsp被转化成servlet的阶段进行的。
这里对翻译阶段进行一下说明:我们知道,jsp页面不能原封不动地被传送给浏览器,所有的jsp元素都必须首先由服务器进行处理。这是通过将jsp页面转达化成servlet,然后执行这个servlet来完成的。服务器需要一个jsp容器来处理jsp页面。jsp容器通常以servlet的形式来实现,这个servlet经过配置,可以处理对jsp页面的所有请求。
Jsp容器负责将jsp页面转化成servlet(称为jsp页面实现类?JSP Page implementation class),并编译这个servlet。这两步就构成了翻译阶段.
由此我们就会知道:jsp页面是把include指令元素所指定的页面的实际内容(也就是代码段)加入到引入它的jsp页面中,合成一个文件后被jsp容器将它转化成servlet。可以看到这时会产生一个临时class文件和一个java文件。下面举个例子。
服务器用tomcat,引入页面的jsp文件叫test.jsp。被引入的页面叫date.jsp.这个jsp文件里存放的是一个有关时间的jsp代码,当前的上下文根设为test
//======date.jsp的源文件=====//
<%@ page language=”java” contentType="text/html;charset=gb2312"%>
<%
java.util.Date date=new java.util.Date();
String date_cn ="";
String dateStr = "";
switch(date.getDay())
{
case 0:date_cn ="日"; break;
case 1:date_cn ="一"; break;
case 2:date_cn ="二"; break;
case 3:date_cn ="三"; break;
case 4:date_cn ="四"; break;
case 5:date_cn ="五"; break;
case 6:date_cn ="六"; break;
}
dateStr = (1900+date.getYear())+"年"+(date.getMonth()+1)+"月"+date.getDate()+
"日(星期" + date_cn + ")";
%>
document.write("<%=dateStr%>");
//======以下是test.jsp的源文件=============//
<%@ page language=”java” contentType=”text/html;charset=gb2312”%>
<html>
<head>
<title>include的两种用法</title>
<jsp:include page=”date.jsp” flush=”true”/>
<%--@ include file=”date.jsp” %-->
//我们在这里用include的两种不同形式来引入date.jsp这个文件.
<head>
<body>
<table><tr><td>
有关jsp中include的两种用法.敬请关注。
</td></tr></table>
</body>
</html>
在test.jsp 文件中,我们只输出了一行文本“ 有关jsp中include的两种用法.敬请关注。”,现在让我们先用这种形式引入date.jsp这个文件。你想会出现什么问题了吗?此时出现了错误提示:
HTTP Status 500 ?
org.apache.jasper.JasperException: /date.jsp(0,0) Page directive:
can't have multiple occurrences of contentType
以下还有一堆错误,但我们只要看这里就知道问题的所在了。状态码为http 500服务器内部错误。再看下面的提示。在date.jsp页面中不能指定多个contentType.