2024-04-19 16:45:11 发布
网友
在我的Django应用程序中,我需要从request.META.get('HTTP_REFERER')中的referer获取主机名及其协议,以便从如下URL获取:
request.META.get('HTTP_REFERER')
我应该得到:
我查看了其他相关的问题,发现了关于urlparse的问题,但这并没有起到作用,因为
>>> urlparse(request.META.get('HTTP_REFERER')).hostname 'docs.google.com'
你应该可以用urlparse(文档:python2,python3)来完成它:
urlparse
from urllib.parse import urlparse # from urlparse import urlparse # Python 2 parsed_uri = urlparse('http://stackoverflow.com/questions/1234567/blah-blah-blah-blah' ) result = '{uri.scheme}://{uri.netloc}/'.format(uri=parsed_uri) print(result) # gives 'http://stackoverflow.com/'
https://github.com/john-kurkowski/tldextract
这是urlparse的更详细版本。它为您检测域和子域。
从他们的文件来看:
>>> import tldextract >>> tldextract.extract('http://forums.news.cnn.com/') ExtractResult(subdomain='forums.news', domain='cnn', suffix='com') >>> tldextract.extract('http://forums.bbc.co.uk/') # United Kingdom ExtractResult(subdomain='forums', domain='bbc', suffix='co.uk') >>> tldextract.extract('http://www.worldbank.org.kg/') # Kyrgyzstan ExtractResult(subdomain='www', domain='worldbank', suffix='org.kg')
ExtractResult是一个namedtuple,因此访问所需的部分很简单。
ExtractResult
>>> ext = tldextract.extract('http://forums.bbc.co.uk') >>> ext.domain 'bbc' >>> '.'.join(ext[:2]) # rejoin subdomain and domain 'forums.bbc'
from urllib.parse import urlsplit url = "http://stackoverflow.com/questions/9626535/get-domain-name-from-url" base_url = "{0.scheme}://{0.netloc}/".format(urlsplit(url)) print(base_url) # http://stackoverflow.com/
你应该可以用
urlparse
(文档:python2,python3)来完成它:https://github.com/john-kurkowski/tldextract
这是urlparse的更详细版本。它为您检测域和子域。
从他们的文件来看:
ExtractResult
是一个namedtuple,因此访问所需的部分很简单。Python3使用urlsplit:
相关问题 更多 >
编程相关推荐