PHP Conference Japan 2024

apache_lookup_uri

(PHP 4, PHP 5, PHP 7, PHP 8)

apache_lookup_uri对指定的 URI 执行部分请求并返回其所有信息

描述

apache_lookup_uri(字符串 $filename): 对象|false

这将对 URI 执行部分请求。它只进行足够的处理以获取有关给定资源的所有重要信息。

当 PHP 作为 Apache 模块 Web 服务器安装时,支持此函数。

参数

filename

正在请求的文件名(URI)。

返回值

一个包含相关 URI 信息的对象。此对象的属性为:

  • status
  • the_request
  • status_line
  • method
  • content_type
  • handler
  • uri
  • filename
  • path_info
  • args
  • boundary
  • no_cache
  • no_local_copy
  • allowed
  • send_bodyct
  • bytes_sent
  • byterange
  • clength
  • unparsed_uri
  • mtime
  • request_time

失败时返回false

示例

示例 #1 apache_lookup_uri() 示例

<?php
$info
= apache_lookup_uri('index.php?var=value');
print_r($info);

if (
file_exists($info->filename)) {
echo
'文件存在!';
}
?>

以上示例将输出类似于以下内容:

stdClass Object
(
    [status] => 200
    [the_request] => GET /dir/file.php HTTP/1.1
    [method] => GET
    [mtime] => 0
    [clength] => 0
    [chunked] => 0
    [content_type] => application/x-httpd-php
    [no_cache] => 0
    [no_local_copy] => 1
    [unparsed_uri] => /dir/index.php?var=value
    [uri] => /dir/index.php
    [filename] => /home/htdocs/dir/index.php
    [args] => var=value
    [allowed] => 0
    [sent_bodyct] => 0
    [bytes_sent] => 0
    [request_time] => 1074282764
)
file exists!

添加注释

用户贡献的注释 3 条注释

2
tester
16 年前
bug:使用 Apache 2 时,apache_lookup_uri("/directory") 会输出警告并无法返回任何内容。apache_lookup_uri("/directory/") 可以正常工作。

另一个 bug:virtual("something") 会强制刷新 header。我知道文档中已说明,但如果它不这样做会更好。当使用 virtual() 包含动态文件(例如 PHP 或 Perl 文件)时,您永远都不想刷新 header,这使得 virtual() 无法用于大多数网站内容 :-(。
1
niels dot kootstra at gmail dot com
16 年前
这是一个非常有用的函数,但它没有显示所有输出。例如,我只看到:
[status]
[the_request]
[method]
[mtime]
[clength]
[chunked]
[content_type]
[no_cache]
[no_local_copy]
[unparsed_uri]
[uri]
[filename]
[path_info]
[allowed]
[sent_bodyct]
[bytes_sent]
[request_time]
0
redbeard at mdjohnson dot nospam dot us
21 年前
一个有用的特性是,如果您启用了内容协商 (Options MultiViews),Apache 将尽可能为您解决协商问题。因此,www.example.com/blah 将根据需要解析为 /base/blah.php 或 /base/blah.html,甚至 /base/blah.en.html。
To Top