文章
· 十月 12, 2022 阅读大约需 3 分钟

第十四章 CSP 中的 HTTP 请求 - CSP.Page 类

第十四章 CSP 中的 HTTP 请求 - CSP.Page 类

CSP 服务器上,所有 HTTP 请求都通过调用由类中的 %CSP.Page 定义的方法来处理。类中的 %CSP.Page 从不直接处理请求本身;它只是定义了处理 HTTP 请求所需的接口。实际的事件处理的 %CSP.Page 的子类完成(手动创建或作为处理 CSP 源文件的结果)。

%CSP.Page 的子类永远不会被实例化;也就是说,不会在对象中创建 %CSP.Page%CSP.Page 定义的方法都是类方法,不需要对象即可调用。正如我们将看到的,这些方法所需的任何状态信息都由 CSP 服务器管理的其他对象(例如%CSP.Request 和对象中的 %CSP.Session)提供。

Page 方法

CSP 服务器确定类中的哪个 %CSP.Page 应该处理请求后,它会设置适当的处理上下文,然后调用该类的 Page 方法。设置处理上下文包括重定向标准输出设备 ($IO),以便将所有输出(使用 Write 命令)发送回 HTTP 客户端并创建任何所需对象的实例(例如 %request%response%session 对象)或局部变量。

Page 方法处理对 HTTP 请求的完整响应。它通过按顺序调用回调方法 OnPreHTTPOnPageOnPostHTTP 来做到这一点。这些被称为回调方法,因为子类可以覆盖它们以提供自定义行为。

OnPreHTTP 方法负责写出 HTTP 响应的标头。这包括内容类型和 cookie 等信息。默认行为是将内容类型设置为 text/html。在需要更直接地控制响应标头的情况下,通常只需要覆盖 OnPreHTTP 方法。

OnPage 方法执行响应 HTTP 请求的大部分工作。它负责写出请求的主体,例如 HTMLXML 文档。

例如,下面是一个包含 OnPage 方法的示例 CSP 类:

Class MyApp.Page Extends %CSP.Page
{
ClassMethod OnPage() As %Status
{
    Write "<html>",!
    Write "<body>",!
    Write "My page",!
    Write "</body>",!
    Write "</html>",!
    Quit $$$OK
}
}

提供 OnPostHTTP 方法是为了在 HTTP 请求处理完成后执行希望执行的任何操作。

%CSP.Page 类参数

类中的 %CSP.Page 包含许多类参数,可以覆盖这些参数以提供自定义行为,而无需编写代码。

如果正在以编程方式开发应用程序,则可以在创建覆盖 %CSP.Page的子类中的这些类参数(例如,使用 Studio 中的类编辑器)。

如果使用 .csp 文件创建页面,则可以使用 csp:class 标记为这些参数提供值:

<csp:class PRIVATE="1">

按资源限制页面访问

使用 SECURITYRESOURCE 参数来限制对 CSP 页面的访问。 SECURITYRESOURCE 采用逗号分隔的系统资源列表和相关权限。可以使用竖线 (|) 指定 OR 条件,使用逗号 (,) 指定 AND 条件。用户必须拥有对所有指定资源的指定权限才能查看此页面或从客户端调用任何页面的服务器端方法。

Resource[:Permission]

资源是在此系统上设置的任何资源。导航到系统管理 > 安全 > 资源以获取资源列表。

权限是 USEREADWRITE 之一。可选的;默认为USE

R1,R2|R3,R3|R4

此示例意味着用户必须拥有资源 R1 和 (R2 OR R3) 之一和 (R3 OR R4) 之一。如果用户有 R1,R3 他们可以运行页面。如果用户有 R1,R4,他们不能运行页面,因为他们不满足 R2 OR R3 条件。竖线 (|) OR 条件优先于逗号 (,) AND 条件。

讨论 (0)1
登录或注册以继续