应该是你的beans目录没有设对
解决方案 »
- 求jfreechart高手来教教折线图折点数值如何错开
- 求教在jsp页面预览原生swf文件的方法,问题一经解决立即结贴给分,在线急等。。。
- jboss上跑一段hibernate程序,老出现java.lang.NullPointerException错误!
- 关于一个简单的正则表达式为什么不行?
- ireport+jasperreports 柱状图如何制作
- jsp参数强制转换怎么写?
- 高手请进,请问如何把要选定信息的值传递到相应的文本框中!
- solaris下上传中文件乱码
- sql语句怎么转换成hql
- 关于自建目录放置servlet的问题
- jsp中的中文处理问题,JAVA不是用unicode编码吗?为什么出现乱码
- 菜鸟编javaBeans遇到的一个“大大的”问题
===============================
PWIN98营造JSP环境及建立数据查询 利用JSP(JavaServer Pages)技术,能有效快速地建造动态数据库查询网页。众所周知,要学好、学精一应用软件,首先要装好软件,找一可运行实例学习,并对实例修改运行、学习提高,这样你就会很快入门及学精这一软件,本文说明在PWIN98下如何营造JSP环境及建立一通过odbc对数据库查询的网页。 环境为pwin98,所需软件为jdk1.3、jswdk1.0.1。这些软件可以从电脑软件市场买到,也可以从网站下载。 jdk1.3的安装,运行jdk1.3安装文件,并把autoexec.bat在path后加c:\jdk1.3\bin 即可。(jdk是安装在c:\jdk1.3中,jdk是安装在其他目录,则c:\jdk1.3改为相应的目录).为了启动运行jswdk服务器在autoexec.bat还必须多加如下: path=%path%;c:\jdk1.3
set classpath=c:\jdk1.3\lib\tools.jar;c:\jdk1.3\lib\dt.jar
set java_home=c:\jdk1.3 JSWDK1.0.1的安装,JSWDK1.0.1的安装文件为一压缩文件,解压缩后它产生一目录jswdk-1.0.1,这样软件已装了。 要想运行启动服务器(jswdk-1.0.1目录下的startserver.bat),还必须设置和修改一些参数,你也可查看jsdk-1.0.1目录下的readme.html的说明,当没有设置修改参数时,在jswdk-1.0.1目录下键入startserver.bat会出现out of environment space错误信息,在jswdk-1.0.1目录下键入stopserver.bat(关闭jswdk服务器)会出现 error opening registry key 'software\javasoft\Java Runtime Environment'错误信息,上面两个出错说明也大概告诉了我们出错的原因1、是内存;2、是注册,解决上面两个问题就可启动服务器.
解决办法: 1、打开一DOS窗口,按住[crtl]键再按[esc]键转到windows窗口,鼠标移到下面的ms-dos方式图标按鼠标右键,出现弹出菜单,再把鼠标移到弹出菜单的属性项并单击它,出现一弹出窗口,并单击其中内存项,把"内存"中的初始环境由自动改为2816或2816以上。
2、在windows窗口开始-运行regedit按确定找到Hkey_Local_Machine双击它找到Software双击它找到Javasoft双击它你们会看到"Java 运行环境"按鼠标右键把它改名为 "Java Runtime Environment",
这样完成了设置和参数的修改。
重新启动计算机。
在jswdk-1.0.1中键入startserver.bat会出现一dos窗口其中有如下内容: JSWDK WebServer Version 1.0.1
Loaded configuration from: file:C:\jswdk-1.0.1\webserver.xml
endpoint created: localhost/127.0.0.1:8080
这表明你已安装成功。 在ie4中键入http://127.0.0.1:8080:/ 就会出现java webserver page 的页面。 这里必须说明的是jswdk1.0.1服务器并不象PWS个人服务器它不是一单独的一软件,它必须JDK支持,如果JDK没装,或没装好它也不能启动运行,所以你们安装不能启动时,不要单从JSWDK1.0.1找问题,还必须到JDK上找。 如下建立一通过odbc对数据库数据库查询网页: 首先建立一数据库Sample.mdb(现在叫数据表)5个字段Name及Cardnum,Chinese,English,Math,并输入一些值.然后在控制面板中的32位odbc (odbc 32bit)模块中,加入用户 dsn( user dsn),取名dataexam,目录选定为Sample.mdb的所在目录,在c:\jswdk-1.0.1\examples\下建一目录meng并在其目录上建一文件databaseexam.jsp内容如下:<%@page import="java.sql.*;"%>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>数据库查询实例</title>
</head>
<body>
<center>
<%
String url="jdbc:odbc:dataexam";
Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
Connection con=DriverManager.getConnection(url);
DatabaseMetaData dma=con.getMetaData();
Statement stmt=con.createStatement();
ResultSet RS=stmt.executeQuery("SELECT * FROM score");
out.print("<table border='2' bgcolor='#0099ff'>");
%>
<caption>数据库查询网面</caption>
<tr><td>姓名</td><td>学号</td><td>语文</td><td>英语</td><td>数学</td></tr>
<%
while (RS.next()) {
out.print("<tr><td>" + RS.getString("Name")+"</td><td>" +RS.getString("Cardnum") + "</td><td>" +RS.getString("Chinese") + "</td><td>" +RS.getString("English") + "</td><td>" +RS.getString("Math") + "</td></tr>");
}
out.print("</table>");
RS.close();
%>
</center>
</body>
</html>这样你在IE里键入 http://127.0.0.1:8080/examples/meng/databaseexam.jsp你会看到你所录入的Name,Cardnum,Chinese,English,Math。如果你看不到内容或 出现 Error: 500 Unable to compile class for JSP 你可到启动服务器中的java dos窗口查看错误原因。
1、在 http://java.sun.com/jdk/处下载JDK(Java 2 SDK、Standard Edition、v 1.2.2)。
2、在http://java.sun.com/products/jsp/处下载JSWDK(JavaServer Web Development Kit 1.0.1)。Linux用户可以在ttp://jakarta.apache.org/处下载Tomcat 3.0。 3、安装 以Windows NT环境为例,JDK的安装是首先运行下载得到的jdk1_2_2-win.exe,然后修改系统环境参数,在PATH参数中加入[x:]\jdk1.2.2\bin以及增加新的环境参数 CLASSPATH=[x:]\jdk1.2.2\lib\tools.jar,其中[x:]是安装JDK的硬盘符(c:、d: 等)。 JSWDK的安装仅需将jswdk1_0_1-win.zip带目录释放到硬盘根目录下(c:\、d:\ 等),然后就可以在硬盘上找到\jswdk-1.0.1\目录。将来如果不想保留JSWDK,删除这个目录就可以了,没有任何系统文件和注册表遗留问题。更详细的安装过程以及Solaris/Unix和Linux下JDK、Tomcat的安装可以参考下载得到的文件包中的安装说明。 4、启动 以Windows NT环境为例,在\jswdk-1.0.1\目录下执行startserver.bat,就可启动JSWDK中一个支持JSP网页技术的Web服务器。为了不与现有的Web服务器(例如IIS、PWS等)冲突,JSWDK的Web服务器使用了8080端口。 在浏览器的地址栏中键入http://localhost:8080或者http://127.0.0.1:8080后,如果能看到 JSWDK 的欢迎页就说明JSP实验环境已经建成,可进入下一步实验。 要关闭Web服务器则运行stopserver.bat。 三、 JSP简单示例 JSWDK中包含的Web服务器的文档目录在缺省状态下为\jswdk-1.0.1\webpages,主文档在缺省状态下为index.html和index.jsp。也就是说访问http://localhost:8080等于访问\jswdk-1.0.1\webpages\index.html。 用文本编辑器,如Windows中的记事本(Notepad),创建一个文本文件hi.jsp,保存在\jswdk-1.0.1\webpages\目录下,其内容如下:
<html>
<head>
<title>Hi-JSP实验</title>
</head>
<body>
<%
String Msg = "This JSP test.";
out.print("Hello World!");
%>
<h2><%=Msg%></h2>
</body>
</html> 在浏览器的地址栏中键入http://localhost:8080/hi.jsp,JSWDK中的Web服务器会执行JSP 文件中用<%以及%>括起来的Java程序语句,其中out.print是将文字输出到网页,语句<%= 变量 | 表达式 %>的作用是将Java Scriptlet中变量或表达式的值输出到网页,执行结果如图1。 图1 将变量Msg赋值为中文字符串,用<%= %>输出,或者用out.print输出中文字符串,则在英文版NT4及Redhat 6.1下实验运行结果正常,而在中文NT 4.0和中文98下,则反而会出现乱码。
四、 统一的网站界面 JSP支持服务器端的文件包含,即可以在一个JSP文件中插入多个其他文件,用来实现统一的网站界面。修改上述hi.jsp并另存为mypage.jsp:
<%@ include file="top.htm" %>
<%
String Msg = "This JSP test.";
out.print("Hello World!");
%>
<h2><%=Msg%></h2>
<%@ include file="bot.htm" %> 用可视化HTML编辑器,例如FrontPage、Dreamweave等设计网站的框架结构,将设计好的框架结构文件分割成两个部分,上面一半保存为top.htm, 下面一半保存为bot.htm,代码如下面所示:
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>我的主页</title>
</head>
<body>
<table border="0" width="100%" cellpadding="4" cellspacing="0" align="center">
<tr>
<td width="100%" colspan="2" bgcolor="#837ED1" align="center"><font face="隶书"
color="#FFFF00" size=5>主页标题</font>
</td>
</tr>
<tr>
<td bgcolor="#837ED1" width="15%" valign="top" align="center"><br>
<font color="#FFFFFF">选项</font><p><font color="#FFFFFF">选项</font></p>
<p><font color="#FFFFFF">选项</font></p>
<p><font color="#FFFFFF">......</font></p>
<p> </p>
</td>
<td width="85%" valign="top">
----------------------------------------------------------------------------------------------------------------
</td>
</tr>
</table>
</body>
</html> 在浏览器的地址栏中键入http://localhost:8080/mypage.jsp,得到结果如图2。 图2 这样网站的界面就能统一起来,而设计者可以集中精力在功能模块上处理用户登录、连接数据库、发送email等等。每个JSP文件都有如下结构:
<%@ include file="top.htm" %>
<%
// 实现某些功能
%>
<%@ include file="bot.htm" %> 维护网站的界面也相对比较容易,只要修改top.htm和bot.htm,就能影响到所有网页。 五、 服务器参数设置
JSWDK的Web服务器参数保存在\jswdk-1.0.1\webserver.xml中,用Windows写字板打开并编辑这个文件就可以修改缺省设置值。本节内容主要针对JSWDK,Linux下Tomcat的设置方法略有不同。
JSWDK缺省的文档目录是\jswdk-1.0.1\webpages,在此目录下可以建立子目录,例如\jswdk-1.0.1\webpages\test,就能在浏览器中用http://localhost/test访问这个目录,为了使得这个子目录能执行JSP程序,还必须在webserver.xml中的<Service></Service>节加入:
<WebApplication id="test" mapping="/test" docBase="webpages/test" />
并且,还必须建立\jswdk-1.0.1\webpages\test\WEB-INF目录,并从\jswdk-1.0.1\webpages\WEB-INF目录中复制过来以下四个文件:mappings.properties、mime.properties、servlets.properties以及webapp.properties。完成这些过程,才能通知JSWDK的Web服务器执行http://localhost/test 中的JSP程序。 六、 JavaBean
JSP网页吸引人的地方之一就是能结合JavaBean技术来扩充网页中程序的功能。
JavaBean是一种Java类 (class),通过封装属性和方法成为具有某种功能或者处理某个业务的对象。JavaBean被组织成为package(数据包)以便进行管理,实际上就是把一组JavaBean一起放在某某目录中,每个类的定义前加上package某某,本例中为test。目录test必须放在系统环境CLASSPATH包含的目录下,系统才能找到其中的JavaBean。JSWDK在缺省状态下将\jswdk-1.0.1\webpages\WEB-INF\jsp\beans\ 加入CLASSPATH。建立自己的JavaBean和package时,就放在这个目录中也不失为一种简易的方法。
下面介绍一个简单的JavaBean框架。用文本编辑器创建一个文本文件helloWorld.java,并保存在\jswdk-1.0.1\webpages\WEB-INF\jsp\beans\test目录下,其内容如下:
package test;
public class helloWorld {
public String name = "My first bean";
public String getHi()
{
return "Hello from " + name;
}
} helloWorld.java编辑好后,在DOS状态下,进入目录\jswdk-1.0.1\webpages\WEB-INF\jsp\beans\,用JDK的javac命令编译helloWorld.java如下: javac helloWorld.java 注意,Java是区分大小写的,在程序中,编译命令行中字母的大小写都不能写错。
编译成功就表示建立了一个JavaBean。下面看如何在JSP中使用这个JavaBean。用文本编辑器创建一个文本文件hi-bean.jsp,并保存在\jswdk-1.0.1\webpages\test目录下,其内容如下: <html>
<head>
<title>JavaBean 试验</title>
</head>
<body>
<jsp:useBean id="helloBean" scope="session" class="test.helloWorld" />
<%= helloBean.getHi() %>
<hr>
<%
helloBean.name = "JSP";
out.print(helloBean.getHi());
%>
</body>
</html> 在JSP网页中,使用 <jsp:useBean ... />语法来创建JavaBean对象,并命名为helloBean。读者可从这个简单的例子中看出设置、获取JavaBean属性,以及调用JavaBean方法的做法。在浏览器的地址栏中键入http://localhost:8080/test/hi-bean.jsp,得到结果如图3所示。
注意,如果修改和重新编译了JavaBean程序,则需要关闭和重新启动JSWDK的Web服务器以后修改的结果才会有效。如果仅仅修改JSP文件,则不用重新启动JSWDK的Web服务器. 虽然,这仅仅完成了一个非常简单的JavaBean框架,但是遵循这个框架可以设计出多种多样的JavaBean。例如,从JSP中访问数据通常就是通过JavaBean来实现的。 七、 数据库连接
数据库连接对动态网站来说是最为重要的部分,Java中连接数据库的技术是JDBC(Java Database Connectivity)。很多数据库系统带有JDBC驱动程序,Java程序就通过JDBC驱动程序与数据库相连,执行查询、提取数据等等操作。Sun公司还开发了JDBC-ODBC bridge,用此技术Java程序就可以访问带有ODBC驱动程序的数据库,目前大多数数据库系统都带有ODBC驱动程序,所以Java程序能访问诸如Oracle、Sybase、MS SQL Server和MS Access等数据库。下面介绍如何用Access实现一个动态FAQ(常见问题及答案)网站。
首先建立一个Access数据库faq.mdb,其中的表faqs有字段id(自动增量型,并设为主关键字)、subject(文字型,长度200)、answers(备注型)。这个表中可以存放一些编程知识的常见问题及答案,如图4。
图 4 然后,在Control Panel(控制面板)的ODBC Datasource模块中加入System DSN,取名faq,并指向faq.mdb。
创建一个JavaBean,名为faq.java,并保存在\jswdk-1.0.1\webpages\WEB-INF\jsp\beans\test目录下。faq.java 的内容如下: package test;
import java.sql.*; public class faq {
String sDBDriver = "sun.jdbc.odbc.JdbcOdbcDriver";
String sConnStr = "jdbc:odbc:faq";
Connection conn = null;
ResultSet rs = null; public faq() {
try {
Class.forName(sDBDriver);
}
catch(java.lang.ClassNotFoundException e) {
System.err.println("faq(): " + e.getMessage());
}
} public ResultSet executeQuery(String sql) {
rs = null;
try {
conn = DriverManager.getConnection(sConnStr);
Statement stmt = conn.createStatement();
rs = stmt.executeQuery(sql);
}
catch(SQLException ex) {
System.err.println("aq.executeQuery: " + ex.getMessage());
}
return rs;
}
}
用上一节介绍的方法编译faq.java以后,在\jswdk-1.0.1\webpages\test目录下创建JSP文件faq.jsp,其内容如下: <html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>我的FAQ !</title>
</head>
<body>
<p><b>这是我的FAQ!</b></p>
<%@ page language="java" import="java.sql.*" %>
<jsp:useBean id="workM" scope="page" class="test.faq" />
<%
ResultSet RS = workM.executeQuery("SELECT * FROM faqs");
String tt;
while (RS.next()) {
tt = RS.getString("Answer");
out.print("<LI>" + RS.getString("Subject") + "</LI>");
out.print("<pre>" + tt + "</pre>");
}
RS.close();
%>
在浏览器的地址栏中键入http://localhost:8080/test/faq.jsp,faq.jsp调用JavaBean,从数据库中读出内容并输出,得到结果如图5所示. 限于篇幅,本文不能列举JSP-JavaBean-JDBC/ODBC-数据库的复杂例子,读者可以从本文最后所推荐的网址中找到并下载到数据库连接范例。