ICE之STUN协议---Binding Request

参考文档

按照时间顺序:

stun协议

使用

https://tools.ietf.org/html/rfc5389#section-14

  • stun不是NAT穿透问题的解决方案。
  • stun只能作为大解决方案的一个工具。
    在这里插入图片描述

stun message structure

https://tools.ietf.org/html/rfc5389#section-6

binding request

  • message type 分析

    • 14bits表示message type

    • 2bits表示class,C0和C1,也就是说一共四个class类型

      • 0b00 : request
      • 0b01 : indication
      • 0b10 : success response
      • 0b11 : error response
    • 12bits表示method,M0-M11
      在这里插入图片描述

    • 下面这个是在rfc3489的描述
      https://tools.ietf.org/html/rfc3489#section-11.1
      说明:

      • 0b000000000001 :表示Binding方法
      • 0b000000000010 :表示Shared Secret方法
        在这里插入图片描述
  • cookie 必须是 0x2112a442
    在这里插入图片描述

  • messgae length

    • 单位是字节
    • 不包含20字节头
      在这里插入图片描述
  • transaction id

    • 随机值
    • 0至 2 96 − 1 {2^{96}-1} 2961
      在这里插入图片描述

attributes

  • 跟在header之后
  • 可以没有
  • TLV(Type-Length-Value)格式
    在这里插入图片描述

在这里插入图片描述

Type

在这里插入图片描述

Length
  • 只表示value的长度

  • 但是如果长度不是整4个字节,要补0
    在这里插入图片描述
    比如这就是补的三个0
    在这里插入图片描述

  • 具体案例分析
    在这里插入图片描述

  • username
    在这里插入图片描述

  • ice-controlling

    • Tie breaker 是一个64bits的随机值,是当两端的角色相同时,在服务端做决策的,决定哪一端改变角色。
      在这里插入图片描述
  • use-candidate
    在这里插入图片描述

  • priority
    在这里插入图片描述

  • message-integrity
    在这里插入图片描述

  • fingerprint
    在这里插入图片描述

你可以使用 Rust 编程语言来实现一个 STUN 客户端。STUN(Simple Traversal of UDP through NATs)是一种用于网络地址转换(NAT)穿透的协议。 下面是一个简单的示例代码,演示了如何使用 Rust 和 tokio 库来实现一个基本的 STUN 客户端: ```rust use std::net::{SocketAddr, UdpSocket}; use tokio::runtime::Runtime; fn main() { // 设置 STUN 服务器的地址 let stun_server: SocketAddr = "stun.example.com:3478".parse().unwrap(); // 创建 UDP 套接字 let socket = UdpSocket::bind("0.0.0.0:0").expect("Failed to bind socket"); // 发送 STUN 请求 let mut buf = [0u8; 1024]; let request: [u8; 20] = [ 0x00, 0x01, 0x00, 0x00, 0x21, 0x12, 0xA4, 0x42, // STUN 请求头部 0x00, 0x06, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // STUN 请求数据 0x00, 0x08, 0x00, 0x14, // STUN 请求数据长度 ]; socket .send_to(&request, stun_server) .expect("Failed to send STUN request"); // 接收 STUN 响应 let (recv_len, _) = socket.recv_from(&mut buf).expect("Failed to receive STUN response"); let response = &buf[..recv_len]; // 处理 STUN 响应 // 这里可以根据 STUN 协议解析 response 数据 println!("STUN response: {:?}", response); } ``` 这只是一个简单的示例,实际上你可能需要更多的代码来处理 STUN 协议的各种情况和错误处理。你可以使用其他 Rust 库来帮助解析和处理 STUN 响应数据。 请注意,这个示例使用了 tokio 库来实现异步网络编程。你需要在 `Cargo.toml` 文件中添加相应的依赖,例如: ```toml [dependencies] tokio = { version = "1", features = ["full"] } ``` 希望这个示例能对你有所帮助!如果你有任何其他问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值