禁止修改ip地址 python_DHCP方式获取ip地址后防止用户手动修改ip地址方法

在很多组网中有这样的一个需求:

1、客户端采用DHCP方式获取ip地址

2、并且要防止客户端自行手动修改ip地址

这样的功能在H3C交换机上实现起来还是比较方便的,

通过在设备接入用户侧的端口上启用IP Source Guard功能,可以对端口收到的报文进行过滤控制,防止非法报文通过端口,从而限制了对网络资源的非法使用(比如非法主机仿冒合法用户IP接入网络),提高了端口的安全性。

IP Source Guard在端口上用于过滤报文的特征项包括:源IP地址、源MAC地址和VLAN标签。这些特征项可单独或组合起来与端口进行绑定,形成绑定表项,具体包括:IP、MAC、IP+MAC、IP+VLAN、MAC+VLAN和IP+MAC+VLAN。配置了IP Source Guard的端口接收到报文后查找IP Source Guard绑定表项,如果报文中的特征项与绑定表项中记录的特征项匹配,则端口转发该报文,否则做丢弃处理。绑定功能是针对端口的,一个端口配置了绑定功能后,仅该端口被限制,其他端口不受该绑定影响。

IP Source Guard按照绑定表项的产生方式分为静态绑定和动态绑定:

l              静态绑定:通过手工配置产生绑定表项来完成端口的控制功能,适用于局域网络中主机数较少或者需要为某台主机进行单独的绑定配置的情况;

l              动态绑定:通过自动获取DHCP Snooping或DHCP Relay的绑定表项来完成端口控制功能,适用于局域网络中主机较多,并且采用DHCP进行动态主机配置的情况,可有效防止IP地址冲突、盗用等问题。其原理是每当DHCP为用户分配一条表项时,动态绑定功能就相应地增加一条绑定表项以允许该用户访问网络。如果某个用户私自设置IP地址,会由于没有触发DHCP分配表项,导致动态绑定功能未增加相应的访问允许规则,使得该用户不能访问网络。

注意:

加入聚合组或加入业务环回组的端口上不能配置IP Source Guard功能,反之亦然。

配置相对简单,这里仅列举DHCP方式下的配置情况,更多的请参考H3C相关的软件版本配置手册

(1)        配置Switch A

# 配置端口GigabitEthernet1/0/1的动态绑定功能,绑定源IP地址和MAC地址。

system-view

[SwitchA] interface gigabitethernet 1/0/1

[SwitchA-GigabitEthernet1/0/1] ip check source ip-address mac-address

[SwitchA-GigabitEthernet1/0/1] quit

# 开启DHCP Snooping功能。

[SwitchA] dhcp-snooping

# 设置与DHCP服务器相连的端口GigabitEthernet1/0/2为信任端口。

[SwitchA] interface gigabitethernet 1/0/2

[SwitchA-GigabitEthernet1/0/2] dhcp-snooping trust

[SwitchA-GigabitEthernet1/0/2] quit

(2)        验证配置结果

# 显示端口GigabitEthernet1/0/1的动态绑定功能配置成功。

[SwitchA] interface gigabitethernet 1/0/1

[SwitchA-GigabitEthernet1/0/1] display this

#

interface GigabitEthernet1/0/1

ip check source ip-address mac-address

#

return

# 显示端口GigabitEthernet1/0/1从DHCP Snooping获取的动态表项。

[SwitchA-GigabitEthernet1/0/1] display ip check source

Total entries found: 1

MAC               IP               Vlan   Port                               Status

0001-0203-0406    192.168.0.1      1      GigabitEthernet 1/0/1              DHCP-SNP

# 显示DHCP Snooping已有的动态表项,查看其是否和端口GigabitEthernet1/0/1获取的动态表项一致。

[SwitchA-GigabitEthernet1/0/1] display dhcp-snooping

DHCP Snooping is enabled.

The client binding table for all untrusted ports.

Type : D--Dynamic , S--Static

Type IP Address      MAC Address    Lease        VLAN Interface

==== =============== ============== ============ ==== =================

D    192.168.0.1     0001-0203-0406 86335        1    GigabitEthernet1/0/1

从以上显示信息可以看出,端口GigabitEthernet1/0/1在配置动态绑定功能之后获取了DHCP Snooping产生的动态表项。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用Python中的socket和struct库获取MAC地址,并使用Python的requests库向DHCP服务器发送请求,获取相应的IP地址。以下是一个示例代码: ```python import socket import struct import requests # 获取本机MAC地址 def get_mac_address(): mac = ':'.join(['{:02x}'.format((uuid.getnode() >> ele) & 0xff) for ele in range(0, 8 * 6, 8)][::-1]) return mac # 将MAC地址转换为二进制格式 def mac_to_bytes(mac): return struct.pack('!6B', *[int(x, 16) for x in mac.split(':')]) # 发送DHCP请求并获取IP地址 def get_ip_address(mac): # 构造DHCP请求包 dhcp_packet = b'\x01\x01\x06\x00' + b'\x00' * 236 + b'\x63\x82\x53\x63' + b'\x35\x01\x03' + \ b'\x3d\x07\x01' + mac_to_bytes(mac) + b'\xff\x00' # 绑定UDP套接字并发送DHCP请求 sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM) sock.setsockopt(socket.SOL_SOCKET, socket.SO_BROADCAST, 1) sock.bind(('0.0.0.0', 68)) sock.sendto(dhcp_packet, ('255.255.255.255', 67)) # 接收DHCP响应并解析IP地址 while True: data, server = sock.recvfrom(1024) if data[0] == 0x02 and data[1] == 0x01 and data[2] == 0x06 and data[3] == 0x00: ip_address = '.'.join(map(str, data[20:24])) return ip_address # 使用requests库发送HTTP请求获取IP地址 def get_ip_address_http(mac): url = 'http://dhcp_server_ip_address/dhcp_request?mac=' + mac response = requests.get(url) if response.status_code == 200: ip_address = response.text return ip_address # 测试 mac = get_mac_address() ip_address = get_ip_address(mac) print('IP address:', ip_address) ip_address = get_ip_address_http(mac) print('IP address:', ip_address) ``` 以上代码中的get_mac_address()函数使用uuid库获取本机MAC地址,并将其转换为标准格式。mac_to_bytes()函数将MAC地址转换为二进制格式,以便构造DHCP请求包。get_ip_address()函数构造并发送DHCP请求,接收并解析DHCP响应中的IP地址。get_ip_address_http()函数使用requests库发送HTTP请求获取IP地址。 请注意替换代码中的dhcp_server_ip_address为您的DHCP服务器的IP地址

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值