明辉站/技术开发/内容

APACHE(5)

技术开发2023-08-14 阅读
[摘要]4.8.1 SPML - 包含文件格式 这种文件被当作 HTML 文件剖析,并如同 SGML 的注解嵌入(embedded) 特殊的指令。指令一般的语法是: <!--# 项目属性=值 属性=值 ...--> 这里的值常包括在双引号里;许多指令只允许单一个属性-值的配对。 允许使用的项目...
4.8.1 SPML - 包含文件格式

这种文件被当作 HTML 文件剖析,并如同 SGML 的注解嵌入(embedded)
特殊的指令。指令一般的语法是:

<!--# 项目属性=值 属性=值 ...-->

这里的值常包括在双引号里;许多指令只允许单一个属性-值的配对。

允许使用的项目是:

config
这个指令控制各种剖析的方式。有效的属性是:

errmsg
此值是如果剖析文件发生错误时送回客户端的讯息。

sizefmt
此值是设定显示文件大小使用的格式。有效的值是使用
位元组计算的 bytes 或是以 Kb 或 Mb 中合适者显示
的 abbrev 。

timefmt
此值是列印日期时由 strftime(3) 程序库函式使用的
字串。

echo
这个指令列印内涵的参数其中之一,定义如下。如果该参数未被
设定则印出(none)。印出的任何日期都依从目前配置的 timefmt
。属性:

var
此值是要印出之参数的名称。

exec
此指令执行所给 shell 指令或 CGI 指令稿。InculdesNOEXEC
这个选项可以完全关闭这个指令。有效的属性是:

cgi
此值指定 (%-encode)URL 到 CGI 指令稿的相对路径
。如果该路径没有以(/) 作为开始,那麽它就是相对於
目前的文件。这个路径所参照的文件会被当作是个 CGI
指令稿起动,即使服务器并不认为它是个 CGI 指令稿
。然而,包含该指令稿的目录必须打开 CGI 指令稿的
支援(以 ScriptAlias 或 ExecCGI 选项打开)。
从客户端来的请求给予此指令稿 PATH_INFO 以及查询
字串(QUERY_STRING);但这无法在 URL 路径中指定。
所以在标准的 CGI 环境参数之外指令稿可以从内含的
参数取得这些资讯。
如果该指令稿回传 Location: 标头而不是一般的输出
,那麽这将会被转换成 HTML 的链结。
include virtual 这个项目应该用来参照 exec cgi 。

cmd
服务器将会以 /bin/sh 执行所给的字串。这个指令可
以取得内含的参数。

fsize
这个指令印出指定文件的大小,并依从 sizefmt 的格式指定。
属性:

file
此值是包含要剖析之文件的目录之相对路径。

virtual
此值是相对於要剖析之文件的 (%-encoded) URL 路径
。如果该路径没有以(/) 作为开始,那麽它就是相对於
目前的文件。

flastmod
这个指令印出指定文件最後修改的日期,依从 timefmt 的格式
指定。属性与 fsize 指令的属性一样。

include
这个指令插入另一份文件或文件的内容到要剖析的文件里。任何
含入的文件都依从通常的存取控制。如果包含剖析文件的目录设
有 IncludesNOEXEC 选项,而且含入该文件会起动某支程序的话
,那麽它将不会被含入;这阻止 CGI 指令稿的执行。否则 CGI
指令稿就会如同一般在指令中使用完整的 URL 指定的一样执行
,包含任何查询字串。
有个属性定义文件的位置:

file
此值是包含目前要剖析之文件的目录之相对路径。它不
能包含有 ../ 也不能是绝对路径。virtual 这个属性
永远应该用来参照这一个。

virtual
此值是相对於目前要剖析之文件的 (%-encoded)URL 。
此 URL 不能包含有动作(scheme)或主机名称,只能是
路径或选用的查询字串。如果它不是以倒斜线(/) 作为
开始那麽它就是相对於目前的文件。

URL 是由属性建构的,如果客户端请求的 URL 包含在被剖析的
输出则服务器会回传该输出。因此含入的文件可以是巢状的。


4.8.2 内含的参数

这些参数可以提供给 echo 指令,以及任何由文件起动的程序取用。

DATE_GMT
目前的格林威治日期。

DATE_LOCAL
目前当地时间区域的日期。

DOCUMENT_NAME
使用者请求之文件的文件名称(不包括目录)。

DOCUMENT_URI
使用者请求之文件的 (%-decoded)URL 路径。注意,在巢状含入
文件这种情况下,这不会是目前文件的 URL 。

LAST_MODIFIED
使用者要求之文件最後修改的日期。


4.8.3 XBitHack

语法: XBitHack 状态
语法
预设: XBitHack off
用於: server config, virtual host, directory, .htaccess
需求: Options
状态: 基础
模组: mod_include

XBitHack 这个指令控制一般 html 文件的剖析。状态可以是下列值:

off
对可执行的文件一视同仁。

on
任何设有代表使用者可执行之位元的文件将被当作是服务端剖析
的 html 文件。

full
与 on 相同但同时还测试代表群组可执行之位元。如果有设定,
那麽不会送出最後修改日期。设定这个位元使客户端以及代理者
(proxies) 可以暂存请求的结果。


4.9 mod_log_common 模组

这个模组包含在 mod_log_common.c 文件里,而且依预设会编译进来。
它提供使用一般记录档格式(Common Logfile Format) 记录对服务器之
请求的功能。


4.9.1 记录档格式

对於每个请求记录档包含个别的一行。一行是由数个以空白间隔的记
号所组成:

host ident authuser date request status bytes

如果某个记号没有值就会以短线(-) 表示。这些记号以及其代表的意义
如下:

host
客户端的完整域名,或者如果无法取得其名称的话
则记录 IP 位址

ident
如果开启 IdentityCheck 功能而且客户端机器执行有
identd 的话,那麽这会是客户端所报告的 identity
资讯。

authuser
如果请求的是密码保护的文件,那麽这会是请求中使用
的使用者识别码。

date
请求的日期以及时间,使用下列的格式:
date = [day/month/year:hour:minute:second
zone]
day = 2*数字
month = 3*字元
year = 4*数字
hour = 2*数字
minute = 2*数字
second = 2*数字
zone = ('+' '-') 4*数字

request
从客户端传来的请求行,以双引号(") 括起。

status
回传给客户端,三位数字的状态码。

bytes
回传给客户端的位元组数量,报包含任何标头。


4.9.2 TransferLog

语法: TransfetLog 文件-管线
预设: TransferLog logs/transfer_log
用於: server config, virtual host
状态: 基础
模组: mod_log_common

TransferLog 这个指令设定服务器记录进入之请求的文件名称。文件-
管线是这些其中之一:

一个文件名称
一个相对於 ServerRoot 的文件名称

` ' 跟随著一个指令
从标准输入接收参考记录资讯的程序。注意如果虚拟主机从主要
服务器继承 RefererLog 设定的话不会起动新的程序。

安全: 如果在此使用程序,它将会以起动 httpd 的使用者身分执行。
如果服务器由 root 起动那麽此程序就是由 root 执行;所以要确定次
程序的安全性。


4.10 mod_mime 模组

这个模组包含在 mod_mime.c 文件里,而且依预设会编译进来。他提供
从文件名称决定文件型态的功能。


4.10.1 摘要

这个模组用来决定文件的 mime 型态。某些 mime 型态会指出服务器得
执行的特别程序,其它的型态则传回客户端,如此浏览器就可以适当地
处理文件。

文件的文件名称被当作基本名称的一部份,其後跟随某些副文件名,次序
如下:

base.type.language.enc

其中 type 这个副文件名设定文件的型态,型态定义在 TypesConfig 文件
以及 AddType 指令的设定中。而 language 这个副文件名设定文件的语言
,藉由 AddLanguage 指令定义。最後,enc 这个副文件名设定文件的编码
,藉由 AddEncoding 指令定义。


4.10.2 AddEncoding

语法: AddEncoding mime-enc 副文件名 副文件名
用於: server config, virtual host, directory, .htacess
需求: FileInfo
状态: 基础
模组: mod_mime

AddEncoding 这个指令以指定的编码型态把可能作为文件名称结尾的副
文件名加入文件副文件名列表。Mime-enc 是用在以该副文件名结尾的文件的
mime 编码。例如:

AddEncoding x-gzip gz
AddEncoding x-compress Z

这将会使以 .gz 结尾的文件被标记为使用 z-gzip 编码,以及 .Z 结
尾的文件被标记为使用 x-compress 编码。


4.10.3 AddLanguage

语法: AddLanguage mime-lang 副文件名 副文件名
用於: server config, virtual host, directory, .htaccess
需求: FileInfo
状态: 基础
模组: mod_mime

AddLanguage 这个指令以指定的语言把可能作为文件名称结尾的副文件名
加入文件副文件名列表。Mime-lang 是以此副文件名作为名称结尾之文件的
mime 语言,这是在所有作为编码的副文件名移除之後再决定的。例如:

AddEncoding x-compress Z
AddLanguage en .en
AddLanguage fr .fr

那麽 xxxx.ez.Z 将会被当作压缩过的英文文件。虽然内容的语言已经
报告给客户端,浏览器不太可能使用此资讯。AddLanguage 这个指令对
内容协商(content negotiation) 会更有用,这样服务器可以参考客户
端的语言回传数份文件中的一份。


4.10.4 AddType

语法: AddType mime-type 副文件名 副文件名
用於: server config, virtual host, directory, .htaccess
需求: FileInfo
状态: 基础
模组: mod_mime

AddType 这个指令以指定的内容型态把可能作为文件名称结尾的副文件名
。Mime-type 是用在以该副文件名结尾的文件的 mime 型态。这是在所有
作为编码以及语言的副文件名移除之後再决定的。例如:

AddType image/gif GIF

新的 mime 型态建议使用 AddType 指令加入而不要修改 TypesConfig
文件。

注意,与 NCSA httpd 不同,这个指令不能用来设定特殊文件的型态。


4.10.5 TypesConfig

语法: TypesConfig 文件名称
预设: TypesConfig conf/mime.types
用於: server config
状态: 基础
模组: mod_mime

TypesConfig 这个指令设定 mime 型态配置档所在的位置。文件名称是
相对於 ServerRoot 的。这个文件设定从文件扩充文件名对应内容型态的
预设列表;不建议变更这个文件。使用 AddType 指令取代对它做修改
。文件所包含的行是使用 AddType 指令的参数格式:

mime 型态 副文件名 副文件名 ...

副文件名是小写,空白行,以及('#') 起始的行会被忽略。


4.11 mod_negotiation 模组

这个模组包含在 mod_negotiation.c 文件里,而且依预设会编译进来
。它是提供作为内容协商之用的。任何文件如果它的 mime 型态之设定
为 application/x-type-map 则将会由这个模组处理。


4.11.1 摘要

内容协商,或更精确的说,内容选择,是从几份可以取用的文件中选择
最符合客户端能力的文件。这有两种实作的方法。

。明确列出包含差异之文件的型态对应(这就是使用 mime 型态
为 application/x-type-map 的文件)

。多重观点搜寻(藉由 MultiViews 选项开启),此时服务器会
执行隐含的文件名称样板对照,并从中选择结果。

型态对应

型态对应的格式与 RFC822 邮件标头相同。它包含以空白行间隔的文件
描述,以杂凑('#') 字元开头的行会被当作注解。文件描述由数种标头
记录组成;如果以空白作为连续行的开始那麽记录可以连续很多行。前
导的空白会被删除而这些行就可以连接起来。标头记录包含关键字名称
,这总是以冒号结尾,跟著一个值。在关键字与值之间,以及值的记号
之间允许空白。可以使用的标头是:

Content-Encoding:
文件的编码。目前藉由 http 只认得两种编码; compress 压缩
的文件是 x-compress 而 gzip 压缩的文件是 x-gzip 。

Content-Language:
不同的语言,使用网际网路标准语言码,像是 en 。

Content-Length:
文件的长度,单位是位元组。如果这个标头不存在,那麽就使用
该文件真实的长度。

Content-Type:
文件的 MIME 媒体型态,有选用的参数。参数以分号与媒体型态
及其它参数间隔。参数的语法是 名称=值;可以使用的参数是:

level
此值是整数,指出媒体型态版本。对於 text/html 此
预设为 2 而其它则为 0 。

qs
此值是浮点数其值在 0. 以及 1 之间。它指出差异的
‘质’。

例如:
Content-Type: image/jpeg; qs=0.8

URI:
包含这个有所差异的文件之 URL,相对於 map 文件。


多重观点

重观点搜寻是以 MultiViews 选项开启。如果该服务器接收到一个对於
/some/dir/foo 的请求而 /some/dir/foo 不存在的话,那麽服务器会
读取目录中所有名为 foo.* 的文件,并且有效地假造这些文件的型态
对应,如果客户端以名称查问它们就以相同的媒体型态以及内容编码来
指定它们。然後选择最符合客户端请求的一份,并且回传该文件。


4.11.2 LanguagePriority

语法: LanguagePriority mime-lang mime-lang
用於: server config, virtual host, directory, .htaccess
需求: FileInfo
状态: 基础
模组: mod_mime

LanguagePriority 这个指令是在处理多重观点请求时设定若有差异,
而客户端没有表示要参照何种语言的情况下的语言优先权。 mime-lang
列表是递减的顺序。例如:

LanguagePriority en fr de

请求 foo.html ,而 foo.html.fr 以及 foo.html.de 都存在,但浏
览器没有表示要参照的语言时,则回传 foo.html.fr 。


4.12 mod_userdir 模组

这个模组包含在 mod_userdir.c 文件里,而且依预设会编译进来。它
用来提供代表使用者的(user-specific) 目录。


4.12.1 UserDir

语法: UserDir directory
预设: UserDir public_html
用於: server config, virtual host
状态: 基础
模组: mod_userdir

UserDir 这个指令设定在使用者自家(home)目录里的一个真实目录,当
接收到一个对使用者文件所发出的请求时会使用这个目录。 Directory
可以是 Disable ,用来关掉这项特色,或者是一个目录的名称。如果
没有关掉,那麽以 http://myserver/~unix-username 作为开始的一个
URL 请求将会被转换成以 home-dir/directory 作为开始的文件名称,
其中 home-dir 是 unix-username 这个使用者的自家目录。
□例:

UserDir public_html

那麽一个对 http://myserver/~foo56/adir/file.html 的请求将传回
http://myserver/home/foo56/public_html/adir/file.html 文件。


第五章

阿帕奇扩充模组


5.1 mod_auth_dbm 模组

这个模组包含在 mod_auth_dbm.c 这个文件里,而且依预设不会编译进
去。它提供使用 DBM 文件做使用者验认的功能。参阅 DBM 的使用者
文件。


5.1.1 AuthDbmGroupFile

语法: AuthDBMGroupFile 文件名称
用於: directory, .htaccess
需求: AuthConfig
状态: 扩充
模组: mod_auth_dbm

AuthDBMGroupFile 这个文件设定作为验认用的 DBM 文件名称,其中
包含使用者群组的列表。文件名称是该群组文件的绝对路径。

这个文件是以使用者名称作为关键。而使用者後的值则是该使用者所属
群组的列表,以逗点分隔。此值不能有空白,而且不能包含冒号。

安全: 确定 AuthDBMGroupFile 存放在服务器的文件树之外;不要把它
放在它所要保护的目录里。否则客户端将能下载 AuthDBMGroupFile 。

参阅 AuthName, AuthType 以及 AuthDBMUserFile 。


……

标签:APACHE(5)
相关阅读