如何从URL获取域名?

内容来源于 Stack Overflow,并遵循CC BY-SA 3.0许可协议进行翻译与使用

  • 回答 (2)
  • 关注 (0)
  • 查看 (57)

在我的django应用程序中,我需要从引用程序中获取域名request.META.get('HTTP_REFERER')以及其协议,以便从以下网址获得:

我应该得到:

我查看了其他相关的问题并发现了关于urlparse的问题,但这并没有成功

>>> urlparse(request.META.get('HTTP_REFERER')).hostname
    'docs.google.com'

此外,我没有找到一种方法来获得协议,也许做了一个简单的连接:\

提问于
用户回答回答于

你应该能够做到这一点:

from urlparse import urlparse
parsed_uri = urlparse( 'http://stackoverflow.com/questions/1234567/blah-blah-blah-blah' )
domain = '{uri.scheme}://{uri.netloc}/'.format(uri=parsed_uri)
print domain

# gives
'http://stackoverflow.com/'

用户回答回答于

https://github.com/John-Kurkowski/tldextracl

这是一个更详细的url解译版本。它为您检测域和子域。

从他们的文件中:

>>> 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是一个名称,所以访问你想要的部件很简单。

>>> ext = tldextract.extract('http://forums.bbc.co.uk')
>>> ext.domain
'bbc'
>>> '.'.join(ext[:2]) # rejoin subdomain and domain
'forums.bbc'

扫码关注云+社区