ASP.NET 2.0中使用自定义provider (2)
在tech ed 2005上,有对asp.net 2.0的介绍,其中讲到asp.net 2.0提供了很多功能,让程序员做少很多东西,这引起了大家的疑惑:asp.net 2.0的自定义能力如何?扩展能力如何?程序员可以扩展微软提供的东西么?下面,我对asp.net 2.0的provider进行了考察,结合资料编译了下文,讲解如何自定义provider于登陆控件使用,同时可以参考http://jackyrong.cnblogs.com/archive/2005/09/02/228533.html一文中,本文可以看做是该文的扩展吧(本文同时发表在http://dev.yesky.com/msdn/373/2128373.shtml?412上)

在asp.net 2.0中,新增加的membership provider功能,以及结合功能强大的一系列注册,登陆控件,可以很方便地对用户的登陆和权限等进行管理(参见
<<asp.net 2.0登陆控件简介>>一文(http://www.yesky.com/466/1870966.shtml)。<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

但是,可能大家会发现,asp.net 2.0自带的这些登陆控件和membership的管理功能,默认的是和sql server 2005 express搭配使用的,那么,如何改成使用sql server 2000或者是其他的数据源,如access,oracle等呢?如果自己想在应用中,另外重新写一个对登陆用户或者用户权限等管理的应用,要如何修改呢?在本文中,将给出在asp.net 2.0中使用自定义provider,以配合登陆控件来实现一个简单的登陆过程。

为了明白asp.net 2.0中的provider是如何工作的,首先看下下面的结构图:
   
      由上图可以清楚看到,在最上面的一层,是各类的登陆控件,下面一层是与member有关的membership api。在Membership Api中,membership 类执行有关对用户的操作,比如增加,删除用户,而MembershipUser类则存储有关用户的个人信息,如用户名,密码,EMAIL等信息。

  在Visual Studio 2005 beta 2中,默认使用的是Sql express membership provider。Provider的作用,是起到沟通Membership Api以及数据库,使得用户并不需要关心要使用的是何种数据库,全部的操作都可以用各类相应的数据provider来实现。

  但很多时候,ASP.NET 2.0默认支持的provider是不能满足其需要的,我们可以自己根据需要编写provider.在本文中,将介绍如何使用access数据库,建立一个数据表,存放用户的信息。本文介绍的方法,也可以适用在其他数据库上。

  首先,我们打开Visual Studio 2005 beta 2,选用VB.NET,新建一个WEB SITE站点。在这个例子中,为简单起见,我们设置一个用户注册表单,一个登陆的表单,新用户可以先注册,之后进行登陆。

  接着,往默认的窗体中,拖放一个CreateUserWizard的控件,这是一个系统提供的新建用户的自动控件,可以很方便地新建一个用户。为了页面美观,我们点控件右上方的"智能感知",选择"auto format",在弹出的窗体中,再选择"Elegant"样式,如下图所示:
   
    当然,我们可以任意修改该控件的文字提示。这里我们为了让能使用户在注册后能转到登陆页面,因此,设置该控件的ContinueDestinationPageUrl属性的值为:Login.aspx,这个页面等下会编写。

  接着,再拖拉一个LoginView控件到default.aspx页面中。在该控件中,可以设置两种模版:Anonymous模版,表示在用户未登陆前,访客看到的状态;LoggedIn 模版,表示等用户成功登陆后,看到的状态(这里可以设置一些文字显示,比如欢迎进入等,同时一般会显示用户的名字)。

  在这里,我们在LoginView控件中的LoggedIn 模版中,我们输入"You are logged in",并且增加一个LoginName和一个LoginStatus控件。其中,LoginName控件显示登陆后用户的ID,而LoginStatus控件,则当用户登陆后,会显示logout(注销)的链接。如下两图所示:


   
    接着,再往项目中新增加一窗体,命名为login.aspx,再往该窗体中增加一个login控件,如下图
 
    接下来,我们要做的工作是创建数据库了。我们在工作目录下,用access创建一个名为Members.mdb的数据库,数据结构表如下图所示:
  Field Name Data Type Field Size
Username (key) Text 8
Password Text 8
Email Text 50
passwordQuestion Text 50
passwordAnswer Text 50

在创建自己的provider前,我们先了解下在ASP.NET 2.0中的provider的构造。在ASP.NET 2.0 beta 2中,默认的SqlMembershipProvider是继承MembershipProvider类的,MembershipProvider类又是继承自ProviderBase这个基类的,如下图所示

如果想修改已有的sql membership provider,则只需要创建一个类,继承SqlMembershipProvider类,并覆盖其方法就可以了,比如下面的例子:
 

Public Class ModifiedSqlMembershipProvider
Inherits SqlMembershipProvider

Public Overrides Function CreateUser (...)
...
End Function
...
End Class

如果不想使用在Visual Studio 2005 beta 2中提供的SqlMembershipProvider,则只需要声明自己的类,并且继承MembershipProvider类就可以了。MembershipProvider类包含了与membership相关的方法和属性。

  在Solution Explorer中,使用"Add New item..",增加一个类,命名为AccessMembershipProvider.vb,并按系统提示,将其放到App_Code目录中去。

  接下来,引用相关的命名空间,并且写出程序的框架如下:

Imports Microsoft.VisualBasic
Imports System.Data

Public Class AccessMembershipProvider
Inherits MembershipProvider
End Class

  为了要使用自定义的provider,必须在web.config中进行相关的配置。可以新增加一个web.config文件,写入如下的代码:

<system.web>
<authentication mode="Forms"/>
<membership
defaultProvider="AccessMembershipProvider" >
<providers>
<add name="AccessMembershipProvider"
type="AccessMembershipProvider"
requiresQuestionAndAnswer="true"
connectionString="Provider=Microsoft.Jet.
OLEDB.4.0;Data Source=C:\NewMembershipProvider\
App_Data\Members.mdb;Persist Security
Info=False" />
</providers>
</membership>
</system.web>

  其中,要留意如下几点:

  必须选择验证方式为"Forms"(authentication mode="forms").

  通过使用<add>标签,增加一个自定义的provider,名称叫AccessMembershipProvider。

  其中的requiresQuestionAndAnswer属性,当其值为true时,指出在新注册时,必须填写提示问题和要回答的答案。

  ConnectionString,指出要进行数据库连接的连接串。

  DefaultProvider属性,指出系统默认使用哪一个provider,因为一个系统中可以设置多个provider.

  在AccessMembershipProvider.vb中,增加以下的私有成员

Private connStr As String
Private comm As New OleDb.OleDbCommand
Private _requiresQuestionAndAnswer As Boolean
Private _minRequiredPasswordLength As Integer

  并且增加Initialize()方法,代码如下

Public Overrides Sub Initialize(ByVal name As String, ByVal config As System.Collections.Specialized.NameValueCollection)

’===retrives the attribute values set in
’web.config and assign to local variables===
If config("requiresQuestionAndAnswer") = "true" Then _
_requiresQuestionAndAnswer = True
connStr = config("connectionString")
MyBase.Initialize(name, config)
End Sub

  当provider被装载时,会调用Initialize()方法。刚才在web.config文件中,使用<add>标签设置的各类属性值,都能在这个方法中读取。比如,可以通过使用config参数来读取,上面的代码中,就使用config("connectionString")来读取数据库连接字符串,并放到变量connStr变量中去。之后,再设置RequiresQuestionAndAnswer属性,如下:

Public Overrides ReadOnly Property _
RequiresQuestionAndAnswer() _
As Boolean
Get
If _requiresQuestionAndAnswer = True Then
Return True
Else
Return False
End If
End Get
End Property

  要注意,必须设置该属性的值,否则,在CreateUserWizard控件中,则不会显示密码提示问题和密码提示答案两个文本框。

  接下来,我们可以开始编写新建用户的代码了,CreateUser()方法的代码如下:

Public Overrides Function CreateUser(ByVal username As String, ByVal password As String, ByVal email As String, ByVal passwordQuestion As String, ByVal passwordAnswer As String, ByVal isApproved As Boolean, ByVal providerUserKey As Object, ByRef status As System.Web.Security.MembershipCreateStatus) As System.Web.Security.MembershipUser
Dim conn As New OleDb.OleDbConnection(connStr)
Try
conn.Open()
Dim sql As String = "INSERT INTO Membership VALUES (" & _
"@username, @password, @email, " & _
" @passwordQuestion, @passwordAnswer )"
Dim comm As New OleDb.OleDbCommand(sql, conn)
comm.Parameters.AddWithValue("@username", username)
comm.Parameters.AddWithValue("@password", password)
comm.Parameters.AddWithValue("@email", email)
comm.Parameters.AddWithValue("@passwordQuestion", passwordQuestion)
comm.Parameters.AddWithValue("@passwordAnswer", passwordAnswer)
Dim result As Integer = comm.ExecuteNonQuery()
conn.Close()

status = MembershipCreateStatus.Success
Dim user As New MembershipUser("AccessMembershipProvider", username, Nothing, email, passwordQuestion, Nothing, True, False, Now, Nothing, Nothing, Nothing, Nothing)
Return user
Catch ex As Exception
status = MembershipCreateStatus.UserRejected
Return Nothing
End Try
End Function

  我们解读一下上面的代码,首先,我们往数据库插入了一条记录,在新增用户成功后,我们必须返回一个状态信息status(该status时在传入时以ByRef status As System.Web.Security.MembershipCreateStatus方式传入),并且我们要返回一个MembershipUser的类的实例,因此,我们以这样的方式返回其实例:

Dim user As New MembershipUser("AccessMembershipProvider", username, Nothing, email, passwordQuestion, Nothing, True, False, Now, Nothing, Nothing, Nothing, Nothing)

  其中,使用到MembershipUser类的方法的构造函数有很多,具体的可以查看MSDN,在这里我们只用到了username,email,passwordQuestion,createdate(帐号创建日期,这里使用NOW)。

  而在登陆页面里,为了判断是否为合法用户登陆,则需要编写如下代码:

Public Overrides Function ValidateUser( _
ByVal username As String, _
ByVal password As String) As Boolean

Dim conn As New OleDb.OleDbConnection(connStr)
Try
conn.Open()
Dim sql As String = _
"Select * From Membership WHERE " & _
"username=@username AND password=@password"
Dim comm As New OleDb.OleDbCommand(sql, conn)
comm.Parameters.AddWithValue("@username", _
username)
comm.Parameters.AddWithValue("@password", _
password)
Dim reader As OleDb.OleDbDataReader = _
comm.ExecuteReader
If reader.HasRows Then
Return True
Else
Return False
End If
conn.Close()

Catch ex As Exception
Console.Write(ex.ToString)
Return False
End Try
End Function

  就这样,一个简单的自定义provider就完成了,可以搭配登陆,注册等控件进行使用了。运行程序,首先是出现用户注册的页面,当用户成功注册后,则会将用户引导到登陆页面,如下图所示:
 
当用户成功登陆后,如下图所示:

posted on 2005-09-21 19:32 jackyrong的世界 阅读(...) 评论(...) 编辑 收藏

转载于:https://www.cnblogs.com/jackyrong/archive/2005/09/21/241446.html

ASP.NET 2.0中使用自定义provider (2)相关推荐

  1. 在ASP.NET 2.0中建立站点导航层次

    站点导航提供程序--ASP.NET 2.0中的站点导航提供程序暴露了应用程序中的页面的导航信息,它允许你单独地定义站点的结构,而不用考虑页面的实际物理布局.默认的站点导航提供程序是基于XML的,但是你 ...

  2. [翻译]在Asp.net 2.0中操作数据::母板页和站点导航

    在Asp.net 2.0中操作数据::母板页和站点导航 英文原文 |  下载示例代码(C#)  |  翻译进度  |  英文教程目录 导言 通常,用户友好的个性化站点都有着一致的,站点统一的页面布局和 ...

  3. 在ASP.NET 2.0中操作数据教程系列

    在ASP.NET 2.0中操作数据教程系列 Scott Mitchell最近完成了为 www.asp.net 网站撰写的<在ASP.NET 2.0中操作数据 (Working with Data ...

  4. ASP.NET 2.0中如何连接到Mysql(转)

    < DOCTYPE html PUBLIC -WCDTD XHTML StrictEN httpwwwworgTRxhtmlDTDxhtml-strictdtd> 最近对mysql比较感兴 ...

  5. 第一次来,试发一帖!--ASP.NET 2.0 中的SqlCacheDependency特性

    ASP.NET中的Page Cache是个很有用的东东,只要简单的在页面上方加上一个OutputCache标签,就可以让页面在制定的Duration内直接把自动保存在缓存中的页面内容输出,而不需要让A ...

  6. ASP.NET 2.0 中改进的缓存功能

    摘要:本文中,Stephen Walther 将重点介绍 ASP.NET 2.0 中新增的缓存功能,以及如何使用这些新功能改进 ASP.NET 应用程序的性能和可扩展性.(本文包含一些指向英文站点的链 ...

  7. ASP.NET 2.0 中的资源与本地化

    转自MSDN 下载本文的代码:BasicInstincts2006_08.exe (878KB) 本页内容 控制页面级别的区域性设置 使用配置文件跟踪语言首选项 ASP.NET 2.0 中的资源文件 ...

  8. 测试ASP.NET 2.0中Gridview控件高级技巧

    ASP.NET 2.0中,新增加的gridview控件的确十分强大,弥补了在asp.net 1.1中,使用datagrid控件时的不足之处.因为在asp.net 1.1中,在使用datagrid时,很 ...

  9. 怎么在ASP.NET 2.0中使用Membership

    摘要: 本文介绍了怎么在ASP.NET 2.0中使用Membership新特性,并且介绍了怎么两种不同的Membership的Provider:ActiveDirectoryMembershipPro ...

最新文章

  1. 常用免费精品Web应用列表(转)
  2. 第十九章 代码重用 5包含对系统的消耗
  3. c语言让电脑发出滴滴声代码,centos命令行控制电脑发出滴滴声——使用beep把警告变为music...
  4. iPhone的Socket编程使用开源代码之AsyncSocket
  5. 乐高创意机器人moc_LEGO乐高MOC作品欣赏:超有爱机器人偶E-MOTE
  6. dpg learning 和q_深度学习和强化学习之间的差别有多大?
  7. php获取微信uninoid_微信小程序获取openid和unionid方法
  8. MIT6.828 boot.S文件分析
  9. 【OPPO主题制作系列 - 01】-- 写个小工具自动打包Theme文件
  10. git 密钥文件在哪里? 代码提交到Git分支。
  11. 【其他】电脑ADB连接手机的方式
  12. SEM和SEO的区别
  13. grep查找文件内容
  14. Ubuntu 制作光盘镜像文件
  15. 核心技术解析:移动端车牌识别系统方案
  16. 无线网改了密码后连不上服务器了,修改wifi密码后连不上网了怎么办?
  17. java计算根号二的无穷_java怎么计算根号
  18. postgresql导出表结构以及数据到mysql
  19. 【CV】图像标准化与归一化
  20. 枚举---枚举的其他应用

热门文章

  1. Kafka笔记-搭建及单机生产者、消费者操作
  2. Qt工作笔记-让界面飞一会(让界面旋转出来)
  3. 7.2图的存储结构(邻接矩阵)
  4. 中断程序_91工控ABB机器人中断程序(陷阱程序)TRAP
  5. idea连接mysql怎么生成实体类_IDEA链接数据库自动生成实体类
  6. C语言指针操作字符数组demo
  7. linux搭建测试环境常见问题,在Linux环境下搭建CCID测试环境
  8. java httpclient 异步请求_Java利用httpasyncclient进行异步HTTP请求
  9. (计算机组成原理)第三章存储系统-第四节:主存储器和CPU的连接
  10. linux 32bit 改为64bit问题