如何解决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
作为二级域。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。