通信過程包括下述兩個方面:
2.1 Applet對Servlet的訪問及參數傳遞的實現
2.1.1創建URL對象
在JAVA程序中,可以利用如下的形式創建URL對象
URL servletURL = new URL( "http://localhost:8080/servlet/dbServlet.DbServlet" );
2.1.2 與URL地址建立連接
在成功的創建了URL對象之后,可以調用URL類中的openConnection()函數來建立連接。openConnection()函數在建立連接的同時,進行通信連接的初始化工作。
URLConnection servletConnection = servletURL.openConnection();
2.1.3 利用URLConnection對象進行讀寫操作
2.1.3.1 利用URLConnection對象讀取Servlet返回的信息
在獲得URLConnection對象之后,如果Servlet向Applet傳送的是JAVA對象,則可以利用URLConnection對象的openStream()方法獲得輸入流,然后新生成一個ObjectInputStream對象,利用ObjectInputStream對象的readObject()方法即可得到Servlet傳回的JAVA對象。
ResultSet rs = null; // Temporary storage for the data.
URL servletURL = null; // The URL to the servlet.
URLConnection servletConnection = null; // The connection to the servlet.
ObjectInputStream dbStream = null; // The stream from the servlet.
try
{
servletURL = new URL( "http://localhost:8080/servlet/dbServlet.DbServlet" );
servletConnection = servletURL.openConnection();
dbStream = new ObjectInputStream( servletURL.openStream() );
// Read an object from the servlet stream and cast it to a DataSetData
// object.
data = (ResultSet) dbStream.readObject();
}
catch( Exception e )
{
。。。
}
如果Servlet向Applet傳送的是普通的文本,則可以利用URLConnection對象的getInputStream()方法獲得輸入流,然后新生成一個DataInputStream對象,利用DataInputStream對象的readLine()方法依次取得Servlet傳回的文本。
DataInputStream dbStream = new DataInputStream ( servletURL.getInputStream() );
// Read text from the servlet stream line by line.
While((inputLine= dbStream.readLine())!=null)
{
??????.
}
2.3.1.2利用URLConnection對象對Servlet的傳值操作
Applet向Servlet的有關參數傳遞,可以通過下面兩種方法實現:
可以通過在URL地址后附加參數以GET的方式實現參數的傳遞:
servletURL = new URL( "http://localhost:8080/servlet/dbServlet.DbServlet?sql=select * from hklhzsj where total>100" );
另一種方法是從URLConnection連接獲得輸出流,這個輸出流被連接到公共網關程序的(服務器端)的標準輸入流上,然后把要傳送的有關數據寫入輸出流,發送完畢關閉輸出流。
servletConnection.setDoOutput(true);
PrintStream outStream=new PrintStream(servletURL.openConnection());
outStream.println(“sql=select * from hklhzsj where total>100”);
outStream.close();
2.2 Servlet向Applet的數據傳遞的實現
可以通過Servlet對象的request參數的getParameter()獲得Applet傳遞過來的參數:String sql=request.getParameter("sql");
通過Servlet對象的request參數的getOutputStream()所得到的輸出流新生成一個對象輸出流ObjectOutputStream類型的對象,然后通過該對象的writeObject()方法輸出JAVA類型的對象。
Class.forName(“sun:jdbc:odbcdriver”);
Connection conn =DriverManager.getConnection(connetionString)
Statement st=conn.createStatement()
ResultSet rs=st.execute(sql)
dbStream = new ObjectOutputStream( response.getOutputStream() );
// Write the object...
dbStream.writeObject(rs );
通過request參數的getWriter ()方法得到PrintWriter類型的輸出,通過此對象的println()方法可以從Servlet想Applet輸出文本:
PrintWriter out = response.getWriter();
out.println("<head><title>DataCenter</title></head>");
通過上面的分析我們通過Servlet 實現了對非宿主機上的數據庫的訪問,Servlet 與Applet通信提供了語言級別上的互相傳遞JAVA對象的便利,我們同樣可以利用Applet通過CGI對各種服務器端的CGI程序或其它腳本應用程序(如ASP、JSP等)提供訪問,以文本的方式實現通信。