网络编程学习

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档


前言

提示:这里可以添加本文要记录的大概内容:

本章主要对网络编程进行讲解


一、认识网络编程

网页编程 : 上层应用
网络编程 : 底层数据的传输
IP : 定位网络中节点
端口 : 区分软件
URL : 统一资源定位符

传输层协议 : 交流方式,标准,合同.
    传输更加畅通,更加规范,更加标准.

UDP : 相当于写信,传递包裹   协议简单,开销小,效率高   只管写只管邮   不安全   大小限制
TCP : 相当于打电话 面向连接  安全,但是效率低   没有大小限制   ******

IP :
    定位节点 : 电子设备 ,手机,计算机,,,
    IPV4 : 4个字节  32位
    IPV6 : ...

    特殊的IP :
        192.168.0.0~192.168.255.255  非注册IP ,供组织内部使用的IP
        本地IP : 127.0.0.1
        本地域名 : localhost
            DNS解析器 : IP 与 域名之间的解析

    java.net 网络包
    InetAddress : 表示IP地址

二、知识点

1.端口

端口 :
区分软件
2个字节 0~65535
统一协议下端口号不能冲突
一般8000以内为预留端口号,不建议使用
常见端口号 :

80 : http
8080 : tomcat
1521 : oracle
3306 : mysql

InetSocketAddress 此类实现IP套接字地址(IP地址+端口号)

2.URL

URL : 统一资源定位符,指向万维网上的“资源”的指针。
互联网的三大基石 : html http url

组成 :
    1.协议
    2.域名
    3.端口
    4.请求资源
    http://www.baidu.com:80/index.html?uname=yjxxt&age=18#a

3.传输层协议

传输层协议 : 规范标准

UDP

udp : 相当于写信|邮寄包裹   非面向连接  效率高,协议简单,开销较小    不安全|不可靠     大小存在限制,一般不超过60k
Socket套接字 : 传输层为应用层开辟的一个小口子,用来做创建层与应用层之间数据的传输
面向Socket编程
不同协议下Socket实现不同

UDP 协议下发送数据两端平等(发送端  接收端)
UDP 协议下数据与字节数组传输

DatagramSocket  : 此类表示用于发送和接收数据报包的套接字。
    数据报套接字是分组传送服务的发送或接收点。

DatagramPacket : 该类表示数据报包。

UDP实现基础的流程:发送端 :
    1.定义我是端点(发送端)
        DatagramSocket(int port) 构造一个数据报套接字并将其绑定到本地主机上的指定端口。
    2.准备数据
    3.数据打包
        DatagramPacket(byte[] buf, int length, SocketAddress address) 构造数据报包,用于将长度为 length的数据包发送到指定主机上的指定端口号。
    4.发送数据
        void send(DatagramPacket p) 从此套接字发送数据报包。
    5.关闭
        void close() 关闭此数据报套接字。
        
UDP协议下实现基础流程 : 接收端
    1.定义我是接收端
         DatagramSocket(int port) 构造一个数据报套接字并将其绑定到本地主机上的指定端口。
    2.准备一个包裹,用来接收数据
        DatagramPacket(byte[] buf, int length) 构造 DatagramPacket用于接收长度为 length数据包。
    3.接收
        void receive(DatagramPacket p) 从此套接字接收数据报包。
    4.处理数据
        byte[] getData() 返回数据缓冲区。
        int getLength() 返回要发送的数据的长度或接收的数据的长度。
    5.关闭
        void close() 关闭此数据报套接字。

TCP

TCP : 面向连接 相当于打电话 安全,效率低 大小没有限制
基于三次握手 四次挥手

服务器与客户端之间是不平等的
服务器可以接受多个客户端的请求,可有做出响应

TCP协议下数据传输基于IO流
连接就是管道,封装这输入流与输出流

tcp协议实现基本流程 : 服务器
    1.定义我是服务器
        ServerSocket该类实现服务器套接字。
        ServerSocket(int port) 创建绑定到指定端口的服务器套接字。
    2.阻塞式监听
        Socket accept() 侦听对此套接字的连接并接受它。
    3.io操作 : 通过输入流读入客户端发送的数据
    4.处理数据
    5.关闭
tcp协议实现基本流程 : 客户端
    1.定义我是客户端
        Socket该类实现客户端套接字(也称为“套接字”)。 套接字是两台机器之间通信的端点。
        Socket(String host, int port)  服务器ip+端口
    2.IO操作 : 通过输出流向服务器发送数据
        OutputStream getOutputStream() 返回此套接字的输出流。
    3.刷出
    4.关闭

总结

提示:这里对文章进行总结:
例如:以上就是今天要讲的内容,本文仅仅简单介绍了pandas的使用,而pandas提供了大量能使我们快速便捷地处理数据的函数和方法。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值