Servlet传送查询记录集给Applet

原创 2002年08月29日 17:12:00

   这篇文章是继<<Servlet传送对象给Applet使用>>后,征对网友的特殊问题写的又一个实例.
现发表出来与大家分享,文中瑕癖之处甚多,望各位指教.
 这个问题在csdn上已经有讨论了http://www.csdn.net/expert/topic/971/971710.xml.
具体的需求就不讲了,这里把我的实现步骤详细写下,与<<Servlet传送对象给Applet使用>>中提到的方法
一样.用到的CachedRowSet可以到
http://java.sun.com//Download4?userid=zlyperson&platform=zip&button=continue&config-file=rowset-1_0-ea4.config
去下.还有一个netscape的包,在C:/WINNT/java/Packages/0S0W0NFX.ZIP中.
我也把所需要的包及我的实现代码打成了包,其中包扩了CachedRowSet&netscape&本文.
http://63.210.240.215/rookieport/rowset.jar
下面给出全部代码和配置,其中Applet部分涵盖
了Javascript与Applet的互相调用,对于该部分不感兴趣的朋友可以复略.

<pre>
第一步,实现Servlet
package exapplet;
import java.io.*;
import java.sql.*;
import javax.sql.*;
import sun.jdbc.rowset.*;
import javax.servlet.*;
import javax.servlet.http.*;

public class MyServlet extends HttpServlet
{
 static {
  try {
   Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
  } catch (Exception e) {
   e.printStackTrace();
  }
 }

 public void doGet(HttpServletRequest req,HttpServletResponse res)
  throws ServletException,IOException
 {
  try {
   Connection dbconn = DriverManager.getConnection("jdbc:odbc:BlueSite");
   Statement stmt = dbconn.createStatement();
   String  dbsql = req.getParameter("DBSQL");
   ResultSet dbrest = stmt.executeQuery(dbsql);
   CachedRowSet crs = new CachedRowSet();
            crs.populate(dbrest);
            dbrest.close();
   stmt.close();
   dbconn.close();
   file://传回对象给Applet
   res.setContentType("application/octet-stream");
   ObjectOutputStream oos = new ObjectOutputStream(res.getOutputStream());
   oos.writeObject(crs);
   oos.close();
  } catch (Exception exp) {
   exp.printStackTrace();
  }
 }
 public String getServletInfo()
 {
  return "A simple Servlet!";
 }
}

第二步,实现提取对象的Applet
package exapplet;
import java.awt.*;
import java.applet.*;
import java.io.*;
import java.net.*;
import javax.sql.*;
import sun.jdbc.rowset.*;
import netscape.javascript.*;

public class MyAppletB extends java.applet.Applet
{
 public void init()
 {
 }
 public void paint(Graphics g)
 {}

 file://This method will be call in html
 public void invoke() {
  try {
   URL url = new URL("http://Liaoyuan:8080/WorkingRoom/exapplet/PostToApplet?DBSQL=Select%20TopicName,TopicName,TopicName%20from%20Topic");
   file://注意url中的空个用%20替代.
   
   URLConnection urlcon = url.openConnection();
   urlcon.connect();
   ObjectInputStream ois=new ObjectInputStream(urlcon.getInputStream());
   CachedRowSet crs = (CachedRowSet)ois.readObject();
   ois.close();
   while ( crs.next() ) {
    JSObject.getWindow(this).call("alert",new String[]{crs.getString(1)});
   }
   crs.close();
  } catch (Exception e) {
  }
 }
}

第三步,配制WebServer(我用的是Tomcat4.0)
拷贝编译后的MyServlet.class到相应目录下,或者下载我打的包到WEB-INF/lib下
编辑对应的web.xml文件,确保下面的内容正确
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.2//EN" "http://java.sun.com/j2ee/dtds/web-app_2_2.dtd">
<web-app>
 <servlet>
        <servlet-name>PostToApplet</servlet-name>
        <servlet-class>exapplet.MyServlet</servlet-class>
    </servlet>

 <servlet-mapping>
        <servlet-name>
            PostToApplet
        </servlet-name>
        <url-pattern>
            /exapplet/PostToApplet
        </url-pattern>
    </servlet-mapping>
</web-app>

第四步,编写html文件
提取对象的html
<HTML>
<HEAD>
<TITLE> New Document For Using Applet </TITLE>
</HEAD>

<BODY>
Hello This is a Test!<br>
<APPLET id="obj_applet" align=center code="exapplet.MyAppletB" codeBase="." width=400 height=300 name="obj_applet" archive="BV7RFD3P.ZIP"></APPLET>
<Input type=button value="CallAppletMethod" onclick="callApplet()">
<Script language=javascript>
function callApplet()
{
 obj_applet.invoke();
}
</Script>
</BODY>
</HTML>
</pre>
中间有错误的地方请指教,zlyperson@163.net

Servlet和Applet(Java小应用程序)相关知识!!!!------阿冬专栏

一、servlet  Servlet是用Java编写的Server端程序。Servlet运行于Java-enabled Web Server中。Java Servle...
  • zhangdong305
  • zhangdong305
  • 2015年06月04日 09:45
  • 2636

asp rs记录集recordset常用操作代码 详细

几乎每一个ASP数据库程序都要用到recordset,关于recordset的很多用法您都知道吗?下面介绍了一些经常用到的ASP RS记录集操作,包括添加、更新、修改、删除数据库内容等,并对一些关键的...
  • fearlessxjdx
  • fearlessxjdx
  • 2016年12月05日 20:45
  • 2587

<applet>和<object>标签的用法区别研究一

研究了半天和标签的用法,虽然还没弄太明白,但总算没有被XX认为的所误导。 对于标签 1.      APPLET CODE="HelloApplet.class" CODEBASE="D:/a...
  • chentracy2008
  • chentracy2008
  • 2013年04月10日 15:02
  • 1488

续上 编写Servlet查询数据库,列出员工信息列表

编写一个Servlet,通过JDBC连接MySQL数据库,在网页中显示数据库信息。 此部分续上一篇:使用JDBC添加员工信息。 后面的步骤为在原有项目基础上添加的。 Step1:新建一个Li...
  • dingding_12345
  • dingding_12345
  • 2015年08月12日 13:06
  • 3460

Java Applet 的运行原理

一、Java Applet的运行原理和生命周期          1.Applet被嵌入到HTML页面中,并由applet的容器(appletviewer或者Web浏览器)执行.       ...
  • z931284151
  • z931284151
  • 2015年10月13日 20:47
  • 973

Android客户端和Servlet服务端的JSON传输(注释详细到啰嗦的地步,欢迎新手学习)

记录一个Android客户端和Servlet服务端的JSON传输的小例子
  • u014704469
  • u014704469
  • 2014年08月01日 20:26
  • 1564

在浏览器中运行applet

用以下两个类定义了一个applet: import javax.swing.JApplet; public class VideoApplet extends JApplet{ public v...
  • l294265421
  • l294265421
  • 2015年06月19日 18:29
  • 2803

Java基础——GUI编程和Applet

33、GUI 概述 GUI(Graphical User interface)图形用户接口 用图形的方式,来显示计算机操作的界面,这样更方便,更直观 CLI(Command Line User Int...
  • dyonline2012
  • dyonline2012
  • 2013年07月14日 20:09
  • 1138

JAVA应用程序转换为Applet

本文是在学习中的总结,欢迎转载但请注明出处:http://blog.csdn.net/pistolove/article/details/41673295 将一个图形的JAVA应用程序转换为能够嵌入在...
  • pistolove
  • pistolove
  • 2014年12月02日 08:06
  • 1827

编写和运行简单的Applet程序

Applet是一种包含在HTML网页中的Java应用程序,下面简单总结一下如何用命令行编译并运行程序。   1、首先用记事本(UltraEdit等)编写一个简单的Applet程序,并命名为SayHel...
  • Crazy_For_Net
  • Crazy_For_Net
  • 2015年12月09日 17:39
  • 3071
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Servlet传送查询记录集给Applet
举报原因:
原因补充:

(最多只允许输入30个字)