网络编程
1.1 概述
打电话 --连接-- 接了–通话 TCP
发短信 – 发送了就完事了-- 接收 UDP
计算机网络:
计算机网络是指将地理位置不同的具有独立功能的多台计算机及其外部设备,通过通信线路连接起来,在网络操作系统,网络管理软件及网络通信协议的管理和协调下,实现资源共享和信息传递的计算机系统。
网络编程的目的:
无线电台… 传播交流信息,数据交换。通信
想要达到这个效果需要什么:
- 如何准确的定位网路上的一台主机 192.168.1.1:端口,定位到这个计算机上的某个资源。
- 找到了这个主机,如何传输数据呢?
JavaWeb: 网页编程 B/S
网络编程:Tcp/ip C/S
1.2 、网络通信的要素
如何实现网络的通信?
通信双方的地址:
- ip
- 端口号
规则:网络通信的协议
TCP/IP参考模型:
小结:
-
网络编程中有两个主要的问题
-
如何准确的定位到网络上的一台或多台主机
-
找到主机之后如何进行通信
-
网络编程中的要素
-
IP和端口号 IP,
-
网络通信协议 udp,tcp
-
万物皆对象:
1.3、IP
ip地址:InetAddress
- 唯一定位一台网络上的计算机
- 127.0.0.1:本机 localhost
- ip地址的分类
- ipv4/ipv6
- ipv4==127.0.0.1 ,4个字节组成 0~255 42亿-;30亿都在北美,亚洲4亿。2011年就用尽;
- iPV6 fe80::b5b9:9a8d:3512:cbb7%6 ,128位。8个无符号整数!
2001:0bb2:aaaa:0015:0000:0000:1aaa:1312
- 公网(互联网)-私网(局域网)
-ABCD类地址
A类IP地址 地址范围1.0.0.1-126.255.255.254(二进制表示为:00000001 00000000 00000000 00000001 - 01111110 11111111 11111111 11111110)。
- ipv4/ipv6
B类IP地址地址范围128.1.0.1-191.254.255.254(二进制表示为:10000000 00000001 00000000 00000001 - 10111111 11111110 11111111 11111110)
C类IP地址范围192.0.1.1-223.255.254.254(二进制表示为: 11000000 00000000 00000001 00000001 - 11011111 11111111 11111110 11111110)。
D类IP地址范围224.0.0.1-239.255.255.254 。
- 192.168.xx.xx专门给组织内部使用的
-域名:记忆IP问题!
- ip:www.baidu.com
java ip的代码实现方法
package lesson01;
import java.net.InetAddress;
import java.net.UnknownHostException;
//测试ip
public class Test {
public static void main(String[] args) {
try {
//查询本机ip地址
InetAddress inetAddress=InetAddress.getByName("127.0.0.1");
System.out.println(inetAddress);
InetAddress inetAddress2=InetAddress.getByName("localhost");
System.out.println(inetAddress2);
InetAddress inetAddress3=InetAddress.getLocalHost();
System.out.println(inetAddress3);
//查询网站ip地址
InetAddress inetAddress1=InetAddress.getByName("www.baidu.com");
System.out.println(inetAddress1);
//常用方法
System.out.println(inetAddress1.getAddress());
System.out.println(inetAddress1.getCanonicalHostName());//规范的名字
System.out.println(inetAddress1.getHostAddress());//ip
System.out.println(inetAddress1.getHostName());//域名,或者自己电脑的名字
} catch (UnknownHostException e) {
e.printStackTrace();
}
}
}