本文整理匯總了Python中socket.getaddrinfo方法的典型用法代碼示例。如果您正苦於以下問題:Python socket.getaddrinfo方法的具體用法?Python socket.getaddrinfo怎麽用?Python socket.getaddrinfo使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類socket
的用法示例。
在下文中一共展示了socket.getaddrinfo方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: host_is_local
# 需要導入模塊: import socket [as 別名]
# 或者: from socket import getaddrinfo [as 別名]
def host_is_local(hostname, port=22): # no port specified, just use the ssh port
"""
Returns True if the hostname points to the localhost, otherwise False.
"""
hostname = socket.getfqdn(hostname)
if hostname in ("localhost", "0.0.0.0", "127.0.0.1", "1.0.0.127.in-addr.arpa",
"1.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.ip6.arpa"):
return True
localhost = socket.gethostname()
if hostname == localhost:
return True
localaddrs = socket.getaddrinfo(localhost, port)
targetaddrs = socket.getaddrinfo(hostname, port)
for (ignored_family, ignored_socktype, ignored_proto, ignored_canonname,
sockaddr) in localaddrs:
for (ignored_rfamily, ignored_rsocktype, ignored_rproto,
ignored_rcanonname, rsockaddr) in targetaddrs:
if rsockaddr[0] == sockaddr[0]:
return True
return False
示例2: create_socket_ipv6_tx_ucast
# 需要導入模塊: import socket [as 別名]
# 或者: from socket import getaddrinfo [as 別名]
def create_socket_ipv6_tx_ucast(self, remote_address, port):
try:
sock = socket.socket(socket.AF_INET6, socket.SOCK_DGRAM, socket.IPPROTO_UDP)
except IOError as err:
self.warning("Could not create IPv6 UDP socket: %s", err)
return None
self.enable_addr_and_port_reuse(sock)
try:
sock_addr = socket.getaddrinfo(remote_address, port, socket.AF_INET6,
socket.SOCK_DGRAM)[0][4]
sock.connect(sock_addr)
except IOError as err:
self.warning("Could not connect UDP socket to address %s port %d: %s",
remote_address, port, err)
return None
return sock
示例3: _do_dns_lookup
# 需要導入模塊: import socket [as 別名]
# 或者: from socket import getaddrinfo [as 別名]
def _do_dns_lookup(hostname: str, port: int) -> str:
try:
addr_infos = socket.getaddrinfo(hostname, port, socket.AF_UNSPEC, socket.IPPROTO_IP)
except (socket.gaierror, IndexError, ConnectionError):
raise ServerHostnameCouldNotBeResolved(f"Could not resolve {hostname}")
family, socktype, proto, canonname, sockaddr = addr_infos[0]
# By default use the first DNS entry, IPv4 or IPv6
tentative_ip_addr = sockaddr[0]
# But try to use IPv4 if we have both IPv4 and IPv6 addresses, to work around buggy networks
for family, socktype, proto, canonname, sockaddr in addr_infos:
if family == socket.AF_INET:
tentative_ip_addr = sockaddr[0]
return tentative_ip_addr
示例4: is_valid_ip
# 需要導入模塊: import socket [as 別名]
# 或者: from socket import getaddrinfo [as 別名]
def is_valid_ip(ip):
"""Returns true if the given string is a well-formed IP address.
Supports IPv4 and IPv6.
"""
if not ip or '\x00' in ip:
# getaddrinfo resolves empty strings to localhost, and truncates
# on zero bytes.
return False
try:
res = socket.getaddrinfo(ip, 0, socket.AF_UNSPEC,
socket.SOCK_STREAM,
0, socket.AI_NUMERICHOST)
return bool(res)
except socket.gaierror as e:
if e.args[0] == socket.EAI_NONAME:
return False
raise
return True
示例5: domain_ip_parser
# 需要導入模塊: import socket [as 別名]
# 或者: from socket import getaddrinfo [as 別名]
def domain_ip_parser(ip_or_domain_or_url, local_dns, ipv6):
"""parsing the arg to get the hostname to query."""
#ip_or_domain_or_url = str(sys.argv[1])
if ip_or_domain_or_url.startswith("https://") or ip_or_domain_or_url.startswith("http://"):
ip_or_domain = ip_or_domain_or_url.split('/')[2]
elif ip_or_domain_or_url == ".":
ip_or_domain = ""
else:
ip_or_domain = ip_or_domain_or_url
if local_dns:
import socket
ip_or_domain = socket.gethostbyname(ip_or_domain)
elif ipv6:
import socket
ip_or_domain = socket.getaddrinfo(ip_or_domain, None, socket.AF_INET6)[0][-1][0]
return ip_or_domain
示例6: select_address_family
# 需要導入模塊: import socket [as 別名]
# 或者: from socket import getaddrinfo [as 別名]
def select_address_family(host, port):
"""Return ``AF_INET4``, ``AF_INET6``, or ``AF_UNIX`` depending on
the host and port."""
# disabled due to problems with current ipv6 implementations
# and various operating systems. Probably this code also is
# not supposed to work, but I can't come up with any other
# ways to implement this.
# try:
# info = socket.getaddrinfo(host, port, socket.AF_UNSPEC,
# socket.SOCK_STREAM, 0,
# socket.AI_PASSIVE)
# if info:
# return info[0][0]
# except socket.gaierror:
# pass
if host.startswith("unix://"):
return socket.AF_UNIX
elif ":" in host and hasattr(socket, "AF_INET6"):
return socket.AF_INET6
return socket.AF_INET
示例7: test_basic_behavior
# 需要導入模塊: import socket [as 別名]
# 或者: from socket import getaddrinfo [as 別名]
def test_basic_behavior(self):
inet4_server = self.mox.CreateMock(wsgi_server._SingleAddressWsgiServer)
inet6_server = self.mox.CreateMock(wsgi_server._SingleAddressWsgiServer)
self.mox.StubOutWithMock(wsgi_server, '_SingleAddressWsgiServer')
self.mox.StubOutWithMock(socket, 'getaddrinfo')
socket.getaddrinfo('localhost', 0, socket.AF_UNSPEC, socket.SOCK_STREAM, 0,
socket.AI_PASSIVE).AndReturn(
[(None, None, None, None, ('127.0.0.1', 0, 'baz')),
(None, None, None, None, ('::1', 0, 'baz'))])
wsgi_server._SingleAddressWsgiServer(('127.0.0.1', 0), None).AndReturn(
inet4_server)
inet4_server.start()
inet4_server.port = 123
wsgi_server._SingleAddressWsgiServer(('::1', 123), None).AndReturn(
inet6_server)
inet6_server.start()
self.mox.ReplayAll()
self.server.start()
self.mox.VerifyAll()
self.assertItemsEqual([inet4_server, inet6_server],
self.server._servers)
示例8: test_retry_limited
# 需要導入模塊: import socket [as 別名]
# 或者: from socket import getaddrinfo [as 別名]
def test_retry_limited(self):
inet4_servers = [self.mox.CreateMock(wsgi_server._SingleAddressWsgiServer)
for _ in range(wsgi_server._PORT_0_RETRIES)]
inet6_servers = [self.mox.CreateMock(wsgi_server._SingleAddressWsgiServer)
for _ in range(wsgi_server._PORT_0_RETRIES)]
self.mox.StubOutWithMock(wsgi_server, '_SingleAddressWsgiServer')
self.mox.StubOutWithMock(socket, 'getaddrinfo')
socket.getaddrinfo('localhost', 0, socket.AF_UNSPEC, socket.SOCK_STREAM, 0,
socket.AI_PASSIVE).AndReturn(
[(None, None, None, None, ('127.0.0.1', 0, 'baz')),
(None, None, None, None, ('::1', 0, 'baz'))])
for offset, (inet4_server, inet6_server) in enumerate(zip(
inet4_servers, inet6_servers)):
wsgi_server._SingleAddressWsgiServer(('127.0.0.1', 0), None).AndReturn(
inet4_server)
inet4_server.start()
inet4_server.port = offset + 1
wsgi_server._SingleAddressWsgiServer(('::1', offset + 1), None).AndReturn(
inet6_server)
inet6_server.start().AndRaise(
wsgi_server.BindError('message', (errno.EADDRINUSE, 'in use')))
inet4_server.quit()
self.mox.ReplayAll()
self.assertRaises(wsgi_server.BindError, self.server.start)
self.mox.VerifyAll()
示例9: test_ignore_other_errors
# 需要導入模塊: import socket [as 別名]
# 或者: from socket import getaddrinfo [as 別名]
def test_ignore_other_errors(self):
inet4_server = self.mox.CreateMock(wsgi_server._SingleAddressWsgiServer)
inet6_server = self.mox.CreateMock(wsgi_server._SingleAddressWsgiServer)
self.mox.StubOutWithMock(wsgi_server, '_SingleAddressWsgiServer')
self.mox.StubOutWithMock(socket, 'getaddrinfo')
socket.getaddrinfo('localhost', 0, socket.AF_UNSPEC, socket.SOCK_STREAM, 0,
socket.AI_PASSIVE).AndReturn(
[(None, None, None, None, ('127.0.0.1', 0, 'baz')),
(None, None, None, None, ('::1', 0, 'baz'))])
wsgi_server._SingleAddressWsgiServer(('127.0.0.1', 0), None).AndReturn(
inet4_server)
inet4_server.start()
inet4_server.port = 123
wsgi_server._SingleAddressWsgiServer(('::1', 123), None).AndReturn(
inet6_server)
inet6_server.start().AndRaise(
wsgi_server.BindError('message', (errno.ENOPROTOOPT, 'no protocol')))
self.mox.ReplayAll()
self.server.start()
self.mox.VerifyAll()
self.assertItemsEqual([inet4_server],
self.server._servers)
示例10: select_ip_version
# 需要導入模塊: import socket [as 別名]
# 或者: from socket import getaddrinfo [as 別名]
def select_ip_version(host, port):
"""Returns AF_INET4 or AF_INET6 depending on where to connect to."""
# disabled due to problems with current ipv6 implementations
# and various operating systems. Probably this code also is
# not supposed to work, but I can't come up with any other
# ways to implement this.
# try:
# info = socket.getaddrinfo(host, port, socket.AF_UNSPEC,
# socket.SOCK_STREAM, 0,
# socket.AI_PASSIVE)
# if info:
# return info[0][0]
# except socket.gaierror:
# pass
if ':' in host and hasattr(socket, 'AF_INET6'):
return socket.AF_INET6
return socket.AF_INET
示例11: _start
# 需要導入模塊: import socket [as 別名]
# 或者: from socket import getaddrinfo [as 別名]
def _start(self):
def try_address(address):
try:
(ip_address, port) = address
index = 0
for info in socket.getaddrinfo(ip_address, port, socket.AF_INET, socket.SOCK_STREAM, socket.IPPROTO_TCP):
try:
with self._lock:
self._found.append((info[4][0], info[4][1]))
except Exception, e:
pass
# snooze for some time, so each dns_seed has a chance
# to add nodes, and get addresses from those nodes
#snooze = -1 + 1.3 ** index
#if snooze > 600: snooze = 600 + random.randint(0, 120)
#index += 1
#time.sleep(snooze)
except Exception, e:
pass
示例12: _xmit_packet
# 需要導入模塊: import socket [as 別名]
# 或者: from socket import getaddrinfo [as 別名]
def _xmit_packet(self, retry=True, delay_xmit=None):
if self.sequencenumber:
self.sequencenumber += 1
if delay_xmit is not None:
# skip transmit, let retry timer do it's thing
self.waiting_sessions[self] = {}
self.waiting_sessions[self]['ipmisession'] = self
self.waiting_sessions[self]['timeout'] = delay_xmit + _monotonic_time()
return
if self.sockaddr:
self.send_data(self.netpacket, self.sockaddr)
else:
self.allsockaddrs = []
try:
for res in socket.getaddrinfo(self.bmc, self.port, 0, socket.SOCK_DGRAM):
sockaddr = res[4]
if res[0] == socket.AF_INET:
# convert the sockaddr to AF_INET6
newhost = '::ffff:' + sockaddr[0]
sockaddr = (newhost, sockaddr[1], 0, 0)
self.allsockaddrs.append(sockaddr)
self.bmc_handlers[sockaddr] = self
self.send_data(self.netpacket, sockaddr)
except socket.gaierror:
raise exc.IpmiException("Unable to transmit to specified address")
if retry:
self.waiting_sessions[self] = {}
self.waiting_sessions[self]['ipmisession'] = self
self.waiting_sessions[self]['timeout'] = self.timeout + _monotonic_time()
示例13: getdestbyaddr
# 需要導入模塊: import socket [as 別名]
# 或者: from socket import getaddrinfo [as 別名]
def getdestbyaddr(self, address, af):
#print('getaddrinfo', address[0], address[1], af, self.sock_type)
if af == AF_INET6 and address[0].startswith('['):
return address
ainfo = getaddrinfo(address[0], address[1], af, self.sock_type)
amatch = [x[4] for x in ainfo if x[0] == af]
if len(amatch) == 0:
raise Exception('no match for the %s in AF %s' % (address, af))
amatch = amatch[0]
if af == AF_INET6:
return (('[%s]' % amatch[0], amatch[1]))
return ((amatch[0], amatch[1]))
示例14: run
# 需要導入模塊: import socket [as 別名]
# 或者: from socket import getaddrinfo [as 別名]
def run(self):
while True:
self.userv.wi_available.acquire()
while len(self.userv.wi) == 0:
self.userv.wi_available.wait()
wi = self.userv.wi.pop(0)
if wi == None:
# Shutdown request, relay it further
self.userv.wi.append(None)
self.userv.wi_available.notify()
self.userv.wi_available.release()
if wi == None:
break
data, address = wi
try:
ai = socket.getaddrinfo(address[0], None, self.userv.uopts.family)
except:
continue
if self.userv.uopts.family == socket.AF_INET:
address = (ai[0][4][0], address[1])
else:
address = (ai[0][4][0], address[1], ai[0][4][2], ai[0][4][3])
for i in range(0, 20):
try:
if self.userv.skt.sendto(data, address) == len(data):
break
except socket.error as why:
if isinstance(why, BrokenPipeError):
self.userv = None
return
if why.errno not in (EWOULDBLOCK, ENOBUFS, EAGAIN):
break
sleep(0.01)
self.userv = None
示例15: __init__
# 需要導入模塊: import socket [as 別名]
# 或者: from socket import getaddrinfo [as 別名]
def __init__(self, global_config, uopts):
self.uopts = uopts.getCopy()
self.skt = socket.socket(self.uopts.family, socket.SOCK_DGRAM)
if self.uopts.laddress != None:
ai = socket.getaddrinfo(self.uopts.laddress[0], None, self.uopts.family)
if self.uopts.family == socket.AF_INET:
address = (ai[0][4][0], self.uopts.laddress[1])
else:
address = (ai[0][4][0], self.uopts.laddress[1], ai[0][4][2], ai[0][4][3])
if (self.uopts.flags & socket.SO_REUSEADDR) != 0:
self.skt.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
if hasattr(socket, 'SO_REUSEPORT') and \
(self.uopts.flags & socket.SO_REUSEPORT) != 0:
self.skt.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEPORT, 1)
self.skt.bind(address)
if self.uopts.laddress[1] == 0:
self.uopts.laddress = self.skt.getsockname()
self.sendqueue = []
self.stats = [0, 0, 0]
self.wi_available = Condition()
self.wi = []
self.asenders = []
self.areceivers = []
if self.uopts.nworkers == None:
nworkers = _DEFAULT_NWORKERS
else:
nworkers = self.uopts.nworkers
for i in range(0, nworkers):
self.asenders.append(AsyncSender(self))
self.areceivers.append(AsyncReceiver(self))