一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - ASP.NET教程 - ASP.NET對HTML頁面元素進行權限控制(二)

ASP.NET對HTML頁面元素進行權限控制(二)

2019-11-23 14:32ASP.NET教程網 ASP.NET教程

分三步實現:標出界面所要分配權限的元素、掃描界面獲取所要分配權限的元素信息、存入數據庫中,感興趣的朋友可以了解下

這是這個權限控制的第一步,掃描界面把要分配權限的元素的信息獲取出來存入到數據庫中。 

這一步分三小步: 

(1).標出界面所要分配權限的元素 

(2).掃描界面獲取所要分配權限的元素信息。(ID,標題,層級關系) 

(3).存入數據庫中。 

1.標出界面所要分配權限的元素. 

在掃描的時候一開始我覺得很難因為HTML元素過多又有很多層級關系。一開始用的是<div>標簽來表示HTML所要分配權限的元素,發現這個方案不行,比如把添加用戶按鈕加上DIV那么這個按鈕的樣式就變了還得調樣式我現在做的KS系統有將近100個界面,再加上現在的界面已經確定好樣式,調好CSS,加上再加上DIV的話那么得重新調界面,就這個問題想了兩三天,最后我想到要不自定義一個HTML元素標簽為:<box></box>為這個標簽加上ID和Title為:<box id="AddID" style="margin: 3px auto 0px; padding: 0px 3px; outline: none; line-height: 25.2px; font-size: 14px; background: rgb(242, 246, 251); width: 640px; clear: both; border-top: 1px solid rgb(0, 153, 204); border-right: 1px solid rgb(0, 153, 204); border-left: 1px solid rgb(0, 153, 204); border-image: initial; border-bottom: none; font-family: tahoma, arial, "Microsoft YaHei";"> 復制代碼代碼如下:


<!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 name="Author" content="[email protected]" /> 
<meta http-equiv="X-UA-Compatible" content="IE=EmulateIE7" /> 
<title>用戶管理——查詢用戶</title> 

<script src="../../js/DIV/jquery.js"></script> 
<script src="../../js/DIV/DIV.js"></script> 
<link href="../../css/admin.global.css" rel="stylesheet" type="text/css" /> 
<link href="../../css/admin.content.css" rel="stylesheet" type="text/css" /> 

<style type="text/css"> 
.btn-middle { 
width: 76px; 

</style> 

</head> 
<body> 
<form id="Form" method="post" runat="server" > 
<%--box標記 main 開始標記--%> 
<box id="main" />
2.掃描界面獲取所要分配權限的元素信息。 

由于界面上有了<box>這個元素來表示權限的元素,這樣掃描起來就好一些了不過還是遇到了不少的問題,最終還是解決了,最難的是掃描出兩個<box>之間的父子關系。下面是JS代碼: 

復制代碼代碼如下:


$(document).ready(function () { 

var rootboxs = document.getElementById("main"); 
var child = rootboxs.childNodes; 
findchildbox(child) 


}); 
//搜尋子節點 
function findchildbox(parentNode) { 

for (var i = 0; i < parentNode.length; i++) { 
/// 
if (parentNode[i].nodeName == "BOX") { 

var childboxId = parentNode[i].id; 
var childboxTitle = encodeURI(parentNode[i].title); 
var parentbox = findparentbox(parentNode[i].parentNode); 
var parentboxId = parentbox.id; 
if (window.XMLHttpRequest) { 
//IE7 above,firefox,chrome^^ 
xmlhttp = new XMLHttpRequest(); 
//為了兼容部分Mozillar瀏覽器,當來自服務器響應開頭不是xml,導致的無法響應問題 
if (xmlhttp.overrideMimeType) { 
xmlhttp.overrideMimeType('text/xml'); 


else if (window.ActiveXObject) { 
//IE5\IE6 
xmlhttp = new activeXObject("Microsoft.XMLHTTP"); 

if (xmlhttp == null || xmlhttp == undefined) { 
alert("con't create XMLHttpRequest Object"); 

//注冊回調函數 
xmlhttp.onreadystatechange = callback; 
//發送信息 

xmlhttp.open('GET', '../../Manager/RoleManager/AddBox.ashx?childboxId=' + childboxId + '&childboxTitle=' + childboxTitle + '&parentboxId=' + parentboxId, true); 
xmlhttp.send(null); 


function callback() { 
//判斷交互是否完成,是否正確返回 
if (xmlhttp.readyState == 4 && xmlhttp.status == 200) { 






findchildbox(parentNode[i].childNodes) 





//查詢父節點 
function findparentbox(child) { 

if (child.nodeName == "BOX") { 
return child; 
} else { 
return findparentbox(child.parentNode) 




3.存入數據庫中。 

利用AJAX存入到數據庫中,一開始就遇到了問題,因為掃描界面所需要的時間太短在還沒有把第一條數據插入到數據庫的時候第二條數據就來了這樣導致了第一條數據的部分信息就會被第二條記錄替代了導致存入數據庫的數據出現了問題。一開始我是打算在JS那里加上個延遲,結果表名不行。然后我就在一班程序里面加入一個類似鎖的一個東西,算作延遲吧這樣存入的數據就不會錯誤了下面是代碼: 

復制代碼代碼如下:


using System; 
using System.Collections.Generic; 
using System.Linq; 
using System.Web; 
using BLL.Manager.RoleUserManagerBLL; 
using System.Data; 
using System.Text; 
using Model; 
using BLL; 

namespace ExamSystemV3.Manager.RoleManager 

/// <summary> 
/// AddBox 的摘要說明 
/// </summary> 
public class AddBox : IHttpHandler 


public void ProcessRequest(HttpContext context) 

context.Response.ContentType = "text/plain"; 
System.Threading.Thread.Sleep(1000); 
DIVEntity EDiv = new DIVEntity(); 
AdmDIVManager admDIVManager = new AdmDIVManager(); 
PublicBLL publicBll = new PublicBLL(); 
string strChildBoxId = ""; 
string strChildBoxTitle = ""; 

strChildBoxId = context.Request.QueryString["childboxId"].ToString().Trim(); 
strChildBoxTitle = context.Server.UrlDecode(context.Request.QueryString["childboxTitle"].ToString().Trim()); 
string strParentBoxId=context.Request.QueryString["parentboxId"].ToString ().Trim();; 
string strState = "是"; 
string strDateTime = publicBll.GetDate(); 
string strIP = publicBll.GetWebClientIp(); 
string strOperator ="xvshu";//context.Session["UserNo"].ToString().Trim(); ; 
EDiv.Id = strChildBoxId; 
EDiv.MainRelation = strParentBoxId; 
EDiv.DIVName = strChildBoxTitle; 
EDiv.DIVDescribe = strChildBoxTitle; 
EDiv.Operator = strOperator; 
EDiv.OperatorIP = strIP; 
EDiv.State = strState; 
EDiv.DateTime = strDateTime; 
admDIVManager.AddDIV(EDiv); 


public bool IsReusable 

get 

return false; 




利用TreeView控件顯示出來如下圖: 
ASP.NET對HTML頁面元素進行權限控制(二)

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 美女扒开奶罩让男人吃奶 | 亚洲精品久久久打桩机 | 歪歪视频在线播放无遮挡 | 国产绿帽 | 暖暖免费观看高清在线 | 成人毛片高清视频观看 | 国内精品中文字幕 | 国产精品林美惠子在线观看 | 91在线永久 | 狠狠色婷婷丁香六月 | 国产成人91高清精品免费 | 日本加勒比在线播放 | 亚洲人成毛片线播放 | chanelpreston欧美网站 | 俄罗斯一级成人毛片 | 国产精品主播在线 | 国产亚洲精品一区在线播 | 免费看片黄 | 日本高清二三四本2021 | 1024国产基地永久免费 | 天堂伊人网 | 亚欧洲乱码视频一二三区 | 免费看一区二区三区 | 亚洲精品一线二线三线 | 国产精品视频一区二区三区经 | 国产91一区二区在线播放不卡 | chinese壮直男gay老年人 | 成人性生交大片免费看软件 | 日韩在线视频一区二区三区 | 亚洲男女天堂 | 九九精品视频在线观看九九 | 日本艳鉧动漫1~6在线观看 | 99久久国语露脸精品国产 | 国产精品乱码高清在线观看 | 成人免费在线视频 | 日韩国产成人资源精品视频 | 熟睡迷j系列小说 | 久久综合中文字幕佐佐木希 | xxxx性欧美极品另类 | 激情五月开心 | 91久久综合九色综合欧美98 |