按键盘上方向键 ← 或 → 可快速上下翻页,按键盘上的 Enter 键可回到本书目录页,按键盘上方向键 ↑ 可回到本页顶部!
————未阅读完?加入书签已便下次继续阅读!
if(evt。target。equals(submit)) {
query = 〃〃;
ta。setText(〃〃);
// Encode the query from the field data:
for(int i = 0; i 《 t。length; i++)
query += 〃Field〃 + i + 〃=〃 +
URLEncoder。encode(
t'i'。getText()。trim()) +
〃&〃;
query += 〃submit=Submit〃;
// Send the name using CGI's POST process:
try {
URL u = new URL(
getDocumentBase(); 〃cgi…bin/POSTtest〃);
URLConnection urlc = u。openConnection();
urlc。setDoOutput(true);
urlc。setDoInput(true);
urlc。setAllowUserInteraction(false);
DataOutputStream server =
new DataOutputStream(
urlc。getOutputStream());
// Send the data
server。writeBytes(query);
server。close();
// Read and display the response。 You
// cannot use
// getAppletContext()。showDocument(u);
// to display the results as a Web page!
DataInputStream in =
575
…………………………………………………………Page 577……………………………………………………………
new DataInputStream(
urlc。getInputStream());
String s;
while((s = in。readLine()) != null) {
ta。appendText(s + 〃n〃);
}
in。close();
}
catch (Exception e) {
l。setText(e。toString());
}
}
else return super。action(evt; arg);
return true;
}
} ///:~
⑥:我不得不说自己并没有真正理解这儿都发生了什么事情,这些概念都是从Elliotte Rusty Harold 编著
的《Java Network Programming》里得来的,该书由O'Reilly 于 1997 年出版。他在书中提到了Java 连网函
数库中出现的许多令人迷惑的Bug。所以一旦涉足这些领域,事情就不是编写代码,然后让它自己运行那么
简单。一定要警惕潜在的陷阱!
信息发送到服务器后,我们调用getInputStream(),并把返回值封装到一个DataInputStream 里,以便自己
能读取结果。要注意的一件事情是结果以文本行的形式显示在一个TextArea (文本区域)中。为什么不简单
地使用 getAppletContext()。showDocument(u)呢?事实上,这正是那些陷阱中的一个。上述代码可以很好地
工作,但假如试图换用 showDocument(),几乎一切都会停止运行。也就是说,showDocument()确实可以运
行,但从POSTtest 得到的返回结果是“Zero CONTENT_LENGTH”(内容长度为零)。所以不知道为什么原
因,showDocument()阻止了 POST 查询向CGI 程序的传递。我很难判断这到底是一个在以后版本里会修复的
Bug,还是由于我的理解不够(我看过的书对此讲得都很模糊)。但无论在哪种情况下,只要能坚持在文本区
域里观看自 CGI 程序返回的内容,上述程序片运行时就没有问题。
15。7 用 JDBC 连接数据库
据估算,将近一半的软件开发都要涉及客户(机)/服务器方面的操作。Java 为自己保证的一项出色能力就
是构建与平台无关的客户机/服务器数据库应用。在Java 1。1 中,这一保证通过 Java 数据库连接(JDBC )
实现了。
数据库最主要的一个问题就是各家公司之间的规格大战。确实存在一种“标准”数据库语言,即“结构查询
语言”(SQL…92),但通常都必须确切知道自己要和哪家数据库公司打交道,否则极易出问题,尽管存在所
谓的“标准”。JDBC 是面向“与平台无关”设计的,所以在编程的时候不必关心自己要使用的是什么数据库
产品。然而,从JDBC 里仍有可能发出对某些数据库公司专用功能的调用,所以仍然不可任性妄为。
和Java 中的许多API 一样,JDBC 也做到了尽量的简化。我们发出的方法调用对应于从数据库收集数据时想
当然的做法:同数据库连接,创建一个语句并执行查询,然后处理结果集。
为实现这一“与平台无关”的特点,JDBC 为我们提供了一个“驱动程序管理器”,它能动态维护数据库查询
所需的所有驱动程序对象。所以假如要连接由三家公司开发的不同种类的数据库,就需要三个单独的驱动程
序对象。驱动程序对象会在装载时由“驱动程序管理器”自动注册,并可用Class。forName()强行装载。
为打开一个数据库,必须创建一个“数据库URL”,它要指定下述三方面的内容:
(1) 用“jdbc”指出要使用JDBC 。
(2) “子协议”:驱动程序的名字或者一种数据库连接机制的名称。由于JDBC 的设计从ODBC 吸收了许多灵
感,所以可以选用的第一种子协议就是“jdbc…odbc 桥”,它用“odbc”关键字即可指定。
(3) 数据库标识符:随使用的数据库驱动程序的不同而变化,但一般都提供了一个比较符合逻辑的名称,由
数据库管理软件映射(对应)到保存了数据表的一个物理目录。为使自己的数据库标识符具有任何含义,必
须用自己的数据库管理软件为自己喜欢的名字注册(注册的具体过程又随运行平台的不同而变化)。
所有这些信息都统一编译到一个字串里,即“数据库URL”。举个例子来说,若想通过ODBC 子协议同一个标
576
…………………………………………………………Page 578……………………………………………………………
识为“people”的数据库连接,相应的数据库URL 可设为:
String dbUrl = 〃jdbc:odbc:people〃
如果通过一个网络连接,数据库URL 也需要包含对远程机器进行标识的信息。
准备好同数据库连接后,可调用静态方法 DriverManager。getConnection(),将数据库的URL 以及进入那个
数据库所需的用户名密码传递给它。得到的返回结果是一个Connection 对象,利用它即可查询和操纵数据
库。
下面这个例子将打开一个联络信息数据库,并根据命令行提供的参数查询一个人的姓(Last Name)。它只选
择那些有 E…mail 地址的人的名字,然后列印出符合查询条件的所有人:
//: Lookup。java
// Looks up email addresses in a
// local database using JDBC
import java。sql。*;
public class Lookup {
public static void main(String'' args) {
String dbUrl = 〃jdbc:odbc:people〃;
String user = 〃〃;
String password = 〃〃;
try {
// Load the driver (registers itself)
Class。forName(
〃sun。jdbc。odbc。JdbcOdbcDriver〃);
Connection c = DriverManager。getConnection(
dbUrl; user; password);
Statement s = c。createStatement();
// SQL code:
ResultSet r =
s。executeQuery(
〃SELECT FIRST; LAST; EMAIL 〃 +
〃FROM people。csv people 〃 +
〃WHERE 〃 +
〃(LAST='〃 + args'0' + 〃') 〃 +
〃 AND (EMAIL Is Not Null) 〃 +
〃ORDER BY FIRST〃);
while(r。next