`

[转]关于Apache的内容协商

阅读更多

该功能使得服务器可以根据agent指定的http头来选择合适的资源。
涉及的http头包括: Accept-*
涉及的Apache中的知识: 类型表

1。 需要模块 : modules/mod_negotiation.so
2。 需要在目录的Options中添加: MultiViews;  如: Options FollowSymLinks MultiViews Indexes
3。 参考文档: http://apache.jz123.cn/content-negotiation.html
4。 该功能可能会影响到rewrite,参考: http://www.linuxpk.com/4941.html

apache根据你给的资源名称a,查找所有的a.*资源,加入有两种资源: a.txt 和a.php, 在类型表中查出:
.txt 对应文档类型为: text/plain 
.php 对应文档类型为: application/x-httpd-php

如果请求时使用的 accept为:
text/plain ,则返回a.txt
如果请求时使用的 accept为: application/x-httpd-php ,则返回a.php
如果请求时使用的accept为: text/none ,找不到这种类型,则协商失败,apache返回406,并返回所有可用的类型列表,如:

Not Acceptable

An appropriate representation of the requested resource /a could not be found  on this server.

Available variants:

        
  • a.php , type application/x-httpd-php
  •     
  • a.txt , type text/plain

Apache可以协商的内容基本有四类:

  1. 文档类型: content-type, 通过accept来说明
  2. 语言: language, 通过accept-language来说明
  3. 字符集: charset, 通过accept-charset来说明
  4. 编码: encoding, 通过accept-encoding来说明; (注意是传输过程的编码,不是字符的编码)

相关源码参考:
modules/mappers/mod_negotiation.c

  1. typedef struct {
  2.     apr_pool_t *pool;
  3.     request_rec *r;
  4.     neg_dir_config *conf;
  5.     char *dir_name;
  6.     int accept_q;               /* 1 if an Accept item has a q= param */
  7.     float default_lang_quality; /* fiddle lang q for variants with no lang */
  8.     /* the array pointers below are NULL if the corresponding accept
  9.      * headers are not present
  10.      */
  11.     apr_array_header_t *accepts;            /* accept_recs */
  12.     apr_array_header_t *accept_encodings;   /* accept_recs */
  13.     apr_array_header_t *accept_charsets;    /* accept_recs */
  14.     apr_array_header_t *accept_langs;       /* accept_recs */
  15.     apr_array_header_t *avail_vars;         /* available variants */
  16.     int count_multiviews_variants;     /* number of variants found on disk */
  17.     int is_transparent;       /* 1 if this resource is trans. negotiable */
  18.     int dont_fiddle_headers;   /* 1 if we may not fiddle with accept hdrs */
  19.     int ua_supports_trans;     /* 1 if ua supports trans negotiation */
  20.     int send_alternates;       /* 1 if we want to send an Alternates header */
  21.     int may_choose;           /* 1 if we may choose a variant for the client */
  22.     int use_rvsa;             /* 1 if we must use RVSA/1.0 negotiation algo */
  23. } negotiation_state;

对于协商的表达方式都是一样的,如:

Accept: */*
Accept-Language: zh-cn,zh;q=0.5
Accept-Encoding: gzip,deflate
Accept-Charset: GB2312,utf-8;q=0.7,*;q=0.7

其中“,”和“;”的分隔或许不太好明白其含义,其实,其格式是这样的:
name;q=N;charset=TEXT
如果要表达多组,则用“,”分隔;如:
name;q=N;charset=TEXT,name;q=N;charset=TEXT

其中,q、charset都是可以省略的,如:
Accept: */*
只有一组说明,而且是省略了q和charset


相关源码参考:
modules/mappers/mod_negotiation.c

  1. typedef struct accept_rec {
  2.     char *name;                 /* MUST be lowercase */
  3.     float quality;
  4.     float level;
  5.     char *charset;               /* for content-type only */
  6. } accept_rec;


关于文档类型的协商依赖的是: docs/conf/mime.types
如:
文档类型                     资源扩展名
text/html                   html htm
text/css                    css
text/plain                  txt text conf def list log in  

关于语言和字符集的协商依赖的是: docs/conf/charset.conv
如:
# Lang-abbv Charset     Language
#---------------------------------
en          ISO-8859-1  English
UTF-8       utf8        UTF-8  
Unicode     ucs         Unicode
th          Cp874       Thai    
ja          SJIS        Japanese
ko          Cp949       Korean  
zh          Cp950       Chinese-Traditional
zh-cn       GB2312      Chinese-Simplified
zh-tw       Cp950       Chinese
。。。

其中,第一列是语言的缩写,协商时一般用缩写; 第二列是字符集


---------------------------
内容可能是根据多个条件来协商的,那么对于一个协商的资源可能涉及到多个扩展名的,如:
content.en.html.gz
该资源如果写成了:
content.html.en.gz
也是可以找到的,只是在做超链接的时候,如果写成了: content.gz.html.en 就找不到了
参考: http://httpd.apache.org/docs/2.2/content-negotiation.html#naming

关于内容协商与cache
对于http1.0来讲,经过协商的内容是不建议cache的;在http1.1中添加了vary的http头,用来告知客户端内容是根据哪些条件来协商的,这样客户端可以尽可能的利用cache,如果协商条件不变的话就可以使用cache的。

====================
参考资料:

http://httpd.apache.org/docs/2.2/content-negotiation.html
http://httpd.apache.org/docs/2.2/mod/mod_negotiation.html

 

原文地址:http://phpor.net/blog/post/786/

分享到:
评论

相关推荐

    apache2.4.35,apache2.4.23

    标题中的"apache2.4.35"和"apache2.4.23"指的是Apache服务器的两个不同版本,其中2.4.35是较新的版本,而2.4.23则相对旧一些。 Apache 2.4系列是Apache服务器的一个主要分支,引入了许多新特性和性能优化。以下是...

    Apache技术文档

    这份文档涵盖了从Apache HTTP Server的版本升级指导、新特性介绍到详细的服务器配置指南,特别是它包含了服务器的全局配置、特定模块配置、环境变量设置、错误处理、日志文件管理、URL映射、动态共享对象(DSO)支持...

    apache中文手册(html)

    内容协商 动态共享对象(DSO) 环境变量 日志文件 从URL到文件系统的映射 性能调整 安全方面的提示 服务器全局配置 SSL/TLS 加密 CGI脚本的Suexec执行 URL重写指南 虚拟主机 如何.../指南 认证、授权、...

    Apache2 中文使用手册

    `content-negotiation.html`讨论了内容协商,这是Apache2的一种特性,允许服务器根据客户端的能力和偏好(如语言、编码或版本)来提供最合适的资源。 `suexec.html`可能涵盖了suEXEC工具的使用,这是一个安全机制,...

    Apache The Definitive Guide 3rd Edition

    - **内容协商**:探讨了如何根据客户端请求的偏好(如语言、媒体类型)来提供最合适的网页内容。 - **过滤器应用**:介绍了一系列用于处理和修改内容的Apache过滤器,包括压缩、加密等功能。 ### 6. 索引优化 - **...

    ApacheV2.0中文手册

    内容协商 动态共享对象(DSO) 环境变量 日志文件 从URL到文件系统的映射 性能调整 安全方面的提示 服务器全局配置 SSL/TLS 加密 CGI脚本的Suexec执行 URL重写指南 虚拟主机 如何.../指南 认证、授权、...

    Apache2.2中文版参考手册

    内容协商 动态共享对象(DSO) 环境变量 日志文件 从URL到文件系统的映射 性能调整 安全方面的提示 服务器全局配置 SSL/TLS 加密 CGI脚本的Suexec执行 URL重写指南 虚拟主机 如何.../指南 认证、授权、...

    apache 2.2.34 win32 httpd 最终维护版

    7. **内容协商**:服务器可以根据客户端的偏好(如语言、编码等)提供最合适的资源版本,提高用户体验。 在`Win32-2.2.34 VC10`目录下,你可以找到适用于32位Windows系统的编译版本。VC10指的是使用Visual Studio ...

    Apache v2.2.9 Windows版源码包 著名的APACHE服务器最新版的VC++源码包,编译即可使用。同时也是学习的好范例。

    7. **内容协商**:根据客户端的Accept头信息,Apache可以自动选择最适合的资源版本,如HTML、XML、JSON等。 8. **缓存机制**:通过mod_cache模块,Apache可以缓存静态内容,提高响应速度。 9. **URL重写**:mod_...

    apache2.4 X64版本

    9. **安全强化**:除了基本的SSL/TLS支持,Apache 2.4还引入了更多安全特性,如HTTP/2的优先级协商,以及抵御跨站脚本攻击(XSS)和跨站请求伪造(CSRF)的防护。 10. **模块更新**:许多核心模块如`mod_headers`, ...

    Apache HTTP Server Documentation Version 2.2.pdf

    6. **模块支持**:介绍了Dynamic Shared Object (DSO) 支持,内容协商以及自定义错误响应。 7. **多处理模块(MPMs)**:文档解释了Apache中多种MPMs的工作原理及其配置方法。 8. **环境变量**:探讨了Apache...

    apache 源代码

    10. **URL映射与内容协商**:Apache通过mod_rewrite模块可以实现URL重写和内容协商,这对于网站的SEO和动态内容分发至关重要。 11. **虚拟主机**:Apache支持在同一台服务器上运行多个独立的网站,源代码会揭示如何...

    apache2.4.msi安装版+win7+64位

    4. **安全性增强**:Apache 2.4增加了更多安全特性,如HTTP/2的ALPN支持,用于TLS协议协商,以及新的模块如mod_security,提供Web应用防火墙功能。 5. **配置改进**:配置文件语法有所调整,使得配置更加简洁且易于...

    基于apache的网络通信模型

    为了优化基于Apache的网络通信模型,开发者还可以考虑使用HTTP/2协议,它允许在一个TCP连接上复用多个HTTP请求,减少了TCP握手和SSL/TLS协商的开销。此外,还可以启用HTTP压缩来减小传输的数据量,或者使用缓存技术...

    Apache HTTP Server Version 2.2 文档(2013.4.10最新)

    内容协商 自定义错误响应 动态共享对象(DSO)支持 Apache的环境变量 过滤器(Filter) 词汇表 Apache处理器的使用 Apache HTTP Server Version 2.2 文档 编译与安装 启动Apache Apache许可证 2.0 版 日志文件 多路处理...

    Apache+2.2+中文手册

    5. **content-negotiation.html** - 内容协商:Apache支持内容协商,允许服务器根据客户端的能力和偏好返回合适的响应,比如选择不同的语言或编码。这部分会讲解如何配置服务器以实现这一功能。 6. **install.html*...

    apache 中文参考手册

    内容协商是Apache服务器根据客户端能力(如浏览器类型、语言偏好等)提供最合适的资源的方式。这个主题可能包括如何设置HTTP头部,以使服务器自动选择最佳的内容版本。 6. **suexec.html** - suEXEC机制 suEXEC是...

    Apache SSL 加密機制

    Apache SSL(Secure Sockets Layer)加密机制是网络服务器安全配置中的关键组成部分,它为Web通信提供了数据加密、服务器身份验证和消息完整性检查等安全保障。在本文中,我们将深入探讨Apache SSL加密机制的工作...

    Apache2.2中文手册

    内容协商 动态共享对象(DSO) 环境变量 日志文件 从URL到文件系统的映射 性能调整 安全方面的提示 服务器全局配置 SSL/TLS 加密 CGI脚本的Suexec执行 URL重写指南 虚拟主机 如何.../指南 认证、授权、...

Global site tag (gtag.js) - Google Analytics