国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > .NET > 正文

ASP.NET筆記之 控件與母板的區(qū)別分析_.Net教程

2024-07-10 12:52:21
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

推薦: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

復(fù)制代碼 代碼如下:www.CuoXIn.com

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Register.aspx.cs" Inherits="登陸注冊(cè).Register" %>

<!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>


Register.apsx.cs
復(fù)制代碼 代碼如下:www.CuoXIn.com

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using 登陸注冊(cè).DAL.DataSet1TableAdapters;
using System.Text.RegularExpressions;

namespace 登陸注冊(cè)
{
public partial class Register : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{

}

protected void btnRegister_Click(object sender, EventArgs e)
{
//服務(wù)器版測(cè)試是否符合要求:郵箱餓壞密碼
if (txtPassWord.Text != txtPassWord_Second.Text)
{
LabelErrorMsg.Text = "密碼不一致!";
LabelErrorMsg.Visible = true;
return;
}
Regex reEmail = new Regex(@".+@.+");
if (!reEmail.IsMatch(txtEmail.Text))
{
LabelErrorMsg.Text = "Email格式不正確!";
LabelErrorMsg.Visible = true;
return;
}
LabelErrorMsg.Visible = false;
T_userInfoTableAdapter adapter = new T_userInfoTableAdapter();
if (adapter.GetDataByUserName(txtUserName.Text).Count >= 1)
{
errorMsg.Visible = true;
errorMsg.Text = "用戶名重復(fù),請(qǐng)重新輸入!";
return;
}
long userId=Convert.ToInt64(adapter.InsertUser(txtUserName.Text, txtPassWord.Text,
txtEmail.Text));
//讀取Session登陸信息
Session["登陸ID"] = userId;
Session["登陸標(biāo)記"] = true;
//設(shè)置可以傳參數(shù)的公共跳轉(zhuǎn)頁(yè)面
//作用1:告訴用戶注冊(cè)成功,作用2:防止用戶點(diǎn)擊刷新重復(fù)提交數(shù)據(jù)
Response.Redirect("target.aspx?Msg=注冊(cè)成功即將轉(zhuǎn)向登陸界面&RedirectURL=login.aspx");
}

protected void txtUserName_TextChanged(object sender, EventArgs e)
{
T_userInfoTableAdapter adapter = new T_userInfoTableAdapter();
if (adapter.GetDataByUserName(txtUserName.Text).Count >= 1) {
errorMsg.Visible = true;
errorMsg.Text = "用戶名重復(fù),請(qǐng)重新輸入!";
}
else{
errorMsg.Visible = false;
}
}
}
}

其中要用到的正則表達(dá)式:

插入數(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)用程序。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 罗定市| 武隆县| 蒙自县| 杨浦区| 昭平县| 卢龙县| 内丘县| 黑河市| 阿拉尔市| 寻乌县| 峡江县| 灌南县| 宝应县| 焦作市| 龙门县| 潼关县| 阿合奇县| 抚远县| 闽侯县| 闸北区| 丽水市| 星座| 长海县| 利川市| 嘉定区| 沁源县| 耒阳市| 景东| 吴江市| 泽州县| 东方市| 隆回县| 汨罗市| 安吉县| 依安县| 梁河县| 麟游县| 汝州市| 佳木斯市| 乐亭县| 湘西|