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ù)制代碼 代碼如下:
%@ 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ù)制代碼 代碼如下:
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)始的路徑


您可能感興趣的文章:- ASP.NET小結(jié)之MVC, MVP, MVVM比較以及區(qū)別(二)
- ASP.NET小結(jié)之MVC, MVP, MVVM比較以及區(qū)別(一)
- asp.net中virtual和abstract的區(qū)別分析
- Asp.net中Response.Charset與Response.ContentEncoding區(qū)別示例分析
- c#.net中const和readonly的區(qū)別
- 詳細(xì)說(shuō)明asp.net中datareader 和 dataset 的區(qū)別
- asp.net中DBNull.Value,null,String.Empty區(qū)別淺析
- asp.net 中靜態(tài)方法和動(dòng)態(tài)方法調(diào)用的區(qū)別實(shí)例分析
- .net中as和is之間的區(qū)別分析
- .net中的session與cookies區(qū)別及使用方法
- .NET MVC中ViewData,ViewBag和TempData的區(qū)別淺析