URL 辅助函数

URL 辅助函数文件包含帮助使用 URL 的函数。

加载此辅助函数

此辅助函数由框架在每个请求上自动加载。

可用函数

以下函数可用:

site_url([$uri = ''[, $protocol = null[, $altConfig = null]]])
参数:
  • $uri (array|string) – URI 字符串或 URI 段数组

  • $protocol (string) – 协议,例如 ‘http’ 或 ‘https’。如果设置为空字符串 ‘’,则返回一个 protocol-relative 链接。

  • $altConfig (\Config\App) – 要使用的备用配置

返回:

站点 URL

返回类型:

string

备注

从 v4.3.0 开始,如果你设置了 Config\App::$allowedHostnames, 并且当前 URL 匹配,则会返回主机名设置了的 URL。

返回配置文件中指定的你的站点 URL。index.php 文件(或你在配置文件中设置为站点 Config\App::$indexPage 的任何内容)都将添加到 URL 中,就像你传递给函数的任何 URI 段一样。

每当你需要生成本地 URL 时,都建议使用此函数,以便在 URL 改变的情况下使页面更便携。

段可以可选地作为字符串或数组传递给函数。这是字符串示例:

<?php

echo site_url('news/local/123');

上面的示例将返回类似内容: http://example.com/index.php/news/local/123

以下是作为数组传递段的示例:

<?php

$segments = ['news', 'local', '123'];
echo site_url($segments);

如果为不同于你自己的站点生成 URL,其中包含不同的配置首选项,则备用配置可能很有用。我们对框架本身使用它进行单元测试。

base_url([$uri = ''[, $protocol = null]])
参数:
  • $uri (array|string) – URI 字符串或 URI 段数组

  • $protocol (string) – 协议,例如 ‘http’ 或 ‘https’。如果设置为空字符串 ‘’,则返回一个 protocol-relative 链接。

返回:

Base URL

返回类型:

string

备注

从 v4.3.0 开始,如果你设置了 Config\App::$allowedHostnames, 并且当前 URL 匹配,则会返回主机名设置了的 URL。

备注

在以前的版本中,如果不带参数调用,此函数返回没有尾随斜杠 (/) 的基本 URL。该错误已修复, 从 v4.3.2 开始,它返回带有尾随斜杠的基本 URL。

返回配置文件中指定的你的站点基础 URL。示例:

<?php

echo base_url();

此函数返回与不附加 Config\App::$indexPagesite_url() 相同的内容。

site_url() 类似,你可以将段作为字符串或数组提供。这是一个字符串示例:

<?php

// Returns like `http://example.com/blog/post/123`
echo base_url('blog/post/123');

上面的示例将返回类似内容: http://example.com/blog/post/123

如果你传递一个空字符串 '' 作为第二个参数,它会返回 protocol-relative 链接:

这很有用,因为与 site_url() 不同,你可以为文件(如图像或样式表)提供字符串。例如:

<?php

echo base_url('images/icons/edit.png');

这将给你类似的内容: http://example.com/images/icons/edit.png

current_url([$returnObject = false[, $request = null]])
参数:
  • $returnObject (boolean) – 如果希望返回 URI 实例而不是字符串,则为 True。

  • $request (IncomingRequest|null) – 用于路径检测的替代请求;用于测试。

返回:

当前URL

返回类型:

string|\CodeIgniter\HTTP\URI

返回当前正在查看的页面的完整 URL。 返回字符串时,会删除 URL 的查询和片段部分。 返回 URI 时,会保留查询和片段部分。

但是,出于安全原因,它基于 Config\App 设置创建,而不是旨在匹配浏览器 URL。

从 v4.3.0 开始,如果你设置了 Config\App::$allowedHostnames,并且当前 URL 匹配,则会返回主机名设置了的 URL。

备注

调用 current_url() 与这样做相同:

site_url(uri_string());

重要

在 v4.1.2 之前,此函数有一个错误,导致它忽略对 Config\App::$indexPage 的配置。

previous_url([$returnObject = false])
参数:
  • $returnObject (boolean) – 如果希望返回 URI 实例而不是字符串,则为 True。

返回:

用户之前所在的 URL

返回类型:

string|mixed|\CodeIgniter\HTTP\URI

返回用户之前完整的 URL(包括段)。

备注

由于盲目信任 HTTP_REFERER 系统变量存在安全问题,如果可用,CodeIgniter 会将以前访问的页面存储在会话中。这确保我们始终使用已知和可信的来源。如果尚未加载会话或否则不可用,则将使用经过清理的 HTTP_REFERER 版本。

uri_string()
返回:

URI 字符串

返回类型:

string

返回相对于 baseURL 的当前 URL 的路径部分。

例如,当你的 baseURL 为 http://some-site.com/ ,当前 URL 为:

http://some-site.com/blog/comments/123

函数将返回:

blog/comments/123

当你的 baseURL 为 http://some-site.com/subfolder/ ,当前 URL 为:

http://some-site.com/subfolder/blog/comments/123

函数将返回:

blog/comments/123

备注

以前的版本中定义了参数 $relative = false。 然而,由于一个错误,此函数总是返回相对于 baseURL 的路径。 从 v4.3.2 开始,该参数已被删除。

备注

在以前的版本中,当你导航到 baseURL 时,此函数返回 /。 从 v4.3.2 开始,错误已修复,它返回一个空字符串('')。

index_page([$altConfig = null])
参数:
  • $altConfig (\Config\App) – 要使用的备用配置

返回:

indexPage

返回类型:

string

返回配置文件中指定的你的站点 indexPage。例如:

<?php

echo index_page();

site_url() 一样,你可以指定备用配置。如果为不同于你自己的站点生成 URL,其中包含不同的配置首选项,则备用配置可能很有用。我们对框架本身使用它进行单元测试。

anchor([$uri = ''[, $title = ''[, $attributes = ''[, $altConfig = null]]]])
参数:
  • $uri (mixed) – URI字符串或URI段数组

  • $title (string) – 锚点标题

  • $attributes (mixed) – HTML属性

  • $altConfig (\Config\App) – 要使用的备用配置

返回:

HTML链接(锚点标签)

返回类型:

string

基于你的本地站点 URL 创建标准的 HTML 锚点链接。

第一个参数可以包含你希望附加到 URL 的任何段。与上面的 site_url() 函数一样,段可以是字符串或数组。

备注

如果你正在构建应用程序内部的链接,请不要包含基本 URL (http://...)。这将从配置文件中指定的信息自动添加。只包含你希望附加到 URL 的 URI 段。

第二段是你希望链接说的文本。如果留空,将使用 URL。

第三个参数可以包含你希望添加到链接的属性列表。属性可以是简单的字符串或关联数组。

这里有一些示例:

<?php

echo anchor('news/local/123', 'My News', 'title="News title"');
// Prints: <a href="http://example.com/index.php/news/local/123" title="News title">My News</a>

echo anchor('news/local/123', 'My News', ['title' => 'The best news!']);
// Prints: <a href="http://example.com/index.php/news/local/123" title="The best news!">My News</a>

echo anchor('', 'Click here');
// Prints: <a href="http://example.com/index.php">Click here</a>

如上所述,你可以指定备用配置。如果为不同于你自己的站点生成链接,其中包含不同的配置首选项,则备用配置可能很有用。我们对框架本身使用它进行单元测试。

备注

传递给 anchor 函数的属性会自动转义,以防止 XSS 攻击。

anchor_popup([$uri = ''[, $title = ''[, $attributes = false[, $altConfig = null]]]])
参数:
  • $uri (string) – URI字符串

  • $title (string) – 锚点标题

  • $attributes (mixed) – HTML属性

  • $altConfig (\Config\App) – 要使用的备用配置

返回:

弹出式超链接

返回类型:

string

几乎与 anchor() 函数完全相同,除了它在新窗口中打开 URL。你可以在第三个参数中指定 JavaScript 窗口属性以控制窗口的打开方式。如果未设置第三个参数,它将简单地用你自己的浏览器设置打开新窗口。

这里是一个带有属性的示例:

<?php

$atts = [
    'width'       => 800,
    'height'      => 600,
    'scrollbars'  => 'yes',
    'status'      => 'yes',
    'resizable'   => 'yes',
    'screenx'     => 0,
    'screeny'     => 0,
    'window_name' => '_blank',
];

echo anchor_popup('news/local/123', 'Click Me!', $atts);

如上所述,你可以指定备用配置。如果为不同于你自己的站点生成链接,其中包含不同的配置首选项,则备用配置可能很有用。我们对框架本身使用它进行单元测试。

备注

上述属性是函数默认值,所以你只需要设置与你需要的不同的那些。如果你希望函数使用所有默认值,只需在第三个参数中传递一个空数组:

<?php

echo anchor_popup('news/local/123', 'Click Me!', []);

备注

window_name 实际上不是一个属性,而是 window.open() 方法接受的一个参数,它接受窗口名称或窗口目标。

备注

除上述之外的任何其他属性都将作为 HTML 锚点标记的属性进行解析。

备注

传递给 anchor_popup 函数的属性会自动转义,以防止 XSS 攻击。

mailto($email[, $title = ''[, $attributes = '']])
参数:
  • $email (string) – 电子邮件地址

  • $title (string) – 锚点标题

  • $attributes (mixed) – HTML属性

返回:

“发送邮件到”超链接

返回类型:

string

创建标准的 HTML 电子邮件链接。使用示例:

<?php

echo mailto('me@my-site.com', 'Click Here to Contact Me');

如上面的 anchor() 选项卡一样,你可以使用第三个参数设置属性:

<?php

$attributes = ['title' => 'Mail me'];
echo mailto('me@my-site.com', 'Contact Me', $attributes);

备注

传递给 mailto 函数的属性会自动转义,以防止 XSS 攻击。

safe_mailto($email[, $title = ''[, $attributes = '']])
参数:
  • $email (string) – 电子邮件地址

  • $title (string) – 锚点标题

  • $attributes (mixed) – HTML属性

返回:

防垃圾邮件的“发送邮件到”超链接

返回类型:

string

mailto() 函数完全相同,除了它使用序数数字与 JavaScript 编写的隐写版本来帮助防止垃圾邮件机器人收集电子邮件地址。

参数:
  • $str (string) – 输入字符串

  • $type (string) – 链接类型(‘email’、’url’ 或 ‘both’)

  • $popup (bool) – 是否创建弹出链接

返回:

链接化的字符串

返回类型:

string

自动将字符串中包含的 URL 和电子邮件地址转换为链接。示例:

<?php

$string = auto_link($string);

第二个参数确定是转换 URL 和电子邮件还是仅转换其中一个。如果未指定参数,默认行为是两者都转换。电子邮件链接编码为上面显示的 safe_mailto()

仅转换 URL:

<?php

$string = auto_link($string, 'url');

仅转换电子邮件地址:

<?php

$string = auto_link($string, 'email');

第三个参数确定是否在新窗口中显示链接。值可以为 true 或 false(布尔值):

<?php

$string = auto_link($string, 'both', true);

备注

仅识别以 www.:// 开头的 URL。

url_title($str[, $separator = '-'[, $lowercase = false]])
参数:
  • $str (string) – 输入字符串

  • $separator (string) – 单词分隔符(通常为 '-''_')

  • $lowercase (bool) – 是否将输出字符串转换为小写

返回:

URL 格式化的字符串

返回类型:

string

获取一个字符串作为输入,并创建一个人性化的 URL 字符串。例如,如果你有一个博客,希望在 URL 中使用条目的标题。示例:

<?php

$title     = "What's wrong with CSS?";
$url_title = url_title($title);
// Produces: Whats-wrong-with-CSS

第二个参数确定单词分隔符。默认使用破折号。首选选项是: - (破折号)或 _ (下划线)。

示例:

<?php

$title     = "What's wrong with CSS?";
$url_title = url_title($title, '_');
// Produces: Whats_wrong_with_CSS

第三个参数确定是否强制使用小写字符。默认不强制。选项是布尔值 true/false。

示例:

<?php

$title     = "What's wrong with CSS?";
$url_title = url_title($title, '-', true);
// Produces: whats-wrong-with-css
mb_url_title($str[, $separator = '-'[, $lowercase = false]])
参数:
  • $str (string) – 输入字符串

  • $separator (string) – 单词分隔符(通常为 '-''_')

  • $lowercase (bool) – 是否将输出字符串转换为小写

返回:

URL 格式化的字符串

返回类型:

string

此函数的工作方式与 url_title() 相同,但它会自动转换所有重音字符。

prep_url([$str = ''[, $secure = false]])
参数:
  • $str (string) – URL字符串

  • $secure (boolean) – true 为 https://

返回:

带协议前缀的 URL 字符串

返回类型:

string

如果 URL 中缺少协议前缀,此函数将添加 http://https://

如下传入 URL 字符串给函数:

<?php

$url = prep_url('example.com');
url_to($controller[, ...$args])
参数:
  • $controller (string) – 路由名称或 Controller::method

  • ...$args (mixed) – 要传递给路由的一个或多个参数。最后一个参数允许你设置区域设置。

返回:

绝对 URL

返回类型:

string

备注

此函数要求在 app/Config/Routes.php 中为控制器/方法定义路由。

在你的应用程序中构建指向控制器方法的绝对 URL。示例:

<?php

// The route is defined as:
$routes->get('/', 'Home::index');

?>

<a href="<?= url_to('Home::index') ?>">Home</a>
<!-- Result: 'http://example.com/' -->

你还可以向路由添加参数。这是一个示例:

<?php

// The route is defined as:
$routes->get('pages/(:segment)', 'Page::index/$1');

?>

<a href="<?= url_to('Page::index', 'home') ?>">Home</a>
<!-- Result: 'http://example.com/pages/home' -->

这很有用,因为即使在将链接放入视图后,你仍然可以更改路由。

从 v4.3.0 开始,当你在路由中使用 {locale} 时,你可以可选地将区域设置值指定为最后一个参数。

<?php

// The route is defined as:
$routes->add(
    '{locale}/users/(:num)/gallery/(:num)',
    'Galleries::showUserGallery/$1/$2',
    ['as' => 'user_gallery']
);

?>

<a href="<?= url_to('user_gallery', 15, 12, 'en') ?>">View Gallery</a>
<!-- Result: 'http://example.com/en/users/15/gallery/12' -->

有关完整详细信息,请参阅 反向路由使用命名路由

url_is($path)
参数:
  • $path (string) – 要比较当前 URI 路径的相对于 baseURL 的 URL 路径。

返回类型:

boolean

将当前 URL 的路径与给定路径进行比较,以查看它们是否匹配。示例:

<?php

if (url_is('admin')) {
    // ...
}

这将匹配 http://example.com/admin。如果你的 baseURL是 http://example.com/subdir/,它将匹配 http://example.com/subdir/admin

你可以使用 * 通配符来匹配 URL 中的任何其他可应用字符:

<?php

if (url_is('admin*')) {
    // ...
}

这将匹配以下任何一个:

  • /admin

  • /admin/

  • /admin/users

  • /admin/users/schools/classmates/…