From: Barney Gale Date: Tue, 15 Apr 2025 00:05:06 +0000 (+0100) Subject: GH-123599: Match `file:` URL hostname against machine hostname in urllib (#132523) X-Git-Tag: v3.14.0b1~475 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=0879ebc953fa7372a4d99f3f79889093f04cac67;p=thirdparty%2FPython%2Fcpython.git GH-123599: Match `file:` URL hostname against machine hostname in urllib (#132523) In `_is_local_authority()`, return early if the authority matches the machine hostname from `socket.gethostname()`, rather than resolving the names and matching IP addresses. --- diff --git a/Doc/library/urllib.request.rst b/Doc/library/urllib.request.rst index a5f1b9b292a8..b7c0c7d50998 100644 --- a/Doc/library/urllib.request.rst +++ b/Doc/library/urllib.request.rst @@ -199,9 +199,9 @@ The :mod:`urllib.request` module defines the following functions: .. versionchanged:: next This function calls :func:`socket.gethostbyname` if the URL authority - isn't empty or ``localhost``. If the authority resolves to a local IP - address then it is discarded; otherwise, on Windows a UNC path is - returned (as before), and on other platforms a + isn't empty, ``localhost``, or the machine hostname. If the authority + resolves to a local IP address then it is discarded; otherwise, on + Windows a UNC path is returned (as before), and on other platforms a :exc:`~urllib.error.URLError` is raised. .. versionchanged:: next diff --git a/Lib/urllib/request.py b/Lib/urllib/request.py index 2c9c7b6ca539..9a6b29a90a29 100644 --- a/Lib/urllib/request.py +++ b/Lib/urllib/request.py @@ -1483,8 +1483,17 @@ class FileHandler(BaseHandler): file_open = open_local_file def _is_local_authority(authority): + # Compare hostnames if not authority or authority == 'localhost': return True + try: + hostname = socket.gethostname() + except (socket.gaierror, AttributeError): + pass + else: + if authority == hostname: + return True + # Compare IP addresses try: address = socket.gethostbyname(authority) except (socket.gaierror, AttributeError):