Hướng dẫn how does python verify ip address? - python xác minh địa chỉ ip như thế nào?

Trong chương trình Python của bạn, bạn có thể muốn xác thực địa chỉ IP. Đây có thể là một yêu cầu nếu bạn viết các chương trình cấp hệ điều hành và không chỉ.

Để xác thực địa chỉ IP bằng Python, bạn có thể sử dụng hàm ip_address [] của mô -đun iPaddress. Điều này hoạt động cả cho địa chỉ IPv4 và IPv6. Bạn cũng có thể xác thực địa chỉ IP bằng cách sử dụng hàm tùy chỉnh hoặc biểu thức chính quy xác minh các bộ số mà địa chỉ IP được tạo.

Hãy để xác nhận bắt đầu!

  • Làm cách nào để xác thực một địa chỉ IP trong Python?
  • Xác thực địa chỉ IP bằng hàm tùy chỉnh
  • Xác thực địa chỉ IP bằng cách sử dụng regex
  • Cách kiểm tra xem IP có loại IPv4 hay IPv6 bằng Python không
  • Cách kiểm tra xem địa chỉ IP có ở trong một mạng con nhất định không
  • Chuyển đổi địa chỉ IP sang các định dạng khác để xác thực
  • Sự kết luận

Làm cách nào để xác thực một địa chỉ IP trong Python?

Xác thực địa chỉ IP bằng hàm tùy chỉnhipaddress module.

Xác thực địa chỉ IP bằng cách sử dụng regex

Cách kiểm tra xem IP có loại IPv4 hay IPv6 bằng Python không

>>> ipaddress.ip_address["10.10.10.10"]
IPv4Address['10.10.10.10'] 

Cách kiểm tra xem địa chỉ IP có ở trong một mạng con nhất định không

Chuyển đổi địa chỉ IP sang các định dạng khác để xác thực

>>> ipaddress.ip_address["10.10.10.300"]
Traceback [most recent call last]:
  File "", line 1, in 
  File "/opt/anaconda3/lib/python3.8/ipaddress.py", line 53, in ip_address
    raise ValueError['%r does not appear to be an IPv4 or IPv6 address' %
ValueError: '10.10.10.300' does not appear to be an IPv4 or IPv6 address 

Sự kết luận

Cách đơn giản nhất để xác thực nếu một chuỗi biểu thị địa chỉ IP là bằng cách sử dụng mô -đun iPaddress Python.

import ipaddress 

def validate_ip_address[address]:
    try:
        ip = ipaddress.ip_address[address]
        print["IP address {} is valid. The object returned is {}".format[address, ip]]
    except ValueError:
        print["IP address {} is not valid".format[address]] 

Hãy để mở vỏ Python và xem hàm ipaddress.IP_Address [] trả về những gì chúng tôi chuyển đến các chuỗi đại diện cho địa chỉ IPv4 hợp lệ và không hợp lệ.

Người đầu tiên hợp lệ…

validate_ip_address["10.10.10.10"]
validate_ip_address["10.10.10.01"]
validate_ip_address["10.10.10.300"]
validate_ip_address["10.260.10.300"]
validate_ip_address["192.168.1.20"]

[output]
IP address 10.10.10.10 is valid. The object returned is 10.10.10.10
IP address 10.10.10.01 is valid. The object returned is 10.10.10.1
IP address 10.10.10.300 is not valid
IP address 10.260.10.300 is not valid
IP address 192.168.1.20 is valid. The object returned is 192.168.1.20 

Hàm ip_address [] trả về một đối tượng loại IPv4Address, điều này có nghĩa là nó có thể dịch chuỗi thành một địa chỉ IP hợp lệ.

Bây giờ, hãy để thử với một IP không hợp lệ

Lần này, hàm ip_address [] làm tăng ngoại lệ giá trị vì chuỗi chúng tôi đã truyền không đại diện cho một địa chỉ IP hợp lệ.: you can also update the validate_ip_address[] function to return True for a valid IP and False for an invalid IP instead of printing a message.

Xác thực địa chỉ IP bằng hàm tùy chỉnh

Xác thực địa chỉ IP bằng cách sử dụng regex

Cách kiểm tra xem IP có loại IPv4 hay IPv6 bằng Python không

a.b.c.d

Cách kiểm tra xem địa chỉ IP có ở trong một mạng con nhất định không

def validate_ip_address[address]:
    parts = address.split["."]

    if len[parts] != 4:
        print["IP address {} is not valid".format[address]]
        return False

    for part in parts:
        if not isinstance[int[part], int]:
            print["IP address {} is not valid".format[address]]
            return False

        if int[part] < 0 or int[part] > 255:
            print["IP address {} is not valid".format[address]]
            return False
 
    print["IP address {} is valid".format[address]]
    return True 

Chuyển đổi địa chỉ IP sang các định dạng khác để xác thực

  • Sự kết luận
  • Cách đơn giản nhất để xác thực nếu một chuỗi biểu thị địa chỉ IP là bằng cách sử dụng mô -đun iPaddress Python.
  • Hãy để mở vỏ Python và xem hàm ipaddress.IP_Address [] trả về những gì chúng tôi chuyển đến các chuỗi đại diện cho địa chỉ IPv4 hợp lệ và không hợp lệ.
    • Người đầu tiên hợp lệ…
    • Hàm ip_address [] trả về một đối tượng loại IPv4Address, điều này có nghĩa là nó có thể dịch chuỗi thành một địa chỉ IP hợp lệ.

Bây giờ, hãy để thử với một IP không hợp lệ

validate_ip_address["10.10.10.10"]
validate_ip_address["10.10.10.01"]
validate_ip_address["10.10.10.300"]
validate_ip_address["10.260.10.300"]
validate_ip_address["192.168.1.20"]

[output]
IP address 10.10.10.10 is valid
IP address 10.10.10.01 is valid
IP address 10.10.10.300 is not valid
IP address 10.260.10.300 is not valid
IP address 192.168.1.20 is valid 

Lần này, hàm ip_address [] làm tăng ngoại lệ giá trị vì chuỗi chúng tôi đã truyền không đại diện cho một địa chỉ IP hợp lệ.

Chúng ta có thể xây dựng một chức năng đơn giản cho biết một địa chỉ IP có hợp lệ hay không tùy thuộc vào thực tế là một ngoại lệ giá trị được nâng lên bởi ipaddress.ip_address [] cho các IP không hợp lệ.

Lưu ý cách chúng tôi sử dụng phương thức String định dạng [] để tạo các thông báo thành công và thất bại.

Chuyển một vài địa chỉ IP cho chức năng này để xác nhận nếu nó hoạt động tốt.

  • Chức năng hoạt động tốt, cũng nhận thấy rằng trong thử nghiệm thứ hai từ chuỗi 10.10.10.01, chúng tôi lấy lại một đối tượng cho trò chơi 10.10.10.1.
  • Mô -đun loại bỏ số 0 hàng đầu trong phần thứ tư của địa chỉ IP.
  • Lưu ý: Bạn cũng có thể cập nhật chức năng Validate_IP_ADDRESS [] để trả về true cho IP hợp lệ và sai cho IP không hợp lệ thay vì in tin nhắn.
  • Hãy cùng làm một chút thực hành Python và xem cách chúng tôi viết logic xác minh địa chỉ IPv4 mà không cần sử dụng mô -đun iPaddress.
^\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}$ 

Địa chỉ IPv4 có định dạng sau:

>>> address = "10.10.10.10"
>>> re.match[r"^\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}$", address]

>>> 
>>> address = "10.10.10.300"
>>> re.match[r"^\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}$", address]

>>> 
>>> address = "10.10.10.3000"
>>> re.match[r"^\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}$", address]
>>>

Trong đó A, B, C, D là bốn số từ 0 đến 255. Chúng ta có thể sử dụng thông số kỹ thuật này để viết logic tùy chỉnh của chúng tôi.

Trong chức năng này, chúng tôi trải qua các bước sau:

Chia địa chỉ dựa trên ký tự DOT và lưu trữ từng phần của địa chỉ IP thành danh sách các chuỗi.

Xác minh rằng chuỗi IP được tạo bằng 4 số được phân tách bằng các dấu chấm [sử dụng hàm len []].

Đối với mỗi số trong chuỗi IP, hãy kiểm tra bên dưới:

Xác minh rằng số là một số nguyên.re.match[] function. To do that we will use the bool[] function.

>>> address = "10.10.10.10"
>>> match = re.match[r"^[\d{1,3}]\.[\d{1,3}]\.[\d{1,3}]\.[\d{1,3}]$", address]
>>> print[bool[match]]
True 
>>> 
>>> address = "10.10.10.3000"
>>> match = re.match[r"^[\d{1,3}]\.[\d{1,3}]\.[\d{1,3}]\.[\d{1,3}]$", address]
>>> print[bool[match]]
False 

Kiểm tra xem số nguyên có giá trị từ 0 đến 255 không.

Thực hiện chức năng của chúng tôi đối với cùng một địa chỉ IP được sử dụng trước đó:

>>> ipaddress.ip_address["10.10.10.300"]
Traceback [most recent call last]:
  File "", line 1, in 
  File "/opt/anaconda3/lib/python3.8/ipaddress.py", line 53, in ip_address
    raise ValueError['%r does not appear to be an IPv4 or IPv6 address' %
ValueError: '10.10.10.300' does not appear to be an IPv4 or IPv6 address 
0

Đầu ra là chính xác.

>>> ipaddress.ip_address["10.10.10.300"]
Traceback [most recent call last]:
  File "", line 1, in 
  File "/opt/anaconda3/lib/python3.8/ipaddress.py", line 53, in ip_address
    raise ValueError['%r does not appear to be an IPv4 or IPv6 address' %
ValueError: '10.10.10.300' does not appear to be an IPv4 or IPv6 address 
1

Đây là đầu ra khi bạn thực hiện chức năng này đối với một số địa chỉ IP.

>>> ipaddress.ip_address["10.10.10.300"]
Traceback [most recent call last]:
  File "", line 1, in 
  File "/opt/anaconda3/lib/python3.8/ipaddress.py", line 53, in ip_address
    raise ValueError['%r does not appear to be an IPv4 or IPv6 address' %
ValueError: '10.10.10.300' does not appear to be an IPv4 or IPv6 address 
2

Cách kiểm tra xem IP có loại IPv4 hay IPv6 bằng Python không

Một cách đơn giản để kiểm tra xem IP là loại IPv4 hoặc IPv6 có sử dụng mô -đun iPaddress Python hay không.

Khi bạn chuyển một địa chỉ IP ở định dạng chuỗi đến hàm ipaddress.ip_address [], một đối tượng mới sẽ được tạo.

Đối tượng thuộc loại ipaddress.ipv4address hoặc ipaddress.ipv6address. Sử dụng hàm tích hợp isinstance [] để xác minh loại đối tượng được tạo.ipaddress.IPv4Address or ipaddress.IPv6Address. Use the isinstance[] built-in function to verify the type of object created.

>>> ipaddress.ip_address["10.10.10.300"]
Traceback [most recent call last]:
  File "", line 1, in 
  File "/opt/anaconda3/lib/python3.8/ipaddress.py", line 53, in ip_address
    raise ValueError['%r does not appear to be an IPv4 or IPv6 address' %
ValueError: '10.10.10.300' does not appear to be an IPv4 or IPv6 address 
3

Như chúng tôi đã làm trước khi chúng tôi sử dụng thử ngoại trừ để in một tin nhắn trong trường hợp địa chỉ IP không hợp lệ.

Hãy gọi cho chức năng của chúng tôi

>>> ipaddress.ip_address["10.10.10.300"]
Traceback [most recent call last]:
  File "", line 1, in 
  File "/opt/anaconda3/lib/python3.8/ipaddress.py", line 53, in ip_address
    raise ValueError['%r does not appear to be an IPv4 or IPv6 address' %
ValueError: '10.10.10.300' does not appear to be an IPv4 or IPv6 address 
4

Tốt đẹp! 😀

Cách kiểm tra xem địa chỉ IP có ở trong một mạng con nhất định không

Mô -đun iPaddress Python cho phép kiểm tra xem địa chỉ IP có phải là một phần của mạng con cụ thể không.

Đầu tiên, hãy để Lôi nhận được tất cả các địa chỉ IP trong mạng 192.168.1.0/28.192.168.1.0/28.

Mô -đun iPaddress cung cấp chức năng ip_network [] trả về đối tượng ipv4network hoặc ipv6network tùy thuộc vào loại địa chỉ IP được truyền đến hàm.ip_network[] function that returns an IPv4Network or IPv6Network object depending on the type of IP address passed to the function.

Nếu bạn chuyển một đối tượng được trả về bởi hàm ip_network [] vào danh sách, bạn sẽ lấy lại danh sách tất cả các đối tượng IPS [IPv4Address hoặc IPv6Address] thuộc về mạng con.

>>> ipaddress.ip_address["10.10.10.300"]
Traceback [most recent call last]:
  File "", line 1, in 
  File "/opt/anaconda3/lib/python3.8/ipaddress.py", line 53, in ip_address
    raise ValueError['%r does not appear to be an IPv4 or IPv6 address' %
ValueError: '10.10.10.300' does not appear to be an IPv4 or IPv6 address 
5

Bây giờ chúng ta biết điều này, chúng ta có thể tạo một hàm trả về true nếu một địa chỉ IP thuộc về mạng con và sai.

Bắt đầu bằng cách tạo một hàm đi qua các địa chỉ IP trong mạng 192.168.1.0/28 bằng cách sử dụng Python cho Loop:

>>> ipaddress.ip_address["10.10.10.300"]
Traceback [most recent call last]:
  File "", line 1, in 
  File "/opt/anaconda3/lib/python3.8/ipaddress.py", line 53, in ip_address
    raise ValueError['%r does not appear to be an IPv4 or IPv6 address' %
ValueError: '10.10.10.300' does not appear to be an IPv4 or IPv6 address 
6

Đầu ra là:

>>> ipaddress.ip_address["10.10.10.300"]
Traceback [most recent call last]:
  File "", line 1, in 
  File "/opt/anaconda3/lib/python3.8/ipaddress.py", line 53, in ip_address
    raise ValueError['%r does not appear to be an IPv4 or IPv6 address' %
ValueError: '10.10.10.300' does not appear to be an IPv4 or IPv6 address 
7

Và bây giờ chúng tôi sẽ trả về true nếu bất kỳ địa chỉ IP nào trong mạng con khớp với địa chỉ IP được truyền đến hàm như đối số đầu tiên.

>>> ipaddress.ip_address["10.10.10.300"]
Traceback [most recent call last]:
  File "", line 1, in 
  File "/opt/anaconda3/lib/python3.8/ipaddress.py", line 53, in ip_address
    raise ValueError['%r does not appear to be an IPv4 or IPv6 address' %
ValueError: '10.10.10.300' does not appear to be an IPv4 or IPv6 address 
8

Bạn có thể sử dụng các câu lệnh ASPER để kiểm tra chức năng này

>>> ipaddress.ip_address["10.10.10.300"]
Traceback [most recent call last]:
  File "", line 1, in 
  File "/opt/anaconda3/lib/python3.8/ipaddress.py", line 53, in ip_address
    raise ValueError['%r does not appear to be an IPv4 or IPv6 address' %
ValueError: '10.10.10.300' does not appear to be an IPv4 or IPv6 address 
9

Sự khẳng định cho IP 192.168.1.200 không thành công vì IP không thuộc về mạng con 192.168.1.0/28.

Chúng tôi không thấy bất kỳ ngoại lệ nào cho IP 192.168.1.8 bởi vì nó là một phần của mạng con và khẳng định không in bất kỳ tin nhắn nào nếu điều kiện được kiểm tra là đúng.

Chuyển đổi địa chỉ IP sang các định dạng khác để xác thực

Trong một số trường hợp, bạn có thể cần chuyển đổi địa chỉ IP được tạo bằng mô -đun iPaddress thành các định dạng khác trước khi thực hiện bất kỳ xác thực nào.

Để chuyển đổi địa chỉ IP thành một chuỗi, bạn có thể sử dụng hàm str [].

LƯU Ý: Hãy nhớ nhập mô -đun iPaddress trước nếu không bạn sẽ thấy ngoại lệ tên tuổi khi bạn cố gắng sử dụng mô -đun.: remember to import the ipaddress module first otherwise you will see a NameError exception when you try to use the module.

import ipaddress 

def validate_ip_address[address]:
    try:
        ip = ipaddress.ip_address[address]
        print["IP address {} is valid. The object returned is {}".format[address, ip]]
    except ValueError:
        print["IP address {} is not valid".format[address]] 
0

Để chuyển đổi địa chỉ IP thành số nguyên, bạn có thể sử dụng hàm int [].

import ipaddress 

def validate_ip_address[address]:
    try:
        ip = ipaddress.ip_address[address]
        print["IP address {} is valid. The object returned is {}".format[address, ip]]
    except ValueError:
        print["IP address {} is not valid".format[address]] 
1

Để chuyển đổi địa chỉ IP từ số nguyên thành đối tượng byte, bạn có thể sử dụng hàm v4_int_to_packed [].

import ipaddress 

def validate_ip_address[address]:
    try:
        ip = ipaddress.ip_address[address]
        print["IP address {} is valid. The object returned is {}".format[address, ip]]
    except ValueError:
        print["IP address {} is not valid".format[address]] 
2

Một hàm tương tự, v6_int_to_packed [], áp dụng cho các địa chỉ IPv6.v6_int_to_packed[], applies to IPv6 addresses.

Sự kết luận

Trong hướng dẫn này, chúng tôi đã trải qua một cách rất đơn giản để thực hiện xác thực địa chỉ IP bằng thư viện iPaddress Python.ipaddress library.

Chúng tôi cũng đã thấy cách sử dụng một chức năng tùy chỉnh và biểu thức thông thường để xác thực IP.

Cuối cùng, chúng ta đã thấy cách xác minh nếu một địa chỉ IP cụ thể thuộc về mạng con.

Bạn sẽ sử dụng phương pháp nào trong chương trình của mình?

Bài viết liên quan:

Tôi là một nhà lãnh đạo công nghệ, kỹ sư phần mềm và huấn luyện viên lập trình. Tôi muốn giúp bạn trong hành trình trở thành một nhà phát triển siêu!

Bài Viết Liên Quan

Chủ Đề