第十六章 CSP 中的 HTTP 请求 - %CSP.Request 对象
%CSP.Request 对象
当 CSP 服务器响应 HTTP 请求时,它将有关传入请求的信息打包到对象中的 %CSP.Request 实例中。可以使用变量 %request 来引用此对象。
URL 属性
要查找传入 HTTP 请求的 URL (不包括查询字符串),对象中使用 %CSP.Request 的 URL 属性:
Write "URL: ", %request.URL
数据属性和 URL 参数
URL 可能包含参数列表(也称为 URL 查询)对象中的 %CSP.Request 通过其 Data 属性使这些可用。
例如,假设传入的 URL 包含:
/csp/user/MyPage.csp?A=10&a=20&B=30&B=40
可以使用以下命令在服务器上检索这些参数:
Write %request.Data("A",1)
Write %request.Data("a",1)
Write %request.Data("B",1)
Write %request.Data("B",2)
数据是一个多维属性,其中存储的每个值都有 2 个下标:参数的名称和参数的索引号(参数可以在 URL 中多次出现,如上面的 B )。请注意,参数名称区分大小写。
另请注意,传入的 HTTP 请求是 GET 还是 POST 请求并不重要:Data 属性以完全相同的方式表示参数值。
可以使用 ObjectScript $Data ($D) 函数来测试是否定义了给定的参数值:
If ($Data(%request.Data("parm",1))) {
}
如果您希望引用一个参数但不确定它是否已定义,可以使用 ObjectScript $Get 函数:
Write $Get(%request.Data("parm",1))
可以在对象中使用 %CSP.Request 的 Count 方法找出为特定参数名称定义了多少值:
For i = 1:1:%request.Count("parm") {
Write %request.Data("parm",i)
}
CgiEnvs 属性和 CGI环境变量
Web 服务器提供一组值,称为 CGI (通用网关接口)环境变量,其中包含有关 HTTP 客户端和 Web 服务器的信息。可以使用多维属性 CgiEnvs 访问这些 CGI 环境值。可以按照与 Data 属性相同的方式使用它。
例如,要确定发出 HTTP 请求的浏览器类型,请查看 CGI 环境变量 HTTP_USER_AGENT 的值:
Write %request.CgiEnvs("HTTP_USER_AGENT")
Cookies 属性
如果 HTTP 请求包含任何 cookie ,可以使用多维属性 Cookies 检索它们的值。可以按照与 Data 属性相同的方式使用它。
数据也可以保存在 %session 对象中。
请参阅 CSP 示例数据库中 cookie.csp 中使用 cookie 的示例。
MIME 数据属性
传入请求可能包含 MIME (多用途 Internet 邮件扩展)数据。这通常用于较大的信息,例如文件。可以在对象中使用 %CSP.Request 检索 MIME 数据。这将创建并返回一个 Caché 流对象的实例,然后可以使用该实例来读取 MIME 数据。
有关使用 MIME 数据的示例,请参阅 CSP 示例中的 upload.csp 。
|