Java程序设计电子教案第七章

上传人:da****ge 文档编号:243096214 上传时间:2024-09-15 格式:PPT 页数:74 大小:393KB
返回 下载 相关 举报
Java程序设计电子教案第七章_第1页
第1页 / 共74页
Java程序设计电子教案第七章_第2页
第2页 / 共74页
Java程序设计电子教案第七章_第3页
第3页 / 共74页
点击查看更多>>
资源描述
,单击此处编辑母版标题样式,单击此处编辑母版文本样式,第二级,第三级,第四级,第五级,*,第,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,网络程序时,是基于应用层的,不需要考虑那些复杂的底层协议。,java,net,类库包含了你所需要的各种网络类,使用它们就可以编写出基于,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(127.0.0.1);,这三种方法得到的结果是一样的。,上一页,下一页,返回,7.4,网络编程,7.4.2 URL,一、创建一个,URL,为了表示,URL,,,中实现了类,URL,。我们可以通过下面的构造方法来初始化一个,URL,对象:,(,1,),public URL (String spec);,通过一个表示,URL,地址的字符串可以构造一个,URL,对象。,URL urlBase=new URL(http:/www. URL(URL context, String spec);,通过基,URL,和相对,URL,构造一个,URL,对象。,URL net263=new 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( 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,对象。例如下面的程序段首先生成一个指向地址, netchinaren = new URL ( 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 ( 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,中,我们创建一个套接字,用它建立与其他机器的连接。从套接字得到的结果是一个,InputStream,以及,OutputStream,(若使用恰当的转换器,则分别是,Reader,和,Writer,),以便将连接作为一个,IO,流对象对待。有两个基于数据流的套接字类:,ServerSocket,,服务器用它“侦听”进入的连接;以及,Socket,,客户用它初始一次连接。一旦客户(程序)申请建立一个套接字连接,,ServerSocket,就会返回(通过,accept(),方法)一个对应的服务器端套接字,以便进行直接通信。从此时起,我们就得到了真正的“套接字套接字”连接,可以用同样的方式对待连接的两端,因为它们本来就是相同的!此时可以利用,getInputStream(),以及,getOutputStream(),从每个套接字产生对应的,InputStream,和,OutputStream,对象。这些数据流必须封装到缓冲区内。可按第,10,章介绍的方法对类进行格式化,就象对待其他任何流对象那样。,上一页,下一页,返回,7.4,网络编程,对于,Java,库的命名机制,,ServerSocket,(服务器套接字)的使用无疑是容易产生混淆的又一个例证。大家可能认为,ServerSocket,最好叫作“,ServerConnector”,(服务器连接器),或者其他什么名字,只是不要在其中安插一个“,Socket”,。也可能以为,ServerSocket,和,Socket,都应从一些通用的基础类继承。事实上,这两种类确实包含了几个通用的方法,但还不够资格把它们赋给一个通用的基础类。相反,,ServerSocket,的主要任务是在那里耐心地等候其他机器同它连接,再返回一个实际的,Socket
展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 图纸专区 > 小学资料


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!