Socket编程
- 网络基础知识
- InetAddress类
- URL
- TCP编程
- UDP编程
两台计算机通过网络进行通信,需要的必然条件?
- 两台主机需要唯一的标示,用来表示它们所处的身份,它们所在的位置,也就是IP地址
- 它们需要共同的语言。否则它们会言语不通,无法交流。这就是协议
- 每台主机还都需要相应的端口号。
一台主机上可以运行多个应用程序,那如何辨别不同应用程序的通信?答:我们需要使用端口号来区分。
TCP/IP协议
- TCP/IP是目前世界上应用最为广泛的协议
是以TCP和IP为基础的不同层次上多个协议的集合,也称:TCP/IP协议族 或 TCP/IP协议栈。
两个主机之间要进行通信,它们都必须遵从TCP/IP协议
- TCP:Transmission Control Portocol 传输控制协议
- IP:Internet Protocol 互联网协议
我们在实际的应用当中,会将网络进行分层?
IP地址:为实现网络中不通计算机之间的通信,每台机器都必须有一个唯一的标识——IP地址
IP地址格式:数字型,如:192.168.0.1 (IPv4)
端口:用于区分不同应用程序。端口号范围为0~65535,其中0~1023为系统所保留。
IP地址和端口号组成了所谓的Socket,Socket是网络上运行的程序之间双向通信链路的终结点,是TCP和UDP的基础。
http:80 ftp:21 telnet:23
Java中的网络支持:
针对网络通信的不通层次,Java提供的网络功能有四大类:
- IntetAddress:用于标识网络上的硬件资源。
- URL:统一资源定位符 通过URL可以直接读取或写入网络上的数据
- Sockets:使用TCP协议实现网络通信的Socket相关的类。
- Datagram:使用UDP协议,将数据保存在数据报中,通过网络进行通信。
InetAddress类
1、InetAddress类用于标识网络上的硬件资源,表示互联网协议(IP)地址。
package com.xbmu;
import java.net.InetAddress;
import java.net.UnknownHostException;
import java.util.Arrays;
/**
* InetAddress类的使用
* @author bitaotao
*
*/
public class InetAddressDemo1 {
public static void main(String[] args) throws UnknownHostException {
//获取本机的InetAddress实例
InetAddress address = InetAddress.getLocalHost();
System.out.println("计算机名:"+address.getHostName());
System.out.println("IP地址:"+address.getHostAddress());
byte[] bs = address.getAddress();//获取字节数组形式的IP地址
System.out.println("字节数组形式的IP:"+Arrays.toString(bs));
System.out.println(address);//直接输出InetAddress对象
System.out.println("================================");
//根据机器名获取InetAddress实例
//InetAddress address2 = InetAddress.getByName("bitaotao-PC");
InetAddress address2 = InetAddress.getByName("192.168.176.1");
System.out.println("计算机名:"+address2.getHostName());
System.out.println("IP地址:"+address2.getHostAddress());
}
}
URL
1、URL(Uniform Resource Locator)统一资源定位符,表示Internet上某一资源的地址。
2、URL由两部分组成:协议名称和资源名称,中间用冒号隔开。
3、在java.net包中,提供了URL类来表示URL。
package com.xbmu;
import java.net.MalformedURLException;
import java.net.URL;
public class URLDemo1 {
public static void main(String[] args) {
//创建一个URL实例
try {
URL imooc = new URL("http://www.imooc.com");
//?后面表示参数,#后面表示锚点
URL url = new URL(imooc, "/index.html?username=tom#test");
System.out.println("协议:"+url.getProtocol());
System.out.println("主机:"+url.getHost());
//如果未指定端口号,则使用默认的端口号,此时getPort()方法返回值为-1
System.out.println("端口:"+url.getPort());
System.out.println("文件路径:"+url.getPath());
System.out.println("文件名:"+url.getFile());
System.out.println("相对路径:"+url.getRef());
System.out.println("查询字符串:"+url.getQuery());
} catch (MalformedURLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
使用URL读取网页内容:
1、通过URL对象的openStream()方法可以得到指定资源的输入流。
2、通过输入流可以读取、访问网络上的数据。
package com.xbmu;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.MalformedURLException;
import java.net.URL;
/**
* 使用URL读取网页内容
* @author bitaotao
*
*/
public class NetPageDataDemo1 {
private static BufferedReader br = null;
private static InputStreamReader isr = null;
private static InputStream is = null;
public static void main(String[] args) {
try {
//创建一个URL实例
URL url = new URL("http://www.baidu.com");
//通过URL的openStream方法获取URL对象所表示的资源的字节输入流
is = url.openStream();
//将字节输入流转换成字符输入流
isr = new InputStreamReader(is,"utf-8");
//为字节输入流添加缓冲
br = new BufferedReader(isr);
String data = br.readLine();//读取数据
while(data != null){//循环读取数据
System.out.println(data);
data = br.readLine();
}
} catch (MalformedURLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally{
try {
if(null != br){
br.close();
}
if(null != isr){
isr.close();
}
if(null != is){
is.close();
}
} catch (IOException e) {
e.printStackTrace();
}
}
}
}