Membership配置篇

2023-10-05 22:30
文章标签 配置 membership

本文主要是介绍Membership配置篇,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

从.net 2.0开始  asp.net 就进入了一个倡导少写代码多配置的时期

“机器先进阿 我们只要把猪赶进去 对面就会从传送带里传出香肠来!”

下面就是启动机器并且赶猪的工作。


在赶猪以前,我们先来了解一下,Web.Security 的工作大概方式



当一个页面打开  系统会首先读取System.web  按照其中的配置段  在进程中建立相应的各种Provider的实例 。
之后的所有登陆控件在交互的时候会自动调用相应Provider实例的方法和属性。所以大部分工作是在配置中进行的

组件部分的对象  有很多同行建议自己写  免得过于依赖aspnetDB  具体可以参考 幻想曲的文章 
但我们这个是标准例程,所以暂时以 m$的标准库为基础建立


具体配置如下

1 配置数据库
运行    /WINDOWS/Microsoft.NET/Framework/v2.0.50727  下的Aspnet_regsql.exe



随后 向导便在SQL Server中建立了对应的表。
这些表就是.Net 2.0 默认Provider对应的表,如果你在建立一个新项目 就没必要在自己写烦人的登陆了,这些表和它们所支持默认Provider的已经涵盖了很多高级功能,包括cookie的支持、跨网站跨进程的登陆、找回密码、邮箱认证等功能,当然我们也可以扩展它们。





相对的  我们还需要在web.config 建立这个数据连接字符串(<configuration >段中)

     < connectionStrings >
        
< add  name ="MemberShip_Connection"  connectionString ="Data Source=.;Initial Catalog=MemberShip_Demo;Persist Security Info=True;User ID=sa;Password=abcdefg"  providerName ="System.Data.SqlClient" />
     </ connectionStrings >

这样数据库的配置就已经完成了,我爱厨房怎么说来着?阴干待用。

2  配置验证类型

一个asp.net缺省的身份验证是windows nt 登陆。如果我们要自己来处理验证信息就要在 <configuration >下面的<system.web> 段加入节点通知系统。

         < authentication  mode ="Forms" >
            
< forms  loginUrl ="~/Membership/authing/Login.aspx"  timeout ="30000" >
            
</ forms >
        
</ authentication >

mode=forms 表示我不要用默认的windows NT 权限设置、而用我们配置的这种自定义的 面向网页界面的验证方式。
loginUrl  表示如果访问某页需要验证的话 跳转到哪一个(一般是有Login控件的)地址来进行登陆。登陆完毕,会直接跳回刚才的页面。

3  配置各种Provider
Provider对于Membership的感觉有点像 DataAdapter对于Dataset的感觉,都是可选择的配件,你配置了不同的Provider 就有不同的用户数据库可以访问
目前Provider 默认提供两种官方Provider:  SQL Provider  & ADSI  Provider  
前者通过SqlServer数据库保存  后者直接连结windows域的adsi服务

例如
< membership  defaultProvider ="Main_SqlMemberShipProvider"  userIsOnlineTimeWindow ="20" >
            
< providers >
                
< add  connectionStringName ="MemberShip_Connection"  enablePasswordRetrieval ="false"  enablePasswordReset ="true"  requiresQuestionAndAnswer ="true"  passwordFormat ="Hashed"  applicationName ="DEMO_Membership"  name ="Main_SqlMemberShipProvider"  type ="System.Web.Security.SqlMembershipProvider" />
        
            
</ providers >
        
</ membership >

这个例子表示  我要用MemberShip_Connection这个连接字符串连接数据库(我们阴干待用的部分) 
用户不能找回密码但是可以重新设置密码,找回的时候需要密码提示问题,储存在数据库中的密码用sha1进行加密  等等细节问题。  对于公用的Membership数据库 区别名为  DEMO_Membership  .
Type是重要的选项 这决定你使用哪一个符合接口的具体的类型来担任Provider 项  如果你使用自己的Provider  可以把DLL作为引用添加在bin目录后  在这里填写详细的命名空间信息  比如“"System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=B77A5C561934E089” 之类的东西  这里不作赘述

这时候 我们已经可以通过控件进行申请和登陆了   你所需要做的只是把控件拖到指定的页面上 然后test   也可以通过网站菜单下的管理工具进行修改





有些选项可能进不去 但是用户的删除和修改都可以尝试使用了。  我们只需要进一步配置 更多的功能就向我们敞开大门了~~~

同样我们配置Roles 和 Profile 的Provider
         < roleManager  enabled ="true"  cacheRolesInCookie ="true"  cookieName =".ASPROLES"  cookieRequireSSL ="true"  defaultProvider ="SqlRoleProvider" >
            
< providers >
                
< add  connectionStringName ="MemberShip_Connection"  applicationName ="DEMO_Membership"  name ="SqlRoleProvider"  type ="System.Web.Security.SqlRoleProvider" />
            
</ providers >
        
</ roleManager >


< profile  enabled ="true"  defaultProvider ="SqlProfileProvider" >
            
< providers >
                
< add  name ="SqlProfileProvider"  type ="System.Web.Profile.SqlProfileProvider"  connectionStringName ="MemberShip_Connection"  applicationName ="DEMO_Membership"  description ="SqlProfileProvider for SampleApplication" />
            
</ providers >
            
< properties >
            
        
< add  name ="UserAge"  type ="System.String"  defaultValue  ="21" ></ add >
        
< add  name ="UserSex"  type ="System.String"  defaultValue  ="Male" ></ add >
               
</ properties >
         </ profile >


经过编译以后  你已经可以轻松的在你的页面里面访问和设置你现在登陆的用户的各种信息:

    Protected   Sub Button1_Click(ByVal sender As ObjectByVal e As System.EventArgs) Handles Button1.Click
        
Dim x As String = String.Empty
        x 
= x & Membership.GetUser().UserName & ":"
        x 
= x & Roles.GetRolesForUser(Membership.GetUser().UserName).Length & "个角色:"
        x 
= x & "年龄" & Profile.UserAge
        Button1.Text 
= x

    
End Sub

假如你没有登陆  可能会得到一个对象引用错误   但是你作为一个已知用户登陆的话   运行结果大概是这样



而刚才提到的网站管理工具  已经基本可以正常工作了。


配置篇的例子到此完成    至于每一个参数什么意义   MSDN上还是很全的。 如果查资料比较不方便  可以留言  我们一起讨论

下一章我们将使用ODS绑定这些数据到GridView 和FormView 上进行管理。   

这篇关于Membership配置篇的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/152169

相关文章

Linux中SSH服务配置的全面指南

《Linux中SSH服务配置的全面指南》作为网络安全工程师,SSH(SecureShell)服务的安全配置是我们日常工作中不可忽视的重要环节,本文将从基础配置到高级安全加固,全面解析SSH服务的各项参... 目录概述基础配置详解端口与监听设置主机密钥配置认证机制强化禁用密码认证禁止root直接登录实现双因素

嵌入式数据库SQLite 3配置使用讲解

《嵌入式数据库SQLite3配置使用讲解》本文强调嵌入式项目中SQLite3数据库的重要性,因其零配置、轻量级、跨平台及事务处理特性,可保障数据溯源与责任明确,详细讲解安装配置、基础语法及SQLit... 目录0、惨痛教训1、SQLite3环境配置(1)、下载安装SQLite库(2)、解压下载的文件(3)、

Linux如何快速检查服务器的硬件配置和性能指标

《Linux如何快速检查服务器的硬件配置和性能指标》在运维和开发工作中,我们经常需要快速检查Linux服务器的硬件配置和性能指标,本文将以CentOS为例,介绍如何通过命令行快速获取这些关键信息,... 目录引言一、查询CPU核心数编程(几C?)1. 使用 nproc(最简单)2. 使用 lscpu(详细信

Nginx 重写与重定向配置方法

《Nginx重写与重定向配置方法》Nginx重写与重定向区别:重写修改路径(客户端无感知),重定向跳转新URL(客户端感知),try_files检查文件/目录存在性,return301直接返回永久重... 目录一.try_files指令二.return指令三.rewrite指令区分重写与重定向重写: 请求

Nginx 配置跨域的实现及常见问题解决

《Nginx配置跨域的实现及常见问题解决》本文主要介绍了Nginx配置跨域的实现及常见问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来... 目录1. 跨域1.1 同源策略1.2 跨域资源共享(CORS)2. Nginx 配置跨域的场景2.1

gitlab安装及邮箱配置和常用使用方式

《gitlab安装及邮箱配置和常用使用方式》:本文主要介绍gitlab安装及邮箱配置和常用使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1.安装GitLab2.配置GitLab邮件服务3.GitLab的账号注册邮箱验证及其分组4.gitlab分支和标签的

MySQL MCP 服务器安装配置最佳实践

《MySQLMCP服务器安装配置最佳实践》本文介绍MySQLMCP服务器的安装配置方法,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下... 目录mysql MCP 服务器安装配置指南简介功能特点安装方法数据库配置使用MCP Inspector进行调试开发指

Redis Cluster模式配置

《RedisCluster模式配置》:本文主要介绍RedisCluster模式配置,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录分片 一、分片的本质与核心价值二、分片实现方案对比 ‌三、分片算法详解1. ‌范围分片(顺序分片)‌2. ‌哈希分片3. ‌虚

SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志

《SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志》在SpringBoot项目中,使用logback-spring.xml配置屏蔽特定路径的日志有两种常用方式,文中的... 目录方案一:基础配置(直接关闭目标路径日志)方案二:结合 Spring Profile 按环境屏蔽关

Maven 配置中的 <mirror>绕过 HTTP 阻断机制的方法

《Maven配置中的<mirror>绕过HTTP阻断机制的方法》:本文主要介绍Maven配置中的<mirror>绕过HTTP阻断机制的方法,本文给大家分享问题原因及解决方案,感兴趣的朋友一... 目录一、问题场景:升级 Maven 后构建失败二、解决方案:通过 <mirror> 配置覆盖默认行为1. 配置示