Dart 从 URL 字符串中提取主机 提取二级域名

问题描述

假设我有以下 URL 作为字符串;

  Widget textField() {
    return TextField(
      enabled: false,decoration: Inputdecoration(
          contentPadding: EdgeInsets.symmetric(vertical: 10.0),focusedBorder: OutlineInputBorder(
            borderSide: BorderSide(color: Colors.transparent),borderRadius: BorderRadius.circular(10.0),),border: OutlineInputBorder(
            borderSide: BorderSide(color: Colors.white),borderRadius: BorderRadius.all(
              Radius.circular(10.0),hintStyle: TextStyle(
              fontSize: 18,color: Theme.of(context).secondaryHeaderColor),hintText: 'Search',prefixIcon: Padding(
            padding: EdgeInsets.all(2),child: SizedBox(
              width: 10,height: 10,child: Image.asset(
                'assets/icons/nav-icons/Explore.png',suffixIcon:
              Icon(Icons.mic,filled: true,fillColor: Theme.of(context).primaryColor),);
  }
  

我想从这个url字符串中提取主页名称; 'wikipedia',从网址中删除 https://www.com.org 部分。

提取内容的最佳方法是什么?对于RegExp,我必须使用什么正则表达式?

解决方法

在这种情况下,您不需要使用 RegExp

Dart 有一个用于解析 URL 的预制类:

Uri

使用该 API,您想要实现的目标非常简单:

final urlSource = 'https://www.wikipedia.org/';

final uri = Uri.parse(urlSource);
uri.host; // www.wikipedia.org

Uri.host property 会给你 www.wikipedia.org。从那里,您应该能够轻松提取 wikipedia

Uri.host 还将删除整个路径,即主机后 / 之后的任何内容。

提取二级域名

如果您想从主机获取 second-level domain,即 wikipedia,您可以执行 uri.host.split('.')[uri.host.split('.').length - 2]

但是,请注意这不是万无一失的,因为您可能有或没有子域(例如 www),并且顶级域也可能由多个部分组成。例如,co.uk 使用 co 作为二级域。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...