事实上网络编程简单的理解就是两台计算机相互通讯数据而已。对于程序员而言,去掌握一种编程接口并使用一种编程模型相对就会显得简单的多了。Java SDK提供一些相对简单的Api来完成这些工作,Socket就是其中之一。 9@dlH] L}5
GEmd5N$
对于Java而言。这些Api存在与Java.net这个包里面。因此只要导入这个包就可以准备网络编程了。网络编程的基本模型就是客户机到服务器模型。简单的说就是两个进程之间相互通讯,然后其中一个必须提供一个固定的位置,而另一个则只需要知道这个固定的位置,并去建立两者之间的联系。然后完成数据的通讯就可以了。这里提供固定位置的通常称为服务器,而建立联系的通常叫做客户端。基于这个简单的模型,就可以进入网络编程。 O*4_z B
nmW :St
Java对这个模型的支持有很多种Api。而这里我只想介绍有关Socket的编程接口。对于Java而言已经简化了Socket的编程接口。首先我们来讨论有关提供固定位置的服务方是如何建立的。Java提供了ServerSocket来对其进行支持。事实上当你创建该类的一个实力对象并提供一个端口资源你就建立了一个固定位置可以让其他计算机来访问你。 :}zg2 pk<
o>Gx-[m=W
ServerSocket server=new ^6x ]-`q
/pYq?DPRe
ServerSocket(6789); NS!V^,]T
*ewRhC!
这里稍微要注意的是端口的分配必须是唯一的。因为端口是为了唯一标识每台计算机唯一服务的。另外端口号是从0~65535之间的,前1024个端口已经被Tcp/Ip 作为保留端口,因此你所分配的端口只能是1024个之后的。 %t-!9J
&8d;W$T:
好了。我们有了固定位置。现在所需要的就是一根连接线了。该连接线由客户方首先提出要求。因此Java同样提供了一个Socket对象来对其进行支持。只要客户方创建一个Socket的实例对象进行支持就可以了。 s43%f{ _{]
1I0;KM>Q
Socket client=new *|1{I.C
9L%;1Z:o
Socket(InetAddress.getLocalHost(),5678); "/(R2@ro
XKNOByl^
客户机必须知道有关服务器的IP地址。对于着一点Java也提供了一个相关的类InetAddress 该对象的实例必须通过它的静态方法来提供。它的静态方法主要提供了得到本机IP 和通过名字或IP直接得到InetAddress的方法。 MUsH1<R@R
y81xr
好了,上面的方法基本可以建立一条连线让两台计算机相互交流了。可是数据是如何传输的呢?事实上I/O操作总是和网络编程息息相关的。因为底层的网络是继续数据的。除非远程调用,处理问题的核心在执行上。 $6bX;r$i
s6CX5%
否则数据的交互还是依赖于IO操作的。所以你也必须导入Java。io这个包。Java的IO操作也不复杂。它提供了针对于字节流和Unicode的读者和写者,然后也提供了一个缓冲用于数据的读写。 =Qc{qZp)
MQME AX
`M4=H[g6<
BufferedReader in=new /Op>h)\J
J~2{JC]$,
BufferedReader(new InputStreamReader +&_hh}Q"t
!qln{qU
(server.getInputStream())); qt[>}Rz5i
I"D'HI
PrintWriter out=new o,W(OTI,
KW#r(&*X++
PrintWriter(server.getOutputStream()); aegP )w4 V
+Q{G_L?
"]hQ~SC)<o
上面两句就是建立缓冲并把原始的字节流转变为Unicode可以操作。而原始的字节流来源于Socket的两个方法,getInputStream()和getOutputStream()方,分别用来得到输入和输出。那么现在有了基本的模型和基本的操作工具,我们可以做一个简单的Socket例程了服务方: )}]Rkzx
,dDb33xm3
{G*Fm/&W
import Java。io。*; & s kB4ES
FX>=#@2J
import Java。net。*; 'Y8>~:ol{U
P%QCj
public class MyServer 6XDRp)c
D;\JoTi
{ 2(HXK$W
KV98lu
public static void main (` z Q
_*? CzL}]4
(String[] args) throws IOException 47/y^
gt*&|B6|F
{ glZ=(: L(`
ServerSocket server=new g:Ls*Bnz
ServerSocket(5678); Pa3i~L,U
Socket client=server.accept(); 3`eGY'K
BufferedReader ] }O7Qk!?
in=new BufferedReader(new w# bm& Jk4
InputStreamReader b%{Y</|
(client.getInputStream())); ()Z/z&
PrintWriter out=new ^&*`hVk
PrintWriter(client.getOutputStream()); qb R0'S?V
while(true) sS|C[@/
{ Gu9>Sj2J4
String str=in.readLine(); ](r,<
System.out.println(str); Pw<I&[[(@
out.println("has receive..."); p&IS$AN
out.flush(); _ X'#.VgT
if(str.equals("end")) J 89CO+o
break; ~;+qNJ8Q
} %I@#eU4j
client。close(); m#W.;{|Dx
} rLAzAC-1U
} jI*A A1
4PK/32@
这个程序的主要目的在于服务器不断接收客户机所写入的信息只到。客户机发送"End"字符串就退出程序。并且服务器也会做出"Receive"为回应。告知客户机已接收到消息。客户机代码: 2{N|x 0@Ez
/A1HA:
B H4=?~U
import Java.net.*; 'l,L5?%O>
ifA5f3'
import Java.io.*; n{2([,!FLQ
-u)+V:
public class Client{ } 86*ng:P1
static Socket server; wcD[w(="|k
B7OKs:I@
public static void T:E)qV^
main(String[] args) 6_a[W: J|+
throws Exception c(9 KcqQ
{ FI(L
server=new Socket weX9\ !XJ
(InetAddress.getLocalHost(),5678); M4 , R
BufferedReader in=new BufferedReader(new s/6/&
InputStreamReader(server。getInputStream())); !QdT.j93+
PrintWriter out=new @v!7J6Q
PrintWriter(server.getOutputStream()); +|aVAS&;
BufferedReader wt=new BufferedReader(new GBVNbz9]k
InputStreamReader(System.in)); H\/!3yH
while(true) uBCpc}H(
{ ROCg$;:,
String str=wt.readLine(); <\of&
out.println(str); GOMu8k
out.flush(); vph zI5@W
if(str.equals("end")) - rqzxq+
{ WWT7Aw{ N
break; =7`]<&O
} t>by`
System.out.println(in.readLine()); Yc*Q=eTk~
} ,snm4
server.close(); $:z#*k
} UuT#H z
查看本文来源