步骤
永远不要相信用户输入的内容具有适当的大小或者包含适当的字符在使用其做出决策之前应该始终对用户输入进行验证最佳的选择是创建一个 COM+ 组件这样您可以从 ASP 页面中调用该组件来验证用户的输入内容您也可以使用 ServerHTMLEncode 方法ServerURLEncode 方法或者本页底部代码示例中的某一个
不要通过连接用户输入的字符串来创建 ASP 页中的数据库连接字符串恶意用户可以通过在他们的输入内容中插入代码来获取数据库的访问权限如果您使用的是 SQL 数据库那么请使用存储过程创建数据库连接字符串
不要使用默认的 SQL 管理员帐户名 sa每个使用 SQL 的用户都知道存在 sa 帐户创建具有安全可靠密码的其他 SQL 管理帐户并删除 sa 帐户
在您存储客户端用户密码之前请对这些密码使用哈希算法进行 base 编码或者使用 ServerHTMLEncode 或者 ServerURLEncode 进行编码您还可以使用本页底部的某个代码示例验证客户端密码中的字符
不要把管理帐户名或密码放置在管理脚本或 ASP 页中
不要根据请求标题在代码中做出决策因为标题数据可以被恶意用户伪造在使用请求数据前始终要对其进行编码或者使用下面的代码示例验证其所包含的字符
不要将安全数据存储在 Cookie 中或者将输入字段隐藏在网页中
始终将安全套接字层 (SSL) 用于基于会话的应用程序以避免未对会话 Cookie 进行加密就发送它们所带来的风险如果会话 Cookie 没有经过加密则恶意用户可以使用一个应用程序中的会话 Cookie 进入到与之在同一进程中的另一个应用程序
当编写 ISAPI 应用程序筛选器或者 COM+ 对象时请注意由于变量和数据的大小而造成的缓沖区溢出还要注意可能由于解释造成的规范化问题例如将绝对路径名解释成相对路径名或 URL当在单线程单元 (STA) 内运行的 ASP 应用程序切换到多线程单元 (MTA) 内时模拟令牌将过时这可能导致应用程序在无模拟的情况下运行让其用可能允许访问其他资源的进程的标识有效地运行如果您必须切换线程模型请在进行更改之前先禁用该应用程序并将其卸载
代码示例
本代码示例包含了一个函数它可删除发送至该函数的字符串中的可能有害的字符在上面的两个示例中指定代码页以确保正确地编码下面的示例使用的是 Microsoft Visual Basic? Scripting Edition(VBScript)
<%@ LANGUAGE=\VBScript\ %>
<%
ResponseCodePage =
ResponseWrite(\Hello \ & RemoveBadCharacters(RequestForm(\UserName\)))
ResponseWrite(\<BR>This is why you received an error\)
Function RemoveBadCharacters(strTemp)
Dim regEx
Set regEx = New RegE
xp
regExPattern = \[^\\s\\w]\
regExGlobal = True
RemoveBadCharacters = regExReplace(strTemp \\)
End Function
%>
下面的示例使用的是 Microsoft JScript?
<%@ LANGUAGE=\JScript\ %>
<%
ResponseCodePage =
ResponseWrite(\Hello \ + RemoveBadCharacters(RequestForm(\UserName\)))
ResponseWrite(\<BR>This is why you received an error\)
function RemoveBadCharacters(strTemp) {
strTemp = strTempreplace(/[^\\s\\w]/g\\)
return strTemp
}
%>