-- 作者:hongjunli
-- 发布时间:5/19/2007 10:27:00 AM
-- [图书推荐]Java网络编程精解
 china-pub: http://www.china-pub.com/computers/common/info.asp?id=33909 【内容简介】 Java语言是第一个完全融入网络的语言,Java语言之所以适合编写网络应用程序,归功于它的以下优势:. (1)Java语言与生俱来就是平台无关的。Java程序能够运行在不同的平台上,运行在不同平台上的Java程序能够方便的进行网络通信。 (2)Java语言具有完善的安全机制,可以对程序进行权限检查。这对网络程序至关重要。 (3)JDK类库提供了丰富的网络类库(如套节字API、JavaMail API和JDBC API等),大大简化了网络程序的开发过程。 本书将展示如何利用Java网络类库来快速便捷的创建网络应用程序,致力于完成以下任务: ·实现访问HTTP服务器的客户程序。 ·实现HTTP服务器。 ·实现多线程的服务器,以及非阻塞的服务器。.. ·解析并展示HTML页面。 ·通过JDBC API访问数据库。 ·通过JavaMail API接收和发送电子邮件。 ·利用RMI框架实现分布式的软件系统。 ·进行安全的网络通信,对数据加密,验证身份,保证数据的完整性。 ·利用CORBA和Web服务实现分布式的软件系统。 阅读本书,读者不仅可以掌握网络编程的实用技术,还可以进一步提高按照面向对象的思想来设计和编写Java软件的能力。本书适用于所有Java编程人员,包括Java初学者及资深Java开发人员。本书还可作为高校的Java教材,以及企业Java培训教材,也可作为Sun公司的SCJD认证的辅导教材。 本书的目录: 第1章 Java网络编程入门 1.1 进程之间的通信 1.2 计算机网络的概念 1.3 OSI参考模型 1.4 TCP/IP参考模型和TCP/IP协议 1.4.1 IP协议 1.4.2 TCP协议以及端口 1.4.3 RFC简介 1.4.4 客户/服务通信模式 1.5 用Java编写客户/服务器程序 1.5.1 创建EchoServer 1.5.2 创建EchoClient 1.6 小结 第2章 Socket用法详解 2.1 构造Socket 2.1.1 设定等待建立连结的超时时间 2.1.2 设定服务器的地址 2.1.3 设定客户端的地址 2.1.4 客户连结服务器时可能抛出的异常 2.2 获取Socket的信息 2.3 关闭Socket 2.4 半关闭Socket 2.5 设置Socket的选项 2.5.1 TCP_NODELAY选项 2.5.2 SO_RESUSEADDR选项 2.5.3 SO_TIMEOUT选项 2.5.4 SO_LINGER选项 2.5.5 SO_RCVBUF选项 2.5.6 SO_SNDBUF选项 2.5.7 SO_KEEPALIVE选项 2.5.8 OOBINLINE选项 2.5.9 服务类型选项 2.5.10 设定连结时间、延迟和带宽的相对重要性 2.6 发送邮件的SMTP客户程序 2.7 小节 第3章 ServerSocket用法详解 3.1 构造ServerSocket 3.1.1 绑定端口 3.1.2 设定客户连结请求队列的长度 3.1.3 设定绑定的IP地址 3.1.4 默认构造方法的作用 3.2 接收和关闭与客户的连结 3.3 关闭ServerSocket 3.4 获取ServerSocket的信息 3.5 ServerSocket选项 3.5.1 SO_TIMEOUT选项 3.5.2 SO_REUSEADDR选项 3.5.3 SO_RCVBUF选项 3.5.4 设定连结时间、延迟和带宽的相对重要性 3.6 创建多线程的服务器 3.6.1 为每个客户分配一个线程 3.6.2 创建线程池 3.6.3 使用JDK类库提供的线程池 3.6.4 使用线程池的注意事项 3.7 关闭服务器 3.8 小节 第4章 非阻塞通信 4.1 线程阻塞的概念 4.1.1 线程阻塞的原因 4.1.2 服务器程序用多线程处理阻塞通信的局限 4.1.3 非阻塞通信的基本思想 4.2 java.nio包中的主要类 4.2.1 缓冲区Buffer 4.2.2 字符编码Charset 4.2.3 通道Channel 4.2.4 SelectableChannel 4.2.5 ServerSocketChannel 4.2.6 SocketChannel 4.2.7 Selector 4.2.8 SelectionKey 4.3 服务器编程范例 4.3.1 创建阻塞的EchoServer 4.3.2 创建非阻塞的EchoServer 1.处理接收连接就绪事件 2.处理读就绪事件 3.处理写就绪事件 4.编码与解码 5.在非阻塞模式下确保发送一行数据 6.删除ByteBuffer中的已处理数据 4.3.3 在EchoServer中混合用阻塞模式与非阻塞模式 4.4 客户端编程范例 4.4.1 创建阻塞的EchoClient 4.4.2 创建非阻塞的EchoClient 4.4.3 创建非阻塞的PingClient 4.5 小节 第5章 创建非阻塞的HTTP服务器 5.1 HTTP协议简介 5.1.1 HTTP请求格式 1.请求方式、URI、HTTP协议的版本 2.请求头(Request Header) 3.请求正文(Request Content) 5.1.2 HTTP响应格式 1.HTTP协议的版本、状态代码、描述 2.响应头(Response Header) 3.响应正文(Response Content) 5.1.3 测试HTTP请求 5.2 创建非阻塞的HTTP服务器 5.2.1 服务器主程序:HttpServer类 5.2.2 具有自动增长的缓冲区的ChannelIO类 5.2.3 负责处理各种事件的Handler接口 5.2.4 负责处理接收连结就绪事件的AcceptHandler类 5.2.5 负责接收HTTP请求和发送HTTP响应的RequestHandler类 5.2.6 代表HTTP请求的Request类 5.2.7 代表HTTP响应的Response类 5.2.8 代表响应正文的Content接口及其实现类 5.2.9 运行HTTP服务器 5.3 小结 第6章 客户端协议处理框架 6.1 客户端协议处理框架的主要类 6.2 在客户程序中运用协议处理框架 6.2.1 URL类的用法 6.2.2 URLConnection类的用法 6.3 实现协议处理框架 6.3.1 创建EchoURLConnection类 6.3.2 创建EchoURLStreamHandler及工厂类 6.3.3 创建EchoContentHandler类及工厂类 6.3.4 在EchoClient类中运用ECHO协议处理框架 6.4 小节 第7章 用Swing组件展示HTML文档 7.1 在按钮等组件上展示HTML文档 7.2 用JEditorPane组件创建简单的浏览器 7.3 小节 第8章 基于UDP的数据报和套接字 8.1 UDP协议简介 8.2 DatagramPacket类 8.2.1 选择数据报的大小 8.2.2 读取和设置DatagramPacket的属性 8.2.3 数据格式的转换 8.2.4 重用DatagramPacket 8.3 DatagramSocket类 8.3.1 构造DatagramSocket 8.3.2 接收和发送数据报 8.3.3 管理连结 8.3.4 关闭DatagramSocket 8.3.5 DatagramSocket的选项 8.3.6 IP服务类型选项 8.4 DatagramChannel类 8.4.1 创建DatagramChannel 8.4.2 管理连接 8.4.3 用send()方法发送数据报 8.4.4 用receive()方法接收数据报 8.4.5 用write()方法发送数据报 8.4.6 用read()方法接收数据报 8.5 组播Socket 8.5.1 MulticastSocket类 8.5.2 组播Socket的范例 8.6 小节 第9章 对象的序列化与反序列化 9.1 JDK类库中的序列化API 9.2 实现Serializable接口 9.2.1 序列化对象图 9.2.2 控制序列化的行为 9.2.3 readResolve()方法在单例类中的运用 9.3 实现Externalizable接口 9.4 可序列化类的不同版本的序列化兼容性 9.5 小节 第10章 Java语言的反射机制 10.1 Java Reflection API简介 10.2 在远程方法调用中运用反射机制 10.3 代理模式 10.3.1 静态代理类 10.3.2 动态代理类 10.3.3 在远程方法调用中运用代理类 10.4 小节 第11章 RMI框架 11.1 RMI的基本原理 11.2 创建第一个RMI应用 11.2.1 创建远程接口 11.2.2 创建远程类 11.2.3 创建服务器程序 11.2.4 创建客户程序 11.2.5 运行RMI应用 11.3 远程对象工厂设计模式 11.4 远程方法中的参数与返回值传递 11.5 回调客户端的远程对象 11.6 远程对象的并发访问 11.7 分布式垃圾收集 11.8 远程对象的equals()、hashCode()和clone()方法 11.9 使用安全管理器 11.10 RMI应用的部署以及类的动态加载 11.11 远程激活 11.12 小节 第12章 通过JDBC API访问数据库 12.1 JDBC的实现原理 12.2 安装和配置MySQL数据库 12.3 JDBC API简介 1. Driver接口和DriverManager类 2. Connection接口 3. Statement接口 4. PreparedStatement接口 5. ResultSet接口 12.4 JDBC API的基本用法 12.4.1 处理字符编码的转换 12.4.2 把连接数据库的各种属性放在配置文件中 12.4.3 管理Connection、Statement和ResultSet对象的生命周期 12.4.4 执行SQL脚本文件 12.4.5 处理SQLException 12.4.6 输出JDBC日志 12.4.7 获得新插入记录的主键值 12.4.8 设置批量抓取属性 12.4.9 检测驱动器使用的JDBC版本 12.4.10 元数据 12.5 可滚动以及可更新的结果集 12.6 行集 12.7 调用存储过程 12.8 处理Blob和Clob类型数据 12.9 控制事务 12.9.1 事务的概念 12.9.2 声明事务边界的概念 12.9.3 在mysql.exe程序中声明事务 1. 在自动提交模式下运行事务 2.在手工提交模式下运行事务 12.9.4 通过JDBC API声明事务边界 12.9.5 保存点 12.9.6 批量更新 12.9.7 设置事务隔离级别 12.10 数据库连结池 12.10.1 创建连结池 12.10.2 DataSource数据源 12.11 小节 1.选择合适的JDBC驱动器 2.优化数据库连结 3.控制事务 4.优化Statement 5.优化ResultSet 6.及时释放无用的资源 第13章 基于MVC和RMI的分布式应用 13.1 MVC设计模式简介 13.2 store应用简介 13.3 创建视图 13.4 创建控制器 13.5 创建模型 13.6 创建独立应用 13.7 创建分布式应用 13.8 小节 第14章 通过JavaMail API收发邮件 14.1 E-mail协议简介 14.1.1 SMTP简单邮件传输协议 14.1.2 POP3邮局协议 14.1.3 接收邮件的新协议IMAP 14.1.4 MIME简介 14.2 JavaMail API简介 14.3 建立JavaMail应用程序的开发环境 14.3.1 获得JavaMail API的类库 14.3.2 安装和配置邮件服务器 14.4 创建JavaMail应用程序 14.5 身份验证 14.6 URLName类 14.7 创建和读取复杂电子邮件 14.7.1 邮件地址 14.7.2 邮件头部 14.7.3 邮件标记 14.7.4 邮件正文 14.8 操纵邮件夹 14.9 小节 第15章 安全网络通信 15.1 SSL简介 15.1.1 加密通信 15.1.2 安全证书 15.1.3 SSL握手 15.1.4 创建自我签名的安全证书 15.2 JSSE简介 15.2.1 KeyStore、KeyManager与TrustManager类 15.2.2 SSLContext类 15.2.3 SSLServerSocketFactory类 15.2.4 SSLSocketFactory类 15.2.5 SSLSocket类 15.2.6 SSLServerSocket类 15.2.7 SSLEngine类 15.3 创建基于SSL的安全服务器和安全客户 15.4 小节 第16章 CORBA简介 16.1 创建IDL接口 16.2 创建IDL接口的实现类 16.3 创建服务器程序 16.4 创建客户程序 16.5 运行CORBA程序 16.6 小节 第17章 Web服务简介 17.1 SOAP简介 17.2 建立Apache AXIS环境 17.3 在Tomcat上发布Apache-AXIS Web应用 17.4 创建SOAP服务 17.4.1 创建提供SOAP服务的Java类 17.4.2 创建SOAP服务的发布描述符文件 17.5 管理SOAP服务 17.5.1 发布SOAP服务 17.5.2 删除SOAP服务 17.6 创建和运行SOAP客户程序 17.7 发布JWS服务 17.8 小节
|