Java获取URL中的顶级域名domain的工具类
方式一:
- import java.net.MalformedURLException;
- import java.net.URL;
- import java.util.Arrays;
- import java.util.HashSet;
- import java.util.Set;
- import java.util.regex.Pattern;
- public class URLUtil {
- private final static Set<String> PublicSuffixSet = new HashSet<String>(
- Arrays.asList(new String(
- "com|org|net|gov|edu|co|tv|mobi|info|asia|xxx|onion|cn|com.cn|edu.cn|gov.cn|net.cn|org.cn|jp|kr|tw|com.hk|hk|com.hk|org.hk|se|com.se|org.se")
- .split("\\|")));
- private static Pattern IP_PATTERN = Pattern.compile("(\\d{1,3}\\.){3}(\\d{1,3})");
- /**
- * 获取url的顶级域名
- * @param url
- * @return
- */
- public static String getDomainName(URL url) {
- String host = url.getHost();
- if (host.endsWith(".")){
- host = host.substring(0, host.length() - 1);
- }
- if (IP_PATTERN.matcher(host).matches()){
- return host;
- }
- int index = 0;
- String candidate = host;
- for (; index >= 0;) {
- index = candidate.indexOf('.');
- String subCandidate = candidate.substring(index + 1);
- if (PublicSuffixSet.contains(subCandidate)) {
- return candidate;
- }
- candidate = subCandidate;
- }
- return candidate;
- }
- /**
- * 获取url的顶级域名
- * @param url
- * @return
- * @throws MalformedURLException
- */
- public static String getDomainName(String url) throws MalformedURLException {
- return getDomainName(new URL(url));
- }
- /**
- * 判断两个url顶级域名是否相等
- * @param url1
- * @param url2
- * @return
- */
- public static boolean isSameDomainName(URL url1, URL url2) {
- return getDomainName(url1).equalsIgnoreCase(getDomainName(url2));
- }
- /**
- * 判断两个url顶级域名是否相等
- * @param url1
- * @param url2
- * @return
- * @throws MalformedURLException
- */
- public static boolean isSameDomainName(String url1, String url2)
- throws MalformedURLException {
- return isSameDomainName(new URL(url1), new URL(url2));
- }
- public static void main(String[] args) throws Exception {
- String urlStr = "http://news.hexun.com/2017-09-23/190978248.html";
- getDomainName(urlStr);
- getDomainName(new URL(urlStr));
- }
- }
方式二:
- import java.net.MalformedURLException;
- import java.net.URL;
- import java.util.regex.Matcher;
- import java.util.regex.Pattern;
- public class DomainUtils {
- /**
- * 获取url的顶级域名
- * @param
- * @return
- */
- public static String getTopDomain(String url){
- try{
- //获取值转换为小写
- String host = new URL(url).getHost().toLowerCase();//news.hexun.com
- Pattern pattern = Pattern.compile("[^\\.]+(\\.com\\.cn|\\.net\\.cn|\\.org\\.cn|\\.gov\\.cn|\\.com|\\.net|\\.cn|\\.org|\\.cc|\\.me|\\.tel|\\.mobi|\\.asia|\\.biz|\\.info|\\.name|\\.tv|\\.hk|\\.公司|\\.中国|\\.网络)");
- Matcher matcher = pattern.matcher(host);
- while(matcher.find()){
- return matcher.group();
- }
- }catch(MalformedURLException e){
- e.printStackTrace();
- }
- return null;
- }
- public static void main(String[] args) {
- System.out.println(getTopDomain("http://news.hexun.com/2017-09-23/190978248.html"));//hexun.com
- }
- }
Java获取URL中的顶级域名domain的工具类的更多相关文章
- java 解析URL里的主域名及参数工具类
java 解析URL里的协议及参数工具类,解析URL中的主域名,并统一把协议修改成http或去掉协议 public class UrlDomainUtils { private static fina ...
- java获取url中的参数
获取地址栏中的url中的userName的值 String userName=new String(request.getParameter("userName")); 获取中文的 ...
- python 从给定的URL中提取顶级域名(TLD)
安装 PyPI的最新稳定版本: pip install tld 或者GitHub的最新稳定版本: pip install https://github.com/barseghyanartur/tld/ ...
- java获取request中的参数、java解析URL问号后的参数
java获取request中的参数.java解析URL问号后的参数.有时候我们需要从request中获取参数,或者获取拼接在Url后面的参数,有时候一个一个去拿有点麻烦,一起拿出来放在一个map里面需 ...
- 【C++】获取URL中主机域名
// ConsoleApplication1.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include <windows.h& ...
- 记录一次bug解决过程:velocity中获取url中的参数
一.总结 在Webx的Velocity中获取url中参数:$rundata.getRequest().getParameter('userId') 在Webx项目中,防止CSRF攻击(Cross-si ...
- 关于获取URL中传值的解决方法
在我们页面的URL中包含着很多信息,包括域名,协议等等这里就不一一介绍了),对于我们开发者而言,使用比较多的就是页面之间的传值.为什么要页面传值呢?很简单,当你在浏览一个商品页面的时候你要看到一个商品 ...
- Java获取URL对应的资源
Java获取URL对应的资源 认识IP.认识URL是进行网络编程的第一步.java.net.URL提供了丰富的URL构建方式,并可以通过java.net.URL来获取资源. 一.认识URL ...
- 如何获取url中的参数并传递给iframe中的报表
在使用报表软件时,用户系统左边一般有目录树,点击报表节点就会在右侧网页的iframe中显示出报表,同时点击的时候也会传递一些参数给网页,比如时间和用户信息等.如何使网页中的报表能够获取到传递过来的参数 ...
随机推荐
- HDU 5977 Garden of Eden(点分治求点对路径颜色数为K)
Problem Description When God made the first man, he put him on a beautiful garden, the Garden of Ede ...
- Java 基础之--注解Annotation详解
自定义注解入门: public @interface Annotation01 { //set default value ""; String value() default & ...
- [原]CentOS7.2部署KVM虚拟机
前段时间学习了关于PostGis.OSM数据以及Mapnik相关内容,接下来将利用假期重点学习PostgreSQL-XL和瓦片服务器集群技术,因此先把环境搭好.计划采用KVM来充分利用家里不太宽裕的“ ...
- 13. pt-ioprofile
pt-ioprofile 直接运行即可,对系统有影响,慎用!!! read:从文件中读出数据.要读取的文件用文件描述符标识,数据读入一个事先定义好的缓冲区. write:把缓冲区的数据写入文件中. p ...
- [SoapUI] 检查测试步骤的类型或者或者某种特定类型的步骤列表
SoapUI Groovy : Check if test step is of specific type, such as : Wsdl, Rest, Jdbc, HTTP, Groovy etc ...
- zeromq学习记录(九)练习代码学习ZMQ_ROUTER ZMQ_READLER
/************************************************************** 技术博客 http://www.cnblogs.com/itdef/ ...
- 开启hadoop集群
首先开启zookeeper zkServer.sh start start-all
- Unittest中TestCase类中定义的几个特殊方法
1.setUp():每个测试方法运行前运行,测试前的初始化工作: 2.tearDown():每个测试方法运行结束后运行,测试后的清理工作: 3.setUpClass():所有的测试方法运行前运行,单元 ...
- 4k项目--PHY通道绑定的两种模式
1.通道绑定有两种模式: • PMA bonding• PMA and PCS bonding GT通道是不支持通道绑定的 2.PMA绑定 PMA绑定减少了PMA之间的通道之间的Skew.并且在PMA ...
- Centos yum 修改为阿里源以及常用的命令
1.备份 mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.backup 2.下载新的CentOS-Base ...