事实上网络编程简单的理解就是两台计算机相互通讯数据而已,对于程序员而言,去掌握一种编程接口并使用一种编程模型相对就会显得简单的多了,java sdk提供一些相对简单的api来完成这些工作。 socket就是其中之一,对于java而言,这些api存在与java.net 这个包里面,因此只要导入这个包就可以准备网络编程了。
网络编程的基本模型就是客户机到服务器模型,简单的说就是两个进程之间相互通讯,然后其中一个必须提供一个固定的位置,而另一个则只需要知道这个固定的位置。并去建立两者之间的联系,然后完成数据的通讯就可以了,这里提供固定位置的通常称为服务器,而建立联系的通常叫做客户端,基于这个简单的模型,就可以进入网络编程啦。
java对这个模型的支持有很多种api,而这里我只想介绍有关socket的编程接口,对于java而言已经简化了socket的编程接口。首先我们来讨论有关提供固定位置的服务方是如何建立的。java提供了serversocket来对其进行支持.事实上当你创建该类的一个实力对象并提供一个端口资源你就建立了一个固定位置可以让其他计算机来访问你,serversocket server=new serversocket(6789);这里稍微要注意的是端口的分配必须是唯一的。因为端口是为了唯一标识每台计算机唯一服务的,另外端口号是从0~65535之间的,前1024个端口已经被tcp/ip 作为保留端口,因此你所分配的端口只能是1024个之后的。好了,我们有了固定位置.现在所需要的就是一根连接线了.该连接线由客户方首先提出要求。因此java同样提供了一个socket对象来对其进行支持,只要客户方创建一个socket的实例对象进行支持就可以了。socket client
=new socket(.netaddress.getlocalhost(),5678);客户机必须知道有关服务器的ip地址,对于着一点java也提供了一个相关的类.netaddress 该对象的实例必须通过它的静态方法来提供,它的静态方法主要提供了得到本机ip 和通过名字或ip直接得到.netaddress的方法。
上面的方法基本可以建立一条连线让两台计算机相互交流了,可是数据是如何传输的呢?事实上i/o操作总是和网络编程息息相关的。因为底层的网络是继续数据的,除非远程调用,处理问题的核心在执行上,否则数据的交互还是依赖于io操作的,所以你也必须导入java.io这个包.java的io操作也不复杂,它提供了针对于字节流和unicode的读者和写者,然后也提供了一个缓冲用于数据的读写。
bufferedreader in=new bufferedreader(new inputstreamreader(server.getinputstream()));
printwriter out=new printwriter(server.getoutputstream());
上面两句就是建立缓冲并把原始的字节流转变为unicode可以操作,而原始的字节流来源于socket的两个方法,getinputstream()和getoutputstream()方,分别用来得到输入和输出,那么现在有了基本的模型和基本的操作工具,我们可以做一个简单的socket例程了.
服务方:
import java.io.*;
import java.net.*;
public class myserver {
public static void main(string[] args) throws ioexception{
serversocket server=new serversocket(5678);
socket client=server.accept();
bufferedreader in=new bufferedreader(new inputstreamreader(client.getinputstream()));
printwriter out=new printwriter(client.getoutputstream());
while(true){
string str=in.readline();
system.out.println(str);
out.println("has receive....");
out.flush();
if(str.equals("end"))
break;
}
client.close();
}
}
这个程序的主要目的在于服务器不断接收客户机所写入的信息只到,客户机发送"end"字符串就退出程序,并且服务器也会做出"receive"为回应,告知客户机已接收到消息。
客户机代码:
import java.net.*;
import java.io.*;
public class client{
static socket server;
public static void main(string[] args)throws exception{
server=new socket(.netaddress.getlocalhost(),5678);
bufferedreader in=new bufferedreader(new inputstreamreader(server.getinputstream()));
printwriter out=new printwriter(server.getoutputstream());
bufferedreader wt=new bufferedreader(new inputstreamreader(system.in));
while(true){
string str=wt.readline();
out.println(str);
out.flush();
if(str.equals("end")){
break;
}
system.out.println(in.readline());
}
server.close();
}
}
客户机代码则是接受客户键盘输入,并把该信息输出,然后输出"end"用来做退出标识。
这个程序只是简单的两台计算机之间的通讯,如果是多个客户同时访问一个服务器呢?你可以试着再运行一个客户端,结果是会抛出异常的。那么多个客户端如何实现呢?
其实,简单的分析一下,就可以看出客户和服务通讯的主要通道就是socket本身,而服务器通过accept方法就是同意和客户建立通讯.这样当客户建立socket的同时。服务器也会使用这一根连线来先后通讯,那么既然如此只要我们存在多条连线就可以了。那么我们的程序可以变为如下:
Java Asp PHP .Net XML C/C++ CGI VB Jsp J2ee J2se J2me EJB Servlet Tomcat Resin Struts Weblogic Eclipse ANT GUI JMS Web servise IDEA Webphere Hibernate Spring Jboss Applet Swing Socket Javamail Perl Ajax P2P 安全 模式 框架 测试 开源 游戏
Windows XP Windows 2000 Windows 2003 Windows Me Windows 9.x Linux UNIX 注册表 操作系统 服务器 应用服务器