




已阅读5页,还剩69页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
第7章 java 数据库编程和网络编程,7.1 关系数据库简介 7.2 JDBC概述 7.3 连接数据库 7.4 网络编程,7.1 关系数据库简介,关系数据库系统的思想是由IBM公司的E.F.Codd于1970年率先提出的。 关系数据库支持的数据模型是关系模型。关系模型的基本条件是其关系模式中每个属性值必须是一个不可分割的数据量。简单地说,在关系数据库中数据结构一般是张两维表,这张两维表的每一列的值必须是不可分割的数据项,而任两行应互不相同。 关系模型的主要特点是: 结构简单,表示力强,易于掌握。 语言一体化,非过程化的操作,方便用户使用。 有一定的数学理论作基础,利于进一步研究和发展。 操作耗时,执行效率低。 关系数据库管理系统一般向用户提供数据检索、数据插入、数据删除、数据修改四种基本操作功能。,返回,7.2 JDBC概述,使用JDBC连接数据库 JDBC(Java data Base Connectivity)是Java语言为了支持SQL功能而提供的与数据库相联的用户接口,JDBC中包括了一组由Java语言书写的接口和类,它们都是独立于特定的DBMS,或者说它们可以和各种数据相关联。有了JDBC以后,程序员可以方便地在Java语言中使用SQL语言,从而使Java应用程序或Java applet可以实现对分布在网络上的各种关系数据库的访问。使用了JDBC以后,程序员可以将精力集中于上层的功能实现,而不必关心底层与具体的DBMS的连接和访问过程。,下一页,返回,7.2 JDBC概述,JDBC由一组Java语言编写的类和接口组成,使用内嵌式的SQL,主要实现三方面的功能:建立与数据库的连接,执行SQL声明以及处理SQL执行结果。JDBC支持基本的SQL功能,使用它可方便地与不同的关系型数据库建立连接,进行相关操作,并无需再为不同的DBMS分别编写程序。下面我们先介绍JDBC与SQL及ODBC的关系,再介绍JDBC支持的两种模型,最后介绍JDBC的抽象接口和数据库驱动器Driver。,上一页,下一页,返回,7.2 JDBC概述,7.2.1 JDBC与SQL 尽管一般数据库系统在很大范围内支持SQL的语义语法,但它们在复杂的高层次功能如存储功能调用和外部连接等方面往往不尽一致。为了解决这一矛盾,JDBC采用以下的几种措施: (1)JDBC允许使用从属于DBMS的系统的任何询问语句,这些询问语句都将被传送给后台的DBMS实际执行。这样增加了使用的灵活性,一个应用程序的询问可以不是SQL形式的,而是SQL的特定引出形式,如为特定的DBMS提供的文件或图片查询。这样做的风险则在某些DBMS中可以会出现错误。,上一页,下一页,返回,7.2 JDBC概述,(2)一般认为ANSI SQL Entry Level的功能比较完备,而且是被广泛支持的。因此为了使JDBC与SQL一致,要求用户使用至少ANSI SQL 92 Entry Level以上的版本,这样就给那些要求广泛的可携带性的应用程序提供了共同命名的保证。 (3)对较复杂的应用,JDBC提供了接口类DatabaseMetadata,用户可通过这个类获取相应DBMS的描述信息,再根据所得信息采取特定的查询操作方式。,上一页,下一页,返回,7.2 JDBC概述,7.2.2 JDBC与ODBC Microsoft的ODBC(Open DataBase Connectivity)是当前与关系型数据库连接最常用的接口。JDBC是建立在ODBC的基础上的,实际上可视为ODBD的Java语言翻译形式。当然两者都是建立在X/Open SQL CLI(Call Level Interface)的抽象定义之上的。而JDBC与ODBC相比,在使用上更为方便。 既然ODBC已经是成型的通用接口,我们可在Java程序中直接使用ODBC却要建立JDBC接口,这样做的原因和好处包括以下几点: (1)ODBC使用的是C语言界面,而从Java直接调用C源码容易在安全性、健壮性和可移植性等方面产生问题,运行功效也受到影响。,上一页,下一页,返回,7.2 JDBC概述,(2)将ODBC的C语言API逐字译为Java也并不理想。比如,Java没有指针,ODBC的一种面向对象式的翻译界面,对Java的程序员来说更为自然方便。 (3)ODBC难于学习掌握,经常将简单的特性与复杂的特性混合使用。而JDBC相对简单明了许多,容易理解掌握。 (4)JDBC有助于实现“纯Java“的方案。当使用ODBC时,每一台客户机都要求装入ODBC的驱动器和管理器。而当使用JDBC,驱动器完全由Java语言编写时,JDBC代码可以在所有的Java平台上自动装入、移植,而且是安全的。 当然,在JDBC也可以使用ODBC,但是要通过中介JDBC-ODBC Bridge使用。,上一页,下一页,返回,7.2 JDBC概述,7.2.3 JDBC支持的两种模型 在与数据库的连接操作中,JDBC支持两种不同的模型。这两川模型根据用户与数据库的关系层次不同,分别称为两模型和三层模型。 两层模型中,Java的应用程序(Applet或Application)直接与数据库联系。用户的SQL声明被提交给数据库,执行的结果回送给用户,如下图所示。这种模型具有客户机/服务器结构,用户的机器如同客户机,存放数据库的机器则如同服务器,连接两者的可以是局域网,也可以是广域网。,上一页,下一页,返回,7.2 JDBC概述,在三层模型中,用户不直接与数据库联系。用户的命令首先发送给一个所谓“中间层”,中间层再将SQL声明发给DMBS。执行的结果也同样由中间层转交。三层模型的好处是,可以通过中间层保持对存取权限和公有数据允许修改类型的控制,便于安全管理。同时,用户可以使用一种较为友善的高层API,由中间层转化为恰当的低层命令,保证较好地运行功效。到目前为止,中间层多用C或C+语言编写。随着Java语言的逐步推广,将出现用Java编写的中间层,更好地利用它的健壮性、多线程,安全性等特点。,上一页,下一页,返回,7.2 JDBC概述,7.2.4 JDBC的抽象接口 JDBC中最重要的部分是定义了一系列的抽象接口,通过这些接口,JDBC实现了三个基本的功能:建立与数据的连接、执行SQL声明和处理执行结果。 这些接口都存在Java的sql包中,它们的名称和基本功能是: *java.sql.DriverMagnager 管理驱动器,支持驱动器与数据连接的创建。 *java.sql.Connection 代表与某一数据库的连接,支持SQL声明的创建。 *java.sql.Statement,上一页,下一页,返回,7.2 JDBC概述,在连接中执行一静态的SQL声明并取得执行结果。 *java.sql.PreparedStatement Statement的子类,代表预编译的SQL声明。 *java.sql.CallableStatement Statement的子类,代表SQL的存储过程。 java.sql.ResultSet 代表执行SQL声明后产生的数据结果。,上一页,下一页,返回,7.2 JDBC概述,7.2.5 JDBC的数据库驱动器Driver Java的应用程序员通过sql包中定义的一系列抽象类对数据库进行操作,而实现这些抽象类,实际完成操作,则是由数据库驱动器Driver运行的。 JDBC的Driver可分为以下四种类型: (1)JDBC-ODBC Bridge和ODBC Driver 这种驱动器器通过ODBC驱动器提供数据库连接。使用这种驱动器,要求每一台客户机都装入ODBC的驱动器。,上一页,下一页,返回,7.2 JDBC概述,(2)Native-API partly-Java Driver 这种驱动器将JDBC指令转化成所连接使用的DBMS的操作形式。各客户机使用的数据库可能是Oracle,可能是Sybase,也可能是Access,都需要在客户机上装有相应DBMS的驱动程序。 (3)JDBC-Net All-Java Driver 这种驱动器将JDBC指令转化成独立于DBMS的网络协议形式,再由服务器转化为特定DBMS的协议形式。有关DBMS的协议由各数据库厂商决定。这种驱动器可以联接到不同的数据库上,最为灵活。目前一些厂商已经开始添加JDBC的这种驱动器到他们已有的数据库中介产品中。要注意的是,为了支持广域网存取,需要增加有关安全性的措施,如防火墙等等。,上一页,下一页,返回,7.2 JDBC概述,(4)Native-protocol All-Java Driver 这种驱动器将JDBC指令转化成网络协议后不再转换,由DBMS直接使用。相当于客户机直接与服务器联系,对局域网适用。 在这四种驱动器中,后两类“纯Java”(All-Java)的驱动器效率更高,也更具有通用性。但目前第一、第二类驱动器比较容易获得,使用也较普遍。,上一页,返回,7.3 连接数据库,7.3.1 建立数据源 一、建立数据库: Access,简单而实用的数据库(初学者的最爱) 学习目的:学会ACCEES数据库的使用,并针对上例建立一个数据库文件和数据表。 首先,一定要在你的系统中安装OFFICE的ACCEES;)甭管是哪个版本的,安装过程这里就不说了; 然后,新建数据库文件,命名为myDB.mdb; 二、建立数据源: 控制面板-管理工具-数据源(ODBC)(这个很重要,也很简单),下一页,返回,7.3 连接数据库,三、数据库编程的一般过程: 1. 加载驱动程序: Class.forName( “sun.jdbc.odbc.JdbcOdbcDriver“ ) 2. 连接数据库: Connection conn=DriverManager. getConnection(“ jdbc:odbc:myDB“, “sn“, “1234“ ) 其中:sn表示用户标识,1234表示用户密码。也可以不用后面的用户标识及密码,这主要取决于你的数据库是否用密码。 3. 执行SQL: 建立SQL语句变量: Statement stmt=conn.CreateStatement( ),上一页,下一页,返回,7.3 连接数据库,要执行查询数据库的SELECT语句,可以通过executeQuery语句来实现;要执行插入记录、删除记录、更改记录的SQL语句,可以通过executeUpdate语句来实现。 执行executeQuery语句,查询结果存放在ResultSet对象中。 4. 关闭连接: 对数据库操作完成后,应该将与数据库的连接关闭。 conn.close( ) 如果执行了SQL语句,还应该将SQL语句变量关闭。同样,如果执行的是查询语句,执行之后,还应该关闭结果集。 stmt.close( ) rs.close( ),上一页,下一页,返回,7.3 连接数据库,7.3.2具体示例: 首先介绍一些类及其子类: Statement类及其子类 1)Statement接口 Statement stmt=con.createStatement(); /执行SQL声明 int count1=stmt.executeUpdate(“INSERT INTO testTable(id,name) VALUES(1,wu)“); int count2=stmt.executeUpdate(“INSERT INTO testTable(id,name) VALUES(2,wang)“); 2)PreparedStatement接口 String data=“5“,“xu“,“6“,“yan“; PreparedStatement pstmt=con.prepareStatement(“INSERT INTO testTable (id,name) VALUES(?,?)“); /参数赋值,执行SQL声明,上一页,下一页,返回,7.3 连接数据库,for (int i=0;idata.length;i+) pstmt.setInt(1,Integer.parseInt(datai0); pstmt.setString(2,datai1); pstmt.executeUpdate(); 3)CallableStatement接口 CallableStatement cstmt=con.prepareCall(“call Search(?)“); /参数赋值 cstmt.setInt(1,934678); /执行储存过程。 cstmt.execute(); 结果集ResultSet及ResultSetMetaData String query = “SELECT * FROM testTable“; Statement stmt=con.createStatement(); /发出查询要求,获得结果集,上一页,下一页,返回,7.3 连接数据库,ResultSet rs=stmt.executeQuery(query); /显示结果集各行各列 System.out.println(“The detail of testTable is:“); ResultSetMetaData rsmd=rs.getMetaData(); /获得结果集列数 in numCols=rsmd.getColumnCount(); /显示列标题,上一页,下一页,返回,7.3 连接数据库,for(int i=1;i1) System.out.print(“,“); System.out.print(rsmd.getColumnLabel(i); System.out.println(“); /显示结果集信息 while(rs.next() /显示一行 for(int i=1;i1) System.out.print(“,“); System.out.print(rs.getString(i); ,上一页,下一页,返回,7.3 连接数据库,DatabaseMetaData DatabaseMetaData dma = con.getMetaData(); /驱动器和URL信息 System.out.println(“nConnected to“ + dma.getURL(); System.out.println(“Driver“ + dma.getDriverName(); System.out.println(“Version“ + dma.getDriverVersion(); /数据库信息 System.out.println(“nDataBase name:“ + dma.getDatabaseProductName()+dma.getDatabaseProductVersion(); System.out.println(“DataBase supports SQL keywords:nt“ + dma.getSQLKeywords(); /数据库功能信息函数,上一页,下一页,返回,7.3 连接数据库,dma.supportsANSI92EntryLevelSQL() dma.supportsANSI92FullSQL() dma.supportsStoredProcedures() 1. 查询数据库: import java.sql.*; class Query public static void main(String args) try Class.forName(“sun.jdbc.odbc.JdbcOdbcDriver“); catch(ClassNotFoundException ce) System.out.println(“SQLException:“+ce.getMessage(); ,上一页,下一页,返回,7.3 连接数据库,try Connection con=DriverManager.getConnection( “jdbc:odbc:myDB“,“sn“,“1234“); Statement stmt=con.createStatement(); ResultSet rs =stmt.executeQuery(“select * from employee“); while(rs.next() System.out.println(“编号 “+rs.getString(1)+“t“+ “姓名,上一页,下一页,返回,7.3 连接数据库,“+rs.getString(2)+“t“+ “性别 “+rs.getString(3)+“t“+ “工资 “+rs.getFloat(4); rs.close(); stmt.close(); con.close(); catch(SQLException e) System.out.println(“SQLException:“+e.getMessage(); ,上一页,下一页,返回,7.3 连接数据库,注意:在rs.getString(i)中的i表示第几个字段,java编译器会自动在数据库字段进行编号,如姓名字段在数据库中是第二个字段,则rs.getString(i)中的i应为2。 2. 插入记录:import java.sql.*; class Insert1 public static void main(String args) try Class.forName(“sun.jdbc.odbc.JdbcOdbcDriver“); catch(ClassNotFoundException ce) System.out.println(“SQLException:“+ce.getMessage(); ,上一页,下一页,返回,7.3 连接数据库,try Connection con=DriverManager.getConnection( “jdbc:odbc:myDB“,“sn“,“1234“); Statement stmt=con.createStatement(); String sqlstr=“insert into employee values(2001,邢雪花,女,650)“; stmt.executeUpdate(sqlstr);,上一页,下一页,返回,7.3 连接数据库,stmt.executeUpdate(“insert into employee values(2020,翟建设,男,746)“); stmt.close(); con.close(); catch(SQLException e) System.out.println(“SQLException:“+e.getMessage(); ,上一页,下一页,返回,7.3 连接数据库,3. 修改记录: import java.sql.*; class Update1 public static void main(String args) try Class.forName(“sun.jdbc.odbc.JdbcOdbcDriver“); catch(ClassNotFoundException ce) System.out.println(“SQLException:“+ce.getMessage(); try Connection con=DriverManager.getConnection(,上一页,下一页,返回,7.3 连接数据库,“jdbc:odbc:myDB“,“sn“,“1234“); Statement stmt=con.createStatement(); String sqlstr=“update employee set no=3001 “+“where name=翟建设“; stmt.executeUpdate(sqlstr); stmt.executeUpdate(“update employee set salary=600 “+“where sex=男“); stmt.close(); con.close(); catch(SQLException e) System.out.println(“SQLException:“+e.getMessage(); ,上一页,下一页,返回,7.3 连接数据库,4. 删除记录: import java.sql.*; class Delete public static void main(String args) try Class.forName(“sun.jdbc.odbc.JdbcOdbcDriver“); catch(ClassNotFoundException ce) System.out.println(“SQLException:“+ce.getMessage(); ,上一页,下一页,返回,7.3 连接数据库,try Connection con=DriverManager.getConnection( “jdbc:odbc:myDB“,“sn“,“1234“); Statement stmt=con.createStatement(); String sqlstr=“delete from employee where name=邢雪花“; stmt.executeUpdate(sqlstr); stmt.close(); con.close(); ,上一页,下一页,返回,7.3 连接数据库,catch(SQLException e) System.out.println(“SQLException:“+e.getMessage(); 5. 建立表: import java.sql.*; class Create public static void main(String args) try Class.forName(“sun.jdbc.odbc.JdbcOdbcDriver“); ,上一页,下一页,返回,7.3 连接数据库,catch(ClassNotFoundException ce) System.out.println(“SQLException:“+ce.getMessage(); try Connection con=DriverManager.getConnection( “jdbc:odbc:myDB“,“sn“,“1234“); Statement stmt=con.createStatement(); String sqlstr=“create table student( s_num char(4),s_name char(6) null,score int)“; stmt.executeUpdate(sqlstr); stmt.executeUpdate(“insert into student values(9901,张学军,85)“);,上一页,下一页,返回,7.3 连接数据库,stmt.close(); con.close(); catch(SQLException e) System.out.println(“SQLException:“+e.getMessage(); 6. 删除表: import java.sql.*; class Drop public static void main(String args) try Class.forName(“sun.jdbc.odbc.JdbcOdbcDriver“); ,上一页,下一页,返回,7.3 连接数据库,catch(ClassNotFoundException ce) System.out.println(“SQLException:“+ce.getMessage(); try Connection con=DriverManager.getConnection( “jdbc:odbc:myDB“,“sn“,“1234“); Statement stmt=con.createStatement(); String sqlstr=“drop table student“; stmt.executeUpdate(sqlstr); stmt.close(); con.close(); ,上一页,下一页,返回,7.3 连接数据库,catch(SQLException e) System.out.println(“SQLException:“+e.getMessage(); 7. 取表中各栏名称: import java.sql.*; class Meta public static void main(String args) try Class.forName(“sun.jdbc.odbc.JdbcOdbcDriver“); catch(ClassNotFoundException ce) System.out.println(“SQLException:“+ce.getMessage(); ,上一页,下一页,返回,7.3 连接数据库,try Connection con=DriverManager.getConnection( “jdbc:odbc:myDB“,“sn“,“1234“); Statement stmt=con.createStatement(); ResultSet rs=stmt.executeQuery( “select * from employee“); ResultSetMetaData rsmd=rs.getMetaData(); for(int i=1;i=rsmd.getColumnCount();i+),上一页,下一页,返回,7.3 连接数据库,if(i=1) System.out.print(rsmd.getColumnName(i); else System.out.print(“,“+rsmd.getColumnName(i); System.out.println(); rs.close(); stmt.close(); con.close(); catch(SQLException e) System.out.println(“SQLException:“+e.getMessage(); ,上一页,返回,7.4 网络编程,7.4.1 Java网络基础知识 Java获得迅速推广的一个重要原因就在于强大的网络能力,利用网络类,Java程序能够方便地访问Internet和WroldWide Web上的资源。接人Internet的计算机相互之间的通信要么采用TCP协议要么采用UDP协议,这些是较低层次的协议。当你编写Java网络程序时,是基于应用层的,不需要考虑那些复杂的底层协议。javanet类库包含了你所需要的各种网络类,使用它们就可以编写出基于TCP或UDP协议的网络程序。 但为了正确使用网络类,你还是应该了解TCP和UDP的区别。,下一页,返回,7.4 网络编程,传输控制协议TCP(transmission control protoc01)是一个基于连接的协议,可在两台相连计算机之间提供可靠的数据流。当两台计算机要传输信息时,需要建立一个可靠的连接以便发送和接收。这个过程和两个人打电话类似,TCP就像电话局一样,保证一方发出的数据按顺序到达另一方。 目前流行的HTTP、FTP、Telnet都是基于这种点对点通信的TCP协议。 用户数据报协议UDP(user datagram protocol)是一个五连接的、发送独立数据包 (即数据报)的协议,它不保证数据的正确到达。这个过程和通过邮局发信类似,每封信的内容是独立的,既不保证收信方按顺序收到信件,也不保证收信方一定能收到信件。,上一页,下一页,返回,7.4 网络编程,一般来讲,计算机只有一个物理通道连接到网络,所有数据都由这个通道进出。但这些数据可能是计算机上的不同应用程序所需要的,怎样区别它们呢?用端口区分。Internet传输的数据都带有地址,包含了计算机和端口信息。计算机以32bit IP地址表示,端口用一个16bit数表示,TCP和UDP就是使用了这个端口数才能把数据发给正确的程序。基于连接的TCP协议,服务器会把一个套接字(Socket)和一个指定端口绑在一起,客户机连接到这个端口就可接收所有指向这个端口的数据。而基于数据报的UDP 协议,每个数据包都包含端口数,UDP可以指引它们到达正确的应用程序。,上一页,下一页,返回,7.4 网络编程,很多应用程序需要可靠的、按顺序的数据传输,也有的应用程序不需要,因此在设计网络程序时应正确选择网络类。URl、URLConnection、Socket和ServerSocket类是基于TCP协议的,而DatagramPacket、DatagramSocket和MulticastSocket类是基于UDP 协议的。 作为运用InetAddress.getByName()一个简单的例子,请考虑假设自己有一家拨号连接因特网服务提供者(ISP),那么会发生什么情况。每次拨号连接的时候,都会分配得到一个临时IP地址。但在连接期间,那个IP地址拥有与因特网上其他IP地址一样的有效性。如果有人按照你的IP地址连接你的机器,他们就有可能使用在你机器上运行的Web或者FTP服务器程序。当然这有个前提,对方必须准确地知道你目前分配到的IP。由于每次拨号连接获得的IP都是随机的,怎样才能准确地掌握你的IP呢?,上一页,下一页,返回,7.4 网络编程,下面这个程序利用InetAddress.getByName()来产生你的IP地址。为了让它运行起来,事先必须知道计算机的名字。该程序只在Windows 95中进行了测试,但大家可以依次进入自己的“开始”、“设置”、“控制面板”、“网络”,然后进入“标识”卡片。其中,“计算机名称”就是应在命令行输入的内容。 /: WhoAmI.java / Finds out your network address when youre / connected to the Internet. package c15; import .*;,上一页,下一页,返回,7.4 网络编程,public class WhoAmI public static void main(String args) throws Exception if(args.length != 1) System.err.println( “Usage: WhoAmI MachineName“); System.exit(1); InetAddress a = InetAddress.getByName(args0); System.out.println(a); /:,上一页,下一页,返回,7.4 网络编程,服务器和客户机网络最基本的精神就是让两台机器连接到一起,并相互“交谈”或者“沟通”。一旦两台机器都发现了对方,就可以展开一次令人愉快的双向对话。但它们怎样才能“发现”对方呢?这就象在游乐园里那样:一台机器不得不停留在一个地方,侦听其他机器说:“嘿,你在哪里呢?”“停留在一个地方”的机器叫作“服务器”(Server);到处“找人”的机器则叫作“客户机”(Client)或者“客户”。它们之间的区别只有在客户机试图同服务器连接的时候才显得非常明显。一旦连通,就变成了一种双向通信,谁来扮演服务器或者客户机便显得不那么重要了。所以服务器的主要任务是侦听建立连接的请求,这是由我们创建的特定服务器对象完成的。而客户机的任务是试着与一台服务器建立连接,这是由我们创建的特定客户机对象完成的。,上一页,下一页,返回,7.4 网络编程,一旦连接建好,那么无论在服务器端还是客户机端,连接只是魔术般地变成了一个IO数据流对象。从这时开始,我们可以象读写一个普通的文件那样对待连接。所以一旦建好连接,我们只需象第10章那样使用自己熟悉的IO命令即可。这正是Java连网最方便的一个地方。 在没有网络的前提下测试程序由于多种潜在的原因,我们可能没有一台客户机、服务器以及一个网络来测试自己做好的程序。我们也许是在一个课堂环境中进行练习,或者写出的是一个不十分可靠的网络应用,还能拿到网络上去。IP的设计者注意到了这个问题,并建立了一个特殊的地址localhost来满足非网络环境中的测试要求。在Java中产生这个地址最一般的做法是:InetAddress addr = InetAddress.getByName(null);,上一页,下一页,返回,7.4 网络编程,如果向getByName()传递一个null(空)值,就默认为使用localhost。我们用InetAddress对特定的机器进行索引,而且必须在进行进一步的操作之前得到这个InetAddress(互联网地址)。我们不可以操纵一个InetAddress的内容(但可把它打印出来,就象下一个例子要演示的那样)。创建InetAddress的唯一途径就是那个类的static(静态)成员方法getByName()(这是最常用的)、getAllByName()或者getLocalHost()。 为得到本地主机地址,亦可向其直接传递字串“localhost“:InetAddress.getByName(“localhost“);或者使用它的保留IP地址(四点形式),就象下面这样: InetAddress.getByName(““);这三种方法得到的结果是一样的。,上一页,下一页,返回,7.4 网络编程,7.4.2 URL 一、创建一个URL 为了表示URL, 中实现了类URL。我们可以通过下面的构造方法来初始化一个URL对象: (1) public URL (String spec); 通过一个表示URL地址的字符串可以构造一个URL对象。 URL urlBase=new URL(“http:/www. 263.net/“) (2) public URL(URL context, String spec); 通过基URL和相对URL构造一个URL对象。 URL net263=new URL (“/“); URL index263=new URL(net263, “index.html“),上一页,下一页,返回,7.4 网络编程,(3) public URL(String protocol, String host, String file); new URL(“http“, ““, “/pages/G. html“); (4) public URL(String protocol, String host, int port, String file); URL gamelan=new URL(“http“, ““, 80, “Pages/Gwork.html“); 注意:类URL的构造方法都声明抛弃非运行时例外(MalformedURLException),因此生成URL对象时,我们必须要对这一例外进行处理,通常是用try-catch语句进行捕获。格式如下:,上一页,下一页,返回,7.4 网络编程,try URL myURL= new URL() catch (MalformedURLException e) 二、解析一个URL 一个URL对象生成后,其属性是不能被改变的,但是我们可以通过类URL所提供的方法来获取这些属性:,上一页,下一页,返回,7.4 网络编程,public String getProtocol() 获取该URL的协议名。 public String getHost() 获取该URL的主机名。 public int getPort() 获取该URL的端口号,如果没有设置端口,返回-1。 public String getFile() 获取该URL的文件名。 public String getRef() 获取该URL在文件中的相对位置。 public String getQuery() 获取该URL的查询信息。 public String getPath() 获取该URL的路径,上一页,下一页,返回,7.4 网络编程,public String getAuthority() 获取该URL的权限信息 public String getUserInfo() 获得使用者的信息 public String getRef() 获得该URL的锚 三、从URL读取WWW网络资源 当我们得到一个URL对象后,就可以通过它读取指定的WWW资源。这时我们将使用URL的方法openStream(),其定义为: InputStream openStream(); 方法openSteam()与指定的URL建立连接并返回InputStream类的对象以从这一连接中读取数据。,上一页,下一页,返回,7.4 网络编程,public class URLReader public static void main(String args) throws Exception /声明抛出所有例外 URL tirc = new URL(“/“); /构建一URL对象 BufferedReader in = new BufferedReader(new InputStreamReader(tirc.openStream(); /使用openStream得到一输入流并由此构造一个BufferedReader对象,上一页,下一页,返回,7.4 网络编程,String inputLine; while (inputLine = in.readLine() != null) /从输入流不断的读数据,直到读完为止 System.out.println(inputLine); /把读入的数据打印到屏幕上 in.close(); /关闭输入流 ,上一页,下一页,返回,7.4 网络编程,四、通过URLConnetction连接WWW 通过URL的方法openStream(),我们只能从网络上读取数据,如果我们同时还想输出数据,例如向服务器端的CGI程序发送一些数据,我们必须先与URL建立连接,然后才能对其进行读写,这时就要用到类URLConnection了。CGI是公共网关接口(Common Gateway Interface)的简称,它是用户浏览器和服务器端的应用程序进行连接的接口,有关CGI程序设计,请读者参考有关书籍。,上一页,下一页,返回,7.4 网络编程,类URLConnection也在包中定义,它表示Java程序和URL在网络上的通信连接。当与一个URL建立连接时,首先要在一个URL对象上通过方法openConnection()生成对应的URLConnection对象。例如下面的程序段首先生成一个指向地址/index.shtml的对象,然后用openConnection()打开该URL对象上的一个连接,返回一个URLConnection对象。如果连接过程失败,将产生IOException. Try URL netchinaren = new URL (“/index.shtml“); URLConnectonn tc = netchinaren.openConnection(); catch(MalformedURLException e) /创建URL()对象失败 ,上一页,下一页,返回,7.4 网络编程,catch (IOException e) /openConnection()失败 类URLConnection提供了很多方法来设置或获取连接参数,程序设计时最常使用的是getInputStream()和getOurputStream(),其定义为: InputSteram getInputSteram(); OutputSteram getOutputStream();,上一页,下一页,返回,7.4 网络编程,通过返回的输入/输出流我们可以与远程对象进行通信。看下面的例子: URL url =new URL (“/cgi-bin/backwards“); /创建一URL对象 URLConnectin con=url.openConnection(); /由URL对象获取URLConnection对象 DataInputStream dis=new DataInputStream (con.getInputSteam(); /由URLConnection获取输入流,并构造DataInputStream对象 PrintStream ps=new PrintSteam(con.getOutupSteam(); /由URLConnection获取输出流,并构造PrintStream对象,上一页,下一页,返回,7.4 网络编程,String line=dis.readLine(); /从服务器读入一行 ps.println(“client“); /向服务器写出字符串 “client“ 其中backwards为服务器端的CGI程序。实际上,类URL的方法openSteam()是通过URLConnection来实现的。它等价于 openConnection().getInputStream(); 基于URL的网络编程在底层其实还是基于下面要讲的Socket接口的。WWW,FTP等标准化的网络服务都是基于TCP协议的,所以本质上讲URL编程也是基于TCP的一种应用.,上一页,下一页,返回,7.4 网络编程,7.4.4 套接字 “套接字”或者“插座”(Socket)也是一种软件形式的抽象,用于表达两台机器间一个连接的“终端”。针对一个特定的连接,每台机器上都有一个“套接字”,可以想象它们之间有一条虚拟的“线缆”。线缆的每一端都插入一个“套接字”或者“插座”里。当然,机器之间的物理性硬件以及电缆连接都是完全未知的。抽象的基本宗旨是让我们尽可能不必知道那些细节。,上一页,下一页,返回,7.4 网络编程,在Java中,我们创建一个套接字,用它建立与其他机器的连接。从套接字得到的结
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年福安市市直机关遴选考试笔试试题(含答案)
- 北京生物药品知识培训课件
- 2024河北省社区《网格员》典型题汇编及答案
- 电算化会计试题库含答案
- 2025年妇产科护理知识竞赛试题库及答案
- 树叶贴画花篮课件
- 标本制作基础知识培训总结
- 北京农村基础知识培训班课件
- 2025年“全国安全用药月”药品安全知识竞赛题目及答案
- 江苏合院别墅样板软装概念方案
- 计算机二级access选择题库及答案汇总
- 医院食堂管理方案计划书
- 大客户营销管理策略对提高客户满意度和忠诚度的影响
- 《螺纹的种类和应用》课件
- 医学一等奖《白血病》课件
- 高空作业车专项应急预案
- 发现普洱茶的第一个医学实验报告
- 全自动血液细胞分析仪参数
- (完整版)过去完成时ppt
- 1输变电工程施工质量验收统一表式(线路工程)
- 养老护理员(技师、高级技师)知识考试复习题库(含答案)
评论
0/150
提交评论