在Ruby中解析URL以获得没有“www”的子域或主域?

前端之家收集整理的这篇文章主要介绍了在Ruby中解析URL以获得没有“www”的子域或主域?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
如果我有一个URL:
http://www.example.com/page

我想解释一下:

example.com

但是,如果我有:

http://blog.example.com/page

我想回来:

blog.example.com

那难吗?

解决方法

使用Ruby的 URI模块:
require 'uri'
URI.parse('http://www.example.com/page').host
=> "www.example.com"
URI.parse('http://blog.example.com/page').host
=> "blog.example.com"

在这两种情况下,URI都会提取整个主机名,因为从域中选择性地剥离主机是没有意义的.

您必须使用以下内容分别实现该逻辑:

%w[http://www.example.com/page http://blog.example.com/page].each do |u|
  puts URI.parse(u).host.sub(/^www\./,'')
end

哪个输出

example.com
blog.example.com

猜你在找的Ruby相关文章