您的位置:首页 > 理论基础 > 计算机网络

JavaSE入门学习47:Socket网络通信编程(一)

2016-06-07 15:39 429 查看
今天既然我们学习Java的Socket网络通信编程,那么在我们的现实生活中那些是Socket编程的应用呢?可以想象

我们最常用的聊天工具软件QQ就是,当然MSN也是啦。

一网络基础知识

两台计算机通过网络进行通信的必要条件:

1)IP地址

2)网络协议

3)端口号

两台计算机网络通信示意图:



(1)TCP/IP协议

1)TCP/IP协议是目前世界上应用最为广泛的协议,是以TCP和IP为基础的不同层次上多个协议的集合,也称

TCP/IP协议族或TCP/IP协议栈。

2)TCP:Transmission Control Protocol(传输控制协议)。

3)IP:Internet Protocol(互联网协议)

(2)TCP/IP模型

TCP/IP模型示意图:



1)应用层(最高层,HTTP协议表示超文本传输协议,FTP协议表示文件传输协议,SMTP协议表示简单邮件传送协

议,Telnet协议表示远程登录服务)。

2)传输层(TCP/IP协议),TCP和UDP属于传输层。这就是我们程序员编程的一层。

3)网络层IP协议是属于网络层

4)数据链路层

5)物理层(网线,双绞线,网卡)

(3)IP地址

1)为实现网络中不同计算机之间的通信,每台机器都必须有一个唯一的标识——IP地址。

2)IP地址格式:数字型,如:192.168.0.1(Ipv4)。

想要深入了解的可以看我的这篇文章:IP地址的规划和设计方法(一)

(4)端口

1)用于区分不同的应用程序。

2)端口号范围为0~65535,其中0~1023为系统所保留。

3)IP地址和端口号组成了所谓的Socket,Socket是网络上运行的程序之间双向通信链路的终结点,是TCP和UDP

的基础。

4)HTTP协议使用80端口,FTP协议使用21端口,SMTP协议使用25端口,POP3协议使110端口, telnet协议使

用110端口。

(5)Java中的网络支持

针对网络通信的不同层次,Java提供的网络功能有四大类:

1)InetAddress类:用于标识网络上的硬件资源。

2)URL类:统一资源定位符,通过URL可以直接读取或写入网络上的数据。

3)Sockets类:使用TCP协议实现网络通信的Socket相关的类。

4)Datagram类:使用UDP协议,将数据保存在数据报中,通过网络进行通信。

二Java中的InetAddress类的应用

(1)InetAddress类

1)InetAddress类用于标识网络上的硬件资源,标识互联网协议(IP)地址。

2)java.net.InetAddress类表示互联网协议(IP)地址。

InetAddress类中的方法:





先行查看自己的计算机名称和自己的计算机IP地址。

实例代码:

<span style="font-size:18px;">import java.net.*;
import java.util.*;

public class Test01{
public static void main(String[] args) throws UnknownHostException{
System.out.println("--------根据本地主机获取InetAddress实例-----------");
//获取本机的InetAddress实例
InetAddress address1 = InetAddress.getLocalHost();

//直接输出InetAddress对象
System.out.println(address1);

//输出结果
System.out.println("计算机名称:"+address1.getHostName());
System.out.println("IP地址:"+address1.getHostAddress());

//获取字节数组形式的IP地址
byte[] bytes = address1.getAddress();
System.out.println("字节数组形式的IP地址:"+Arrays.toString(bytes));

System.out.println("--------根据主机名获取InetAddress实例-----------");
//根据主机名获取InetAddress实例
InetAddress address2 = InetAddress.getByName("HTACLW0UOMUIZKE");
//直接输出InetAddress对象
System.out.println(address2);

System.out.println("计算机名称:"+address2.getHostName());
System.out.println("IP地址:"+address2.getHostAddress());

System.out.println("--------根据IP地址获取InetAddress实例-----------");
//根据IP地址获取InetAddress实例
InetAddress address3 = InetAddress.getByName("192.168.0.109");
//直接输出InetAddress对象
System.out.println(address3);

System.out.println("计算机名称:"+address3.getHostName());
System.out.println("IP地址:"+address3.getHostAddress());
}
}</span>


运行结果:



(2)URL

1)URL(Uniform Resource Locator)统一资源定位符,表示Internet上某一资源的地址。URL类代表一个统一资源定

位符,它是指向互联网“资源”的指针。资源可以是简单的文件或目录,也可以是对更为复杂的对象的引用,例如对数

据库或搜索引擎的查询。比如:www.imooc.com。

2)URL由两部分组成:协议名称和资源名称,中间用冒号隔开。

比如:http://www.imooc.com/video/2858

协议名称 资源名称

3)在java.net包中,提供了URL类来表示URL。

URL类中的构造方法:



URL类中的方法:





实例代码:

<span style="font-size:18px;">import java.net.*;
import java.util.*;

/*
*URL常用方法
*/
public class Test02{
public static void main(String[] args){
try{
//创建一个URL实例
URL imooc = new URL("http://www.imooc.com");
//根据已存在的imooc实例创建一个新的URL实例
//?后面表示参数
//#后面表示锚点
URL url = new URL(imooc,"/index.html?username=tom#test");
System.out.println("协议:"+url.getProtocol());
System.out.println("主机:"+url.getHost());
//如果URL实例未指定端口号,则使用默认的端口号,此时getPort()方法返回值为-1
System.out.println("端口:"+url.getPort());
//返回默认端口号
System.out.println("端口:"+url.getDefaultPort());
System.out.println("文件路径:"+url.getPath());
System.out.println("文件名:"+url.getFile());
System.out.println("相对路径:"+url.getRef());
System.out.println("查询字符串:"+url.getQuery());
}catch(MalformedURLException e){
e.printStackTrace();
}
}
}</span>


运行结果:



(3)使用URL读取网页内容

1)通过URL对象的openStream()方法可以得到指定资源的输入流。

2)通过输入流可以读取,访问网络上的数据。

实例代码:

<span style="font-size:18px;">import java.net.*;
import java.io.*;

public class Test03{
public static void main(String[] args){
try{
//创建一个URL实例
URL url = new URL("http://www.baidu.com");
//通过URL的openStream()方法获取URL对象所表示的资源的字节输入流
InputStream is = url.openStream();
//将字节输入流转换为字符输入流
InputStreamReader isr = new InputStreamReader(is,"utf-8");
//为字符输入流添加缓冲
BufferedReader br = new BufferedReader(isr);
//读取数据
String data = br.readLine();
//循环读取数据
while(data!=null){
//输出数据
System.out.println(data);
data = br.readLine();
}
br.close();
isr.close();
is.close();
}catch(MalformedURLException e){
e.printStackTrace();
}catch(IOException e){
e.printStackTrace();
}
}
}</span>


运行结果:



将读取的内容复制到一个html文件中,再用浏览器运行,会得到百度首页。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: