这是这个权限控制的第一步,扫描界面把要分配权限的元素的信息获取出来存入到数据库中。
这一步分三小步:
(1).标出界面所要分配权限的元素
(2).扫描界面获取所要分配权限的元素信息。(ID,标题,层级关系)
(3).存入数据库中。
1.标出界面所要分配权限的元素.
在扫描的时候一开始我觉得很难因为HTML元素过多又有很多层级关系。一开始用的是<div>标签来表示HTML所要分配权限的元素,发现这个方案不行,比如把添加用户按钮加上DIV那么这个按钮的样式就变了还得调样式我现在做的KS系统有将近100个界面,再加上现在的界面已经确定好样式,调好CSS,加上再加上DIV的话那么得重新调界面,就这个问题想了两三天,最后我想到要不自定义一个HTML元素标签为:<box></box>为这个标签加上ID和Title为:<box Title=“添加按钮”></box>,用这个标签来标记所要分配权限的元素。这样的话既不用更改样式又能获取到所要的信息。更改之后的界面后台代码为:
复制代码 代码如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<meta content="kudychen@gmail.com" />
<meta http-equiv="X-UA-Compatible" content="IE=EmulateIE7" />
<title>用户管理——查询用户</title>
<script src=""></script>
<script src=""></script>
<link href="" type="text/css" />
<link href="" type="text/css" />
<style type="text/css">
.btn-middle {
width: 76px;
}
</style>
</head>
<body>
<form method="post" runat="server" >
<%--box标记 main 开始标记--%>
<box title="主要">
<div>当前位置:用户管理 -> 查询用户</div>
<div></div>
<%--box标记 QueryUser 开始标记--%>
<box title="查询用户">
<div >
<div>
<span></span>
<h3>快速搜索</h3>
</div>
<div></div>
<div></div>
<div></div>
<div></div>
<div>
<div>
<div>
<label>用户名:</label>
<input value="" type="text" />
<asp:LinkButton runat="server"
OnClick="lbtQuery_Click"><span >查询</span></asp:LinkButton>
<%--box标记 AddUser 开始标记--%>
<box title="添加用户">
<a href="https://www.jb51.net/AdmAddUser.aspx">
<span>添加用户</span>
</a>
</box>
<%--box标记 AddUser结束标记--%>
</div>
</div>
</div>
</div>
</box>
<%--box标记 QueryUser结束标记--%>
<%--box标记 UserList开始标记--%>
<box title="用户列表">
<span>
<div></div>
<div></div>
<div></div>
<div></div>
<div>
<div>
<div>
<span></span>
<h3>用户列表</h3>
</div>
<div></div>
<asp:Repeater runat="server" onitemcommand="rpUserInfo_ItemCommand">
<HeaderTemplate>
<table cellspacing="0" cellpadding="0">
<tr>
<th scope="col">用户名称</th>
<th scope="col">角色</th>
<th scope="col">操作记录</th>
<th scope="col">编辑</th>
</tr>
</HeaderTemplate>
<ItemTemplate>
<tr>
<td><%#Eval("UserName")%></td>
<td><%#Eval("RoleName")%></td>
<td><a href="AdmOperatorRecord.aspx?UserId=<%#Eval("UserNo") %>" title="操作记录">操作记录</a></td>
<td>
<%--box标记 EditUserInfo开始标记--%>
<box title="编辑用户">
<a title="编辑" href="AdmUpdateUser.aspx?UserId=<%#Eval("UserNo") %>">
<span>
</span>
</a>
</box>
<%--box标记 EditUserInfo结束标记--%>
</td>
</tr>
</ItemTemplate>
<FooterTemplate>
</table>
</FooterTemplate>
</asp:Repeater>
</div>
</div>
</span>
<span>第一页</span> <span>上一页</span> <span>下一页</span> <span>最后一页</span> 第<span></span>页/共<span></span>页
</box>
<%--box标记 UserList 结束标记--%>
</box>
<%--box标记 main 结束标记--%>
</form>
</body>
</html>
2.扫描界面获取所要分配权限的元素信息。
由于界面上有了<box>这个元素来表示权限的元素,这样扫描起来就好一些了不过还是遇到了不少的问题,最终还是解决了,最难的是扫描出两个<box>之间的父子关系。下面是JS代码:
复制代码 代码如下: