快精灵印艺坊 您身边的文印专家
广州名片 深圳名片 会员卡 贵宾卡 印刷 设计教程
产品展示 在线订购 会员中心 产品模板 设计指南 在线编辑
 首页 名片设计   CorelDRAW   Illustrator   AuotoCAD   Painter   其他软件   Photoshop   Fireworks   Flash  

 » 彩色名片
 » PVC卡
 » 彩色磁性卡
 » 彩页/画册
 » 个性印务
 » 彩色不干胶
 » 明信片
   » 明信片
   » 彩色书签
   » 门挂
 » 其他产品与服务
   » 创业锦囊
   » 办公用品
     » 信封、信纸
     » 便签纸、斜面纸砖
     » 无碳复印纸
   » 海报
   » 大篇幅印刷
     » KT板
     » 海报
     » 横幅

Java Socket编程中的一个秘密类

介绍

  Java平台在java.net包里来实现Socket。在这本文中,我们将使用Java.net包中的下面三个类来工作:

  ・URLConnection

  ・Socket

  ・ServerSocket

  在java.net包里包含有更多的类,但是这些是你最常常遇见的,让我们从URLConnection开始,这个类提供了在你的java代码里使用Socket的方式而无需了解Socket的底层机制。

  甚至不用尝试就可以使用sockets

  连接到一个URL包括以下几个步骤:

  ・创建一个URLConnection

  ・用不同的setter方式配置它

  ・连接到URLConnection

  ・与不同的getter方式进行交互

  下面,我们来用一些例子示范怎样使用URLConnection从一台服务器上哀求一份文档。

  URLClient类

  我们将从URLClient类的结构开始讲起。

import java.io.*;
import java.net.*;
public class URLClient {
 protected URLConnection connection;
 public static void main(String[] args) {}
 public String getDocumentAt(String urlString) {}
}

  注重:必须要先导入java.net和java.io包才行

  我们给我们的类一个实例变量用于保存一个URLConnection

  我们的类包含一个main()方式用于处理浏览一个文档的逻辑流(logic flow),我们的类还包含了getDocumentAt()方式用于连接服务器以及哀求文档,下面我们将探究这些方式的细节。

  浏览文档

  main()方式用于处理浏览一个文档的逻辑流(logic flow):

public static void main(String[] args) {
 URLClient client = new URLClient();
 String yahoo = client.getDocumentAt("http://www.yahoo.com");
 System.out.println(yahoo);
}

  我们的main()方式仅仅创建了一个新的URLClient类的实例并使用一个有效的URL String来调用getDocumentAt()方式。当调用返回文档,我们把它储存在一个String里并把这个String输出到控制台上。然而,实际的工作是getDocumentAt()方式当中完成的。

  从服务器上哀求一份文档

  getDocumentAt()方式处理在实际工作中如何从web上得到一份文档:

public String getDocumentAt(String urlString) {
 StringBuffer document = new StringBuffer();
 try {
  URL url = new URL(urlString);
  URLConnection conn = url.openConnection();
  BufferedReader reader = new BufferedReader(new InputStreamReader(conn.getInputStream()));
  String line = null;
  while ((line = reader.readLine()) != null)
   document.append(line + "/n");
   reader.close();
 } catch (MalformedURLException e) {
  System.out.println("Unable to connect to URL: " + urlString);
 } catch (IOException e) {
  System.out.println("IOException when connecting to URL: " + urlString);
 }
 return document.toString();
}

  getDocumentAt()方式有一个String类型的参数包含我们想得到的那份文档的URL。我们先创建一个StringBuffer用于保存文档的行。接着,我们用传进去的参数urlString来创建一个新的URL。然后,我们创建一个URLConnection并打开它:

URLConnection conn = url.openConnection();

  一旦有了一个URLConnection,我们就获得它的InputStream并包装成InputStreamReader,然后我们又把它进而包装成BufferedReader以至于我们能够读取从服务器获得的文档的行,我们在java代码中处理socket的时候会常常使用这种包装技术。在我们继承学习之前你必须认识它:

BufferedReader reader =new BufferedReader(new InputStreamReader(conn.getInputStream()));

  有了BufferedReader,我们能够轻易的读取文档的内容。我们在一个while...loop循环里调用reader上的readline()方式:

String line = null;
while ((line = reader.readLine()) != null)
document.append(line + "/n");

  调用readLine()方式后从InputStream传入行终止符(例如换行符)时才产生阻塞。假如没有得到,它将继承等待,当连接关闭时它才会返回null,既然这样,一旦我们获得一个行,我们连同一个换行符把它追加到一个调用的文档的StringBuffer上。这样就保留了从服务器上原文档的格式。

  当我们读取所有行以后,我们应该关闭BufferedReader:

reader.close();

  假如提供应urlString的URL构造器无效,则将会抛出一个MalformedUR特拉LException非常。同样假如产生了其他的错误,例如从连接获取InputStream时,将会抛出IOException。

  总结

  1.用一个你想连接的资源的有效的url String来实例化URL

  2.连接到指定URL

  3.包装InputStream为连接在BufferedReader以至于你可以读取行

  4.用你的BufferedReader读取文档内容

  5.关闭BufferedReader





返回类别: 教程
上一教程: java大进攻(1)
下一教程: java硬件

您可以阅读与"Java Socket编程中的一个秘密类"相关的教程:
· Java Socket编程中的一个秘密类
· Java Socket编程中的一个秘密类
· JAVA SOCKET编程中的一个秘密类
· Vector在Java编程中的应用
· VECTOR在JAVA编程中的应用
    微笑服务 优质保证 索取样品