推薦:ASP.NET筆記之 圖庫(kù)權(quán)限設(shè)置的方法本篇文章小編為大家介紹,ASP.NET筆記之 圖庫(kù)權(quán)限設(shè)置的方法。需要的朋友參考下
1、ASP.NET的好壞處
CodeBehind:“前aspx后cs”的模式,
(1、aspx(控件定義、html、css)控制頁(yè)面長(zhǎng)相,cs控制程序邏輯
aspx就是模板引擎,不需要再去尋找第三方的模板引擎
(2、aspx中調(diào)用cs的成員級(jí)別必須是protected或者public不能是private
因?yàn)楫?dāng)前this執(zhí)行的是當(dāng)前的子類(通過(guò)反編譯查看)

2、

Literal:
Mode屬性,避免XSS攻擊
TextBox:
AutopostBack=true 焦點(diǎn)離開(kāi)Textbox提交表單
ASP.NET中經(jīng)常不直接調(diào)用submit而是調(diào)用_doPostBack方法提交表單
TestChanged事件配合AutopostBack可以點(diǎn)擊submit自動(dòng)提交表單更新輸入文本
Button:OnCLientClick
return confirm("真的要執(zhí)行嗎?")


3、Button、LinkButton、ImageButton讓多個(gè)控件共享一個(gè)處理函數(shù):
command屬性設(shè)置響應(yīng)函數(shù)
CommandArgument=“daomul”(命令參數(shù)傳參數(shù))
CommandName=“Remove”(名字)
4、
Panal:
弄成"高級(jí)設(shè)置"(fieldset)的渲染形式:GroupingText=“高級(jí)設(shè)置”
HyperLink:引用站內(nèi)內(nèi)部資源的時(shí)候很方便(自動(dòng)轉(zhuǎn)換路徑)
NavigateUrl屬性

5、
FileUpload:
FileUploadl.HasFile:用戶是否選擇了文件
FileUploadl.SaveAs("根目錄全路徑"):
Server.Mapath或者VirtualPathUtility.ToAbsolute都可以
path=Server.Mapath(“~/upload/”);
漏洞:(只允許上傳指定類型的文件)
System.IO.File.Delete(Server.Mapath.("~/upload/"));
System.IO.File.ReadAllText(Server.Mapath.("~/upload/"));
6、實(shí)例:注冊(cè)界面
Register.aspx
<!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">
<body>
<form id="form1" runat="server">
<div>
<table border="0" cellpadding="0" cellspacing="0">
<tr>
<td>
<asp:Label ID="LabelName" runat="server" Text="姓名"></asp:Label>
</td>
<td>
<asp:TextBox ID="txtUserName" runat="server" AutoPostBack="True"
ontextchanged="txtUserName_TextChanged"></asp:TextBox>
<asp:Label ID="errorMsg" runat="server"
Text="Label" CssClass="error" Visible="False"></asp:Label>
</td>
</tr>
<tr>
<td>
<asp:Label ID="Label2" runat="server" Text="密碼"></asp:Label>
</td>
<td>
<asp:TextBox ID="txtPassWord" runat="server"></asp:TextBox>
密碼強(qiáng)度:
<span id="spanPassWord" ></span>
</td>
</tr>
<tr>
<td>
<asp:Label ID="Label3" runat="server" Text="重復(fù)輸入密碼"></asp:Label>
</td>
<td>
<asp:TextBox ID="txtPassWord_Second" runat="server"></asp:TextBox>
</td>
</tr>
<tr>
<td>
<asp:Label ID="Label4" runat="server" Text="郵箱"></asp:Label>
</td>
<td>
<asp:TextBox ID="txtEmail" runat="server"></asp:TextBox>
</td>
</tr>
<tr>
<td>
<asp:Button ID="btnRegister" runat="server" Text="注冊(cè)"
onclick="btnRegister_Click" />
</td>
</tr>
<tr>
<td>
<asp:Label ID="LabelErrorMsg" runat="server" Visible="False"></asp:Label>
</td>
</tr>
</table>
</div>
</form>
</body>
<head id="Head1" runat="server">
<style type="text/css">
.error{background:Red;}
</style>
<title>注冊(cè)用戶</title>
<script src="Scripts/jquery-1.4.1.js" type="text/javascript"></script>
<script type="text/javascript">
$(function () {
$("#<%=txtPassWord.ClientID %>").blur(function () {
var str = $(this).val();
if (str.length <= 6) {
$("#spanPassWord").text("弱");
}
else {
//含有數(shù)字、字母
var check = //w/;
if (check.test(str)) {
$("#spanPassWord").text("強(qiáng)");
}
else {
$("#spanPassWord").text("中");
}
}
});
$("#<%=form1.ClientID %>").submit(function () {
var pas1 = $("#<%=txtPassWord.ClientID %>").val();
var pas2 = $("#<%=txtPassWord_Second.ClientID %>").val();
if (pas1 != pas2) {
alert("兩次輸入密碼不一致,請(qǐng)重新輸入");
return;
}
var sEmail = $("#<%=txtEmail.ClientID %>").val();
var check = /.+@.+/;
if (!check.test(sEmail)) {
alert("郵箱格式不正確,請(qǐng)重新輸入");
return;
}
});
});</script>
</head>
</html>


插入數(shù)據(jù)記錄:INSERT INTO [dbo].[T_userInfo] ([sUserName], [sPassWord], [Email]) output Inserted.Id VALUES (@sUserName, @sPassWord, @Email)
(1、增加SQL語(yǔ)句,
(2、增加一個(gè)output Insert.Id 在Insert語(yǔ)句當(dāng)中
(3、設(shè)置ExecuteMode屬性為Scalar
7、三種控件的區(qū)別:html控件、服務(wù)端控件。runat=server 的控件(最好)
a1.Attributes("aaa")="建屬性賦值";

8、驗(yàn)證控件

(1、 RequiredFieldVal:
設(shè)置哪個(gè)控件和顯示名稱(還有CausesValdation焦點(diǎn)移開(kāi)) -----為空
初始值:InitleValue(請(qǐng)輸入關(guān)鍵字、包括下拉框的初始值)

Validator共性
!!!!!!!!!!
if(!IsValid){return;}
if(this.IsValid){//防止跳過(guò)客戶端校驗(yàn)IsValid表示頁(yè)面中所有Validator是否都通過(guò)了
label1.Text="";
}
else{
label1.Text="客戶端填寫(xiě)不足或有錯(cuò)誤";
}


ValidstionGroup 分組(表單可以在頁(yè)面內(nèi)單個(gè)組提交,而不關(guān)聯(lián)其他組)相同于按鈕的name
(2、RangeValidator:范圍驗(yàn)證
最大最小比較
Date.Now.()baidu下

(3、只有RequiredFieldValidator可以對(duì)字段為空進(jìn)行驗(yàn)證
(4、CompareValidator:比較驗(yàn)證(類型校驗(yàn)、與其他控件比較、)
ControlToCompare設(shè)置為要比較的控件

RegularExpression:
VaildationExpression 正則表達(dá)式驗(yàn)證
CustomVaildate自定義控件驗(yàn)證
ServerValidate服務(wù)端校驗(yàn)代碼
ClientVlidtionFunction

(5、ValidationSummary匯總錯(cuò)誤信息
text 和ErrorMsg的區(qū)別,ErrorMsg就是用于ValidationSummary中,
而text則是直接顯示在驗(yàn)證控件位置


母版:
//操作模板頁(yè)的控件
Button btn=(Button)this.Master.FindControl("Button1");
btn.Visible=!btn.Vissble;
this.Master.Mapath();
虛擬路徑轉(zhuǎn)化為客戶端訪問(wèn)的路徑(不是服務(wù)端控件):
src="<%=ResolveClientUrl%>"
this.ResolveClientUrl();
ResolveClientUrl:考慮當(dāng)前頁(yè)面的路徑
ResolveUrl:生成一個(gè)從根開(kāi)始的路徑


分享:判斷WebBrowser瀏覽器網(wǎng)頁(yè)加載完成的處理方法.net 中通過(guò) SqlConnection 連接 sql server,我們會(huì)發(fā)現(xiàn)第一次連接時(shí)總是很耗時(shí),但后面連接就很快,這個(gè)其實(shí)和SqlConnection 的連接池機(jī)制有關(guān),正確的理解這個(gè)連接池機(jī)制,有助于我們編寫(xiě)高效的數(shù)據(jù)庫(kù)應(yīng)用程序。
新聞熱點(diǎn)
疑難解答
圖片精選