欢迎光临
我们一直在努力

Java Socket编程中的一个秘密类-JSP教程,Java技巧及代码

建站超值云服务器,限时71元/月
介绍
  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
赞(0)
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com 特别注意:本站所有转载文章言论不代表本站观点! 本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。未经允许不得转载:IDC资讯中心 » Java Socket编程中的一个秘密类-JSP教程,Java技巧及代码
分享到: 更多 (0)

相关推荐

  • 暂无文章