HTTP Request 对象和处理本地请求

发布于 2024-08-08 21:11:44 字数 489 浏览 13 评论 0原文

我有一个 Web 应用程序,它使用 CDO Message 对象通过电子邮件发送报告。

例如:

Dim objCDO
Set objCDO = Server.CreateObject("CDO.Message")
objCDO.CreateMHTMLBody "http://server/report.asp"

问题在于,当它向 IIS 发出请求时,它不会继承登录用户的 ASP 会话身份,即在允许访问内容之前用于验证请求的会话变量为空。这使得身份验证变得困难,迫使我添加一个查询字符串变量(因为如您所见,您无法向此请求添加表单变量),例如:

objCDO.CreateMHTMLBody "http://server/report.asp?userid=xx&password=xx"

当然,报告中必须有一种授权方法来检查请求是否来自本地计算机,即邮件程序脚本中的 CDO 对象,从而不需要身份验证?

I have a web application that uses the CDO Message object to email reports.

For example:

Dim objCDO
Set objCDO = Server.CreateObject("CDO.Message")
objCDO.CreateMHTMLBody "http://server/report.asp"

The problem is that when it makes its request to IIS, it does not inherit the ASP session identity of the logged in user i.e. the session variables used to authenticate requests before permitting access to the content are blank. This makes authentication tough, forcing me to add a querystring variable (because as you can see, you cant add a form variable to this request) like:

objCDO.CreateMHTMLBody "http://server/report.asp?userid=xx&password=xx"

SURELY there must be a way of the authorisation in the report to check whether the request came from the local machine i.e. the CDO object in the mailer script, thus negating the need for authentication?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

双马尾 2024-08-15 21:11:44

只是不要这样做!由于这些原因: -

  • 向服务器发出第二个请求将导致当前线程阻塞,如果线程太多,应用程序将会死锁。
  • CreateHTMLBody 内部使用 WinINET http 堆栈来发出请求。该堆栈旨在用于客户端交互场景。在服务器场景中它不是线程安全的。
  • 您会丢失所有会话上下文,因此它可以(正如您所发现的那样)使某些事情变得更加困难或安全性降低。此外,它还会创建大量不需要的会话。

虽然它真正的 CreateHTMLBody 非常方便,但它也可能会创建臃肿的电子邮件。在服务器情况下,您确实需要使用代码来编写电子邮件,而不是使用这种诱人的方法。

编辑

看来 Jimbo 考虑的不仅仅是 CreateHTMLBody 更通用的场景。一般情况是,在 ASP 页面(我们将其指定为“客户端页面”)中使用组件(使用者无法控制该组件),并且它向另一个 ASP 页面(我们将其指定为“客户端页面”)发出后续请求(可能通过 WinINET)。将指定其为“服务页面”)。假设“客户端页面”唯一可以控制组件的使用的是提供给它的 URL。

以下是一些避免或减轻上述问题的方法。

处理锁定问题:将“客户端页面”和“服务页面”放在不同的 ASP 应用程序中可以避免锁定问题。我的建议是将“客户端页面”放置在与应用程序其余部分不同的应用程序中,并且这个新应用程序将位于主应用程序的子文件夹中。

处理 WinINET 问题:将新应用程序放入其自己的应用程序池中。如果以不安全的方式使用 WinINET 确实导致了问题,它不会影响主应用程序进程。事实上,将其放在自己的流程中可能有助于避免此类问题。 (这里不能保证,但这是完全避免 WinINET 问题的最佳方法)。

控制安全性:将“服务页面”配置为仅接受来自“客户端页面”的请求。可能有多种方法可以做到这一点,但最简单的是启用基于 IP 的安全性,对“服务页面”的请求只能来自特定 IP 或至少一组有限的 IP 地址。

处理身份验证:在主应用程序登录期间创建一个包含某些唯一值的易失性 cookie。由于浏览器将“客户端页面”视为主应用程序的子文件夹,因此它将接收此 cookie。 “客户端页面”可以使用此 cookie 来确认请求的真实性和/或在使用组件时将其传递到 URL 中。

抑制大量会话创建:让“服务页面”在完成其操作之前调用Session.Abandon

Just don't do it! For these reasons:-

  • Making a second request back into the server will cause the current thread to block, if you have too many of these you will deadlock the application.
  • CreateHTMLBody internaly uses the WinINET http stack to make the request. This stack is intended for use in client interactive scenarios. In the server scenario it isn't thread-safe.
  • You lose all session context so it can (as you are discovering) make somethings more difficult or less secure. In addition it can create a load of unwanted sessions.

Whilst its true CreateHTMLBody can be very convienient it can also create bloated emails. In the server situation you really need to craft the email with code rather than use this tempting method.

Edit

It seems Jimbo has more general scenarios in mind than just CreateHTMLBody. The general scenario is that a component (over which the consumer has no control) is used in an ASP page (we will designate this the "Client Page") and it makes a subsequent request (potentially via WinINET) to another ASP page (we will designate this the "Service Page"). There is the assumption that the only thing the "Client Page" can control about the usage of the component is the URL supplied to it.

Here are some approaches to avoid or mitigate the issues outlined above.

Handling Locking Problems: Placing the "Client Page" and the "Service Page" in different ASP application would avoid the locking issues. My suggestion would be place the "Client Page" in a different application to the rest of the application and that this new application would be in sub folder of the main application.

Dealing with WinINET issues: Place the new application in its own application pool. If using WinINET in an unsafe manner does cause a problem it doesn't affect the main application process. Indeed placing it in its own process may help avoid such problems. (No guarantees here but its the best you can get to avoiding WinINET issues completely).

Controlling security: Configure the "Service Page" to only accept requests from the "Client Page". There are probably a number of ways to do this but the simplest is to enable IP based security, the requests to the "Service Page" should only be coming from a specific IP or at least a limited set of IP addresses.

Handling authentication: During the main application logon create a volatile cookie containing some unique value. Since the "Client Page" is perceived as a sub-folder of the main application by the browser it will receive this cookie. The "Client Page" can use this cookie to confirm the authenticity of the request and/or pass it in the URL when using the component.

Supressing prolific session creation: Have the "Service Page" call Session.Abandon before it completes its operation.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文