当前位置: 首页 > 编程日记 > 正文

ASP.NET 2.0站点登录、导航与权限管理

(一)登录

  asp.net 2.0中,新增了许多新的功能和控件。其中,新增的登陆控件可谓使得WEB应用的设计更加得心应手。什么是登陆控件呢?就是我们平常在WEB应用中经常要用到的用户注册,登陆,忘记密码,登陆后根据权限的不同而显示不同的页面等功能,现在在asp.net 2.0中都已经可以由提供的控件来实现了。

  asp.net 2.0中,为了更方便创建和管理用户,以及对 Web 应用程序中的页进行密码保护,引进了新的框架membership。新的框架包含用于处理身份验证和授权的新增功能,能够同时满足 Web 站点管理员和开发人员的需要。Web 站点管理员可以利用新的 Web 站点管理工具来创建新的用户和角色,以及控制对 Web 应用程序中页面的访问。Web 站点管理工具是一组预先编写的 ASP.NET页,不具备编程技巧的用户可以使用它们来配置 Web 应用程序。利用membership API,编程人员可以很方便地使用拖拉控件的方法,再加以少量的代码,就可以完全实现对用户,角色权限等的管理,还可以自定义做扩充。

  1.建立网站项目

  2.ASP.NET配置

  安全设置选项被分为三部分:用户,角色和规则。

  登录的身份验证可以配置为基于Forms和Windows的。

  3.使用登录控件

  说明:用户登录后,显示“退出”的提示,通过LoginStatus控件来实现。在控件的属性中,有LogoutAction和LogoutPageUrl两个属性,可以来设定注销时是仅仅刷新当前页面、转向到某个页面或者转向到登录页面。

  如何设定LoginPageUrl(登录的页面),运行程序时,当按这个控件的显示的Login链接时,总是转到根文件夹下的Login.aspx,而实际的登录文件在/Login/Login.aspx 。如何解决?

  查了下资料,原来登录的Url是在web.config中设置的。如果是用Form验证登录,缺省的web.config是这样写的:

<system.web>
 <authentication mode="Forms" />
</system.web>

  需要修改成如下的样子:

<system.web>
 <authentication mode="Forms">
  <forms loginUrl="~/member/login.aspx"></forms>
 </authentication>
</system.web>

  (二)站点导航

  1.三种导航控件

  Menu:使用一菜单显示站点的结构。

  TreeView:用一个可展开的树显示站点的结构

  SiteMapPath:用于显示终端用户处于相对于站点结构的具体位置

  2.Web.sitemap 导航XML文件

<?xml version="1.0" encoding="utf-8" ?>
<siteMap xmlns="http://schemas.microsoft.com/AspNet/SiteMap-File-1.0" >
 <siteMapNode title="首页" url="SiteMapTest.aspx" >
 <siteMapNode title="产品" roles="*">
  <siteMapNode title="Windows" url="SiteMapTest.aspx?id=windows" />
  <siteMapNode title="Office" url="SiteMapTest.aspx?id=office" />
  <siteMapNode title="Mobile Devices" url="SiteMapTest.aspx?id=mobile" />
  <siteMapNode title="Business Solutions" url="SiteMapTest.aspx?id=business" />
  <siteMapNode title="Servers" url="SiteMapTest.aspx?id=servers" />
  <siteMapNode title="Developer Tools" url="SiteMapTest.aspx?id=tools" />
  <siteMapNode title="Games and XBox" url="SiteMapTest.aspx?id=games" />
  <siteMapNode title="All Products" url="SiteMapTest.aspx?id=all" />
 </siteMapNode>
 <siteMapNode title="资源" roles="*">
 <siteMapNode title="支持" roles="*">
  <siteMapNode title="修改密码" url="~/Login/ChangePassword.aspx" />
  <siteMapNode title="Knowledge Base" url="SiteMapTest.aspx?id=knowledge" />
 </siteMapNode>
 <siteMapNode title="Downloads" url="SiteMapTest.aspx?id=downloads" />
 <siteMapNode title="Windows Update" url="SiteMapTest.aspx?id=windowsupdate" />
 <siteMapNode title="Office Update" url="SiteMapTest.aspx?id=officeupdate" />
 <siteMapNode title="Learning Tools">
  <siteMapNode title="Training & Certification" url="SiteMapTest.aspx?id=training" />
  <siteMapNode title="Books" url="SiteMapTest.aspx?id=books" />
  <siteMapNode title="Events & Webcasts" url="SiteMapTest.aspx?id=events" />
  <siteMapNode title="Patterns & Practices" url="SiteMapTest.aspx?id=patterns" />
 </siteMapNode>
 <siteMapNode title="Community" url="SiteMapTest.aspx?id=community" />
 <siteMapNode title="Security" url="SiteMapTest.aspx?id=security" />
</siteMapNode>
<siteMapNode title="RSS" roles="*">
<siteMapNode title="公司关系" url="SiteMapTest.aspx?id=relations" />
<siteMapNode title="RSSSite" url="~/RSS/RSSSite.aspx" />
<siteMapNode title="Careers" url="SiteMapTest.aspx?id=careers" />
<siteMapNode title="About this Site" url="SiteMapTest.aspx?id=about" />
</siteMapNode>
</siteMapNode>
</siteMap>


  Web.sitemap文件必须包含根结点sitemap。一张站点地图由一系列相联系的SiteMapNode对象组成。这些SiteMapNode以一种层次方式联系在一起。该层次包含单个根结点-它是该层中唯一的一个没有父结点的结点,代表首页。在该父sitemapnode结点下,可以有若干个子sitemapnode结点,分别按层次结构代表了网站的各子栏目(留意一下上例中,各个子结点之间的包含关系)。

  3. 数据源SiteMapDataSource控件

  SiteMapDataSource会自动查找项目中名为Web.sitemap的 一个XML文件

[NextPage]

(三)权限管理

  网站在安全性方面有一个常见的要求:特定的页面仅允许某些成员或其他经过身份验证的用户浏览。ASP.NET 的角色管理提供了一种方法,可以基于安全角色限制对 Web 文件的访问。站点地图安全性调整提供了一种同样基于安全角色的方法来隐藏站点地图中的导航链接。

  1. ASP.NET 网站配置

  1)提供程序

  可使用 SQL SERVER 2005(默认),2000和Access数据库存储用户信息。

  若要使用 SQL SERVER 2000数据库存储信息:

  a.用SQL Server的企业管理器,创建一个数据库,如为zyh;

  b.用aspnet_regsql(C:\Windows\Microsoft.Net\Framework\v2.0.50215\aspnet_regsql.exe)创建数据库。除在创建向导的第3步数据库下拉框选择“zyh”以外,其余各步骤皆使用默认设置。这样,在Sql Server 2000中会创建一个含有用户表和存贮过程的完整数据库。

  c.在管理工具中打开IIS,找到虚拟目录newtest,用鼠标右键点击,然后左键点菜单项【属性】、【ASP.NET】标签、【编辑配置】按钮,在【常规】标签的【连接字符串管理器】中,点名称【LocalSqlServer】,点【编辑】按钮,把【连接参数】修改为相应能够连接到数据库zyh的数据库连接字符串,如“Data Source=.;Initial Catalog=zyh;Persist Security Info=True;User ID=sa;Password=12345”,此后,一直点【确定】按钮,最后到IIS管理工具界面即可。

  d.最后返回网站管理工具Web页面,点击安全主题,就会出现“使用安全设置向导按部就班地配置安全性。”链接和其它相关链接。

  2)安全设置选项被分为三部分:用户,角色和规则。

  其中规则建立了角色对项目中文件夹的访问权限。

  3)应用程序配置

  可设置SMTP服务器 以供用户通过email找回密码。

  2. 建立登录页面

  3.在Web.config文件中启用角色管理

<system.web>
<siteMap defaultProvider="XmlSiteMapProvider" enabled="true">
<providers>
<add name="XmlSiteMapProvider"
description="Default SiteMap provider."
type="System.Web.XmlSiteMapProvider "
siteMapFile="Web.sitemap"
securityTrimmingEnabled="true" />
</providers>
</siteMap>

<roleManager enabled="true" />

<authentication mode="Forms">
<forms loginUrl="~/Login/login.aspx"></forms>
</authentication>

<compilation debug="true">
<assemblies>
<add assembly="System.Data.OracleClient, Version=2.0.0.0, Culture=neutral, PublicKeyToken=B77A5C561934E089"/>
</assemblies>
</compilation>
</system.web>
<system.net>
<mailSettings>
<smtp from="wangyihust@163.com">
<network host="smtp.163.com" password="passwordModify" userName="wangyihust" />
</smtp>
</mailSettings>
</system.net>

  4.在Web.sitemap 文件中 加入角色权限,以显示或隐藏相关页面

<siteMapNode title="RSS" roles="*">
<siteMapNode title="公司关系" url="SiteMapTest.aspx?id=relations" />
<siteMapNode title="RSSSite" url="~/RSS/RSSSite.aspx" />
<siteMapNode title="Careers" url="SiteMapTest.aspx?id=careers" />
<siteMapNode title="About this Site" url="SiteMapTest.aspx?id=about" />
</siteMapNode>

  其中,roles="*"表示所有人都可以看到下面的页面,但是我们在规则中可以拒绝某些 角色的用户看到下面的相关页面(通过目录权限控制)。

转载地址:http://study.feloo.com/computer/web/ASPNET/shili/200604/162401_2.html

转载于:https://www.cnblogs.com/yiki/archive/2006/12/31/608773.html

相关文章:

Android 中一些常用类的常用方法(Math、Random、Color、Paint、Canvas、Bitmap、BitmapFactory)...

1.java.lang.Math类常用的常量和方法: Math.PI 记录的圆周率 Math.E 记录e的常量 Math.abs 求绝对值 Math.sin 正弦函数 Math.asin 反正弦函数 Math.cos 余弦函数 Math.acos 反余弦函数 Math.tan 正切函数 Math.atan 反正切函数 Math.atan2 商的反正切函数 Math.toD…

效果很好的asp.net的数据库访问模型(优化,封装一体化)

效果很好的asp.net的数据库访问模型(优化,封装一体化) 非常有效的数据库/配置文件访问模型。成功使用在几万流量的网站上。任何建议欢迎大家交流。 在使用SqlCommand对象过程中,我们需要分配Connection对象。 通常,对于…

【技巧——windows】直接登陆到桌面,免去输入密码

关于这个问题其实我很早之前就研究过,只是一直都是弄一次就不管了,下次就忘记怎么弄了,又去查,现在就写个笔记吧。 win8/8.1 在开始的界面输入netplwiz,或者点击winr打开运行,输入netplwiz,然后…

虚商烦恼多?不在怕的!你距离享受高效虚商控制台只差一步的距离

摘要:虚商烦恼多?不在怕的!你距离享受高效虚商控制台只差一步的距离虚商自助服务平台 vco.console.aliyun.com/原文链接本文为云栖社区原创内容,未经允许不得转载

Shark Hive Spark Hadoop2 进行整合的测试。

本文目的是测试将shark和hadoop2进行整合。 本来打算使用Shark 最新版0.9.0 ,但是官方好像还没有针对与Hadoop2的正式下载地址。(这个要说明一下,官方只提供了源码,并没有找到编译好的0.9.0 for hadoop2 ,也许需要自己…

nginx反向代理-多端口映射

2019独角兽企业重金招聘Python工程师标准>>> 代码解释 1.1 http:www.baidu.test.com默认是80,访问“/”利用反向代理,然后访问本地8083; 1.2 8083代表本地的前端工程访问地址,前端需要访问后台数据,”/”…

程序员期末试卷_第三部分复习提纲.doc下载

程序员期末试卷_第三部分复习提纲.doc下载 转载于:https://www.cnblogs.com/dtdnh520/archive/2007/01/20/625390.html

IDEA IntelliJ 如何新建一个不用任何框架的web项目

step 1 step 2 step 3 step 4 step 5 step 6 结果: 导包 找到jsp-api.jar和servlet-api.jar 建包(web项目不建议直接在src目录下新建类)

坑爹系列1--Log

今天的Log信息有的能打有的不能打,甚是奇怪,高了半天明白了,常见的几个问题就不说了,说我这个奇怪的。看下面的内容,那个能打印呢? 1 2 3 4 5 Log.v("交易返回码:log", " "); Log.v(&q…

避免资源死锁:识别已打开的事务

死锁往往由于以下原因引起:1、程序错误,比如一个事务需要操作两个表,由于程序错误在有时是先操作a表后操作b表,有时是先操作b表后操作a表,就有机会互相等待而造成死锁。2、事务太大,大事务操作的表多&#…

【vivado】debug hub时钟不匹配

报错,没有debug core! the clock connected to the debug hub (dbg_hub) core 根因是在调试中,这个debug hub没有工作。 下图两个ila_0,ila_1,分别对应两个时钟clk_out1, clk_out2,然后连到一个hub上。 默认…

IDEA IntelliJ 如何给web项目配置tomcat

step 1 step 2 step 3(重复step 1) step 4 step 5 step 6 结果

使用 spring boot 开发通用程序

2019独角兽企业重金招聘Python工程师标准>>> tag: spring 学习笔记date: 2018-03spring 是什么?spring 核心是应用组件容器,管理组件生命周期,依赖关系,并提倡面向接口编程实现模块间松耦合。 spring boot 是什么&…

java.utilDate和java.sql.Date

java.utilDate和java.sql.Date由广州疯狂软件教育java培训分享: java程序中的时间类型有java.util.Date和java.sql.Date两种。两者之间的关系和转化如下: java.sql.Date是java.util.Date的子类,所以可以直接将java.sql.Date类型的对象赋值给j…

Oracle 10G重建EM DB Control.

Oracle 10G R2重建EM DB Control.如果安装后没有修改过IP地址或机器名字,可以跳过下面1和2两步。1.drop configuration files and repository run :emca -deconfig dbcontrol db -repos drop 2. Logon SQLPLUS as user SYS or SYSTEM, and drop the sysman account and mangem…

IDEA IntelliJ 如何快速查看一个类里面包含哪些方法

主页面停留在那个类上 点击屏幕左侧的Structure

ACM 关于521

关于521 时间限制:1000 ms | 内存限制:65535 KB难度:2描述Acm队的流年对数学的研究不是很透彻,但是固执的他还是想一头扎进去。 浏览网页的流年忽然看到了网上有人用玫瑰花瓣拼成了521三个数字,顿时觉得好浪漫&#…

搭建本地https

生成证书 1. 使用openssl生成密钥privkey.pem: openssl genrsa -out privkey.pem 1024/2038 2. 使用密钥生成证书server.pem: openssl req -new -x509 -key privkey.pem -out server.pem -days 365 证书信息可以随便填或者留空,只有Common Na…

(转载)新年——顺民的牢骚

我是一个顺民,顺的不能再顺的民!相信很多人和我一样,即使心中有很多的不满,也只是偶尔发发牢骚,而且,大多时,还不敢在人多的时候发!即使在昏暗的灯光下的某个角落写写BLOG&#xff0…

IDEA IntelliJ 如何设置网站的欢迎页面

网站的目录结构如下 在web>WEB-INF>web.xml 文件中设置login.html为欢迎页面(运行跳出的第一个页面)

nyoj19 全排列

http://acm.nyist.net/JudgeOnline/status.php?pid19 1 #include<stdio.h>2 #include<stdlib.h>3 int n,a[10];4 bool vis[10];//标示数字是否被用过 5 void f(int k,int m)//k用来给a中第k个元素赋值&#xff0c;m表示还需要寻找的数字个数 6 {7 for(int i1;…

vue中动态样式不起作用? scoped了解一下

vue中style标签使用属性scoped的注意事项 style上添加属性scoped可以实现样式私有化&#xff0c;但是在使用动态样式时&#xff0c;样式会不起作用。可以先去掉scoped转载于:https://www.cnblogs.com/zuojiayi/p/9364347.html

有关cmd.Parameters.Clear()

// detach the SqlParameters from the command object, so they can be used again.cmd.Parameters.Clear(); 这句话在某些时候非常有用,比如说你在一个事务中调用了2个以上的存储过程,而恰巧这两个存储过程又有同样的参数,(例如 p_Name) 这时不加cmd.Parameters.Clear() 就会…

IDEA IntelliJ 如何设置web项目的热部署

这里的热部署指不需要重启服务器&#xff0c;刷新页面就可以反应页面&#xff08;仅限html和JSP&#xff09;的改动 step1 step2 效果 原来的html页面 在IntelliJ中进行修改 回到Chrome&#xff0c;点击 结果

SQL Server 2012 OFFSET/FETCH NEXT分页示例

原文&#xff1a;http://beyondrelational.com/modules/29/presentations/483/scripts/12983/sql-server-2012-server-side-paging-demo-using-offsetfetch-next.aspx?utm_sourcebrnewsletter&utm_mediumemail&utm_campaign2012Apr SQL Server 2005 引入了 ROW_NUMBER…

python数据库学习--Mysql

摘要&#xff1a; Python使用mysql需要安装驱动&#xff0c;有两种1&#xff09;mysqldb 2&#xff09;umysql &#xff0c;两者都是开源&#xff0c;具体区别不详&#xff0c;umysql没用过 一、mysqldb 安装MySQL驱动--http://www.codegood.com/archives/129 提供下载…

master page頁面如何用js來做輸入驗證

問&#xff1a;在使用了master page後&#xff0c;內容頁就沒有html標識了&#xff0c;那麼取得內容頁面控件的cilentID地方法也不一樣&#xff0c;我不知道用js怎麼取得這個cilentID,請各位大大幫忙告知如何寫這個js,並對其進行驗證.答&#xff1a;你可以先浏览一下页面&#…

scanf与空格

1.scanf的%c格式可以读入空格和换行 例&#xff1a; #include<cstdio> int main(){int a;char c,str[10];scanf("%d%c%s",&a,&c,str);printf("a%d,c%c,str%s",a,c,str);return 0;}2.字符数组使用%s读入的时候以空格跟换行为读入结束的标识 …