在ASP应用中验证用户身份(2)

2016-01-29 17:15 4 1 收藏

在ASP应用中验证用户身份(2),在ASP应用中验证用户身份(2)

【 tulaoshi.com - ASP 】

  二、初始化以及用户输入合法性检查

   当一个ASP应用启动的时候,IIS就会寻找一个global.asa文件。如果该文件存
在,就开始执行Application_onStart。在这里可以初始化应用级的变量和常量。下
面的代码在Application_OnStart中初始化一个数组来跟踪任意时刻登录系统的所有
用户:

Sub Application_OnStart
Application("Users") = Array()
End Sub

   在执行Application_OnStart之后,ASP引擎创建一个Session对象并初始化
SessionID,然后触发Session_OnStart事件。在这里可以初始化会话级(和特定用
户相关的)变量和常量:

sub Session_OnStart
Session.Timeout=1
' 数据库DSN
Session("ConnectionString") = "ASPSecurity"
Session("ConnectionTimeout") = 15
' 读/写方式
Session("Mode") = 3
end sub

   考虑到用户的浏览器可能不支持Cookies或关闭了Cookies功能,因此必须在第
一个ASP页面中检查Cookies的支持情况并把结果保存在一个Session变量中。此外,
当用户在登录页面中单击“登录”按钮,还应该检查用户输入的合法性,如下面的代
码所示,其中ASPSecurity.inc提供一些公用函数(如signUserOn用于验证用户身
份):

< %@ Language=VBScript %
< % option explicit %
< % Response.buffer = true %
< !-- #INCLUDE FILE="ASPSecurity.inc" --
< %
dim aSignon
dim aPassword
dim dataValidated
dataValidated = false
' 检查浏览器是否支持Cookies
Session("SupportsCookies") = (instr(1, Request.ServerVariables
("HTTP_COOKIE"), "ASPSESSIONID", vbTextCompare) 0)
if Request("Action") = "登录" then
aSignon = lcase(trim(Request.Form("Signon")))
aPassword = lcase(trim(Request.Form("Password")))
if len(aSignon) = 0 then
Session("msg") = "请输入用户名字."
end if
if len(aPassword) = 0 then
Session("msg") = "请输入密码."
else
dataValidated=true
end if
if dataValidated then
if signUserOn(aSignon, aPassword) then
' 用户身份被证实,允许进入受保护页面
Response.Redirect "signedOn.asp?ID=" & Session("ID")
end if
end if
elseif Request("Action") = "注册" then
Response.Redirect "register.asp"
end if
%


   对于注册页面,除了要检查用户是否完整地输入所有内容之外,还应该检查两次
输入密码是否相同、用户名字是否与数据库中已有记录冲突等。实现代码请参见本文
所附的ZIP文件。

   由于用户每次启动浏览器连接到服务器时SessionID都是不同的,所以不能直接
用它来关联用户与存储在数据库中的相关信息,但SessionID可以用来临时地标识从
数据库或文件提取的用户信息。对于那些不支持Cookies的浏览器,可以用另外的方
法来创建唯一ID,如下面的getID使用的是随机函数:

function getID() dim numbers
dim letters
dim I
dim ID
Randomize
numbers="0123456789"
letters = "ABCDEFGHIJKLMNOPQRSTUVWXYZ"
for I = 1 to 10
if I mod 2 < 0 then
ID = ID & mid(letters, Int((26 * Rnd) + 1),1)
else
ID = ID & mid(numbers, Int((10 * Rnd) + 1),1)
end if
next
getID = ID
end function

 

来源:http://www.tulaoshi.com/n/20160129/1500785.html

延伸阅读
Netverify远程身份证验证和护照   随着网上商业活动的不断增长,我们在享用在线服务给我们带来便利的同时,对于其安全性的担心也随之增加。其中一个最让人担心的问题就来自于身份盗用。因此LaunchKey的概念也就应运而生,它可以给用户提供更加安全的登陆方法。然而,如果遇上某些要求比较苛刻的公司,用户在使用它们的服务之前需要...
标签: ASP
一般的动态网站需要通过表单来收集用户信息,或者实现与用户的交互,虽然我们相信绝大多数人士既然选择了填写表单就会认真的完成,但是亦不能避免无聊人士乱填表单,况且即使一个正常用户在填写过程中也会无意识的出现一些填写错误,或者他们忘记了填某些选项。通常为了避免这种情况,开发者会给表单加一个验证的过程,在表单数据提交到服务器之...
标签: ASP
      在安全性要求不是很高的ASP.Net程序中,基于Forms的身份验证是经常使用的一种方式,而如果需要对WebService进行身份验证,最常用的可能是基于Soap 标头的自定义身份验证方式。如果对两者做一下比较的话,显然,基于Forms的验证方式更加方便易用,能否将Forms验证方式应用到WebService中去呢?     ...
标签: ASP
  然后你就可以用任何方式来使用这些数据了。你可以创建ASP页面来读取数据并将数据呈现给管理员,或者从数据库中将其复制到一个电子工作表中,有时间的时候再进行分析。 但是要记住,使用ASP sessions会带来一些问题。在ASP 2.0中,当主应用程序目录下的嵌套目录中有global.asa 的副本时,有时sessions 会丢失。还有,如果你在URL、...
标签: ASP
  作者: 沈晓刚 如果你是一名Active Server Page (ASP) 开发者,相信你可能经常使用COM对象来创建ASP页面。甚至在你使用中都忽略了他就是COM对象。比如:ADO。只个调用率最高的组件已让你的页面扩展了无限的功能。然而ASP本身是解释型脚本,在功能上不足COM强大。作为拥有快速开发,易用性强,支持COM的VB自然的作为了ASP中开发COM...

经验教程

960

收藏

91
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部