从零开始学ASP.NET(基础篇)

**第一天

** 学习目的:

  • 掌握最基本的Label、TextBox、Button控件用法

  • 掌握用StringBuider类连接字符串

  • 理解服务器的环境变量

StringBuilder类:
命名空间是:System.Text。

StringBuilder类是个高效的类,StringBuilder.Append连接字符串的方法是非常快的。用于连接大量的字符串,其速度的优越性就会体现出来。

先举几个例子:
在cs或vb文件的头部加上
[C#]using System.Text;
[VB]Imports System.Text

[C#]StringBuilder sbFirst = new StringBuilder();
sbFirst.Append(“这是第一个学ASPNET的例子 ”);
sbFirst.Append( “这个例子太简单 ”);
sbFirst.Append( “连三岁小陔都会做,我早知道了,嘿嘿。”);
Response.Write(sbFirst.ToString());

[VB]Dim sbFirst As StringBuilder = New StringBuilder()
sbFirst.Append(“这是第一个学ASPNET的例子 ”)
sbFirst.Append( “这个例子太简单 ”)
sbFirst.Append( “连三岁小陔都会做,我早知道了,嘿嘿。”)
Response.Write(sbFirst.ToString)

下面就可以做正题了:
先建立一个C#的WEB应用程序工程,这废话我就少说了吧。
放一个Button控件:ID为btnShowVariable
放一个Label控件:ID为labServerVariable

添加Button的单击事件,如下代码
private void btnShowVariable_Click( object sender, System.EventArgs e)
{
labServerVariables.Text = "";

StringBuilder info = new StringBuilder();

foreach ( object objVar in Request.ServerVariables)
{
info.Append("

1<span style="font-size:9pt">");   
2info.Append(objVar.ToString());   
3info.Append(" = <font color="blue">");   
4info.Append(Request.ServerVariables[objVar.ToString()]);   
5info.Append("</font></span>
1<br/>

");
}

labServerVariables.Text = info.ToString();
}

结果显示:

图片如下:

这样我们就可以这样用
Response.Write(Request.ServerVariables["REMOTE_ADDR"]); // IP地址
Response.Write("

1<br/>

");
Response.Write(Request.ServerVariables["URL"]); // 网页的URL

**第二天

** 学习目的:

  • 掌握文本框的用法

  • 初次接触try…catch…语法

今天内容很轻松,用一个例子,输入年月日,判断输入是否正确

图片如下:

用个文本框,ID分别为txtYear,txtMonth,txtDate;
检验按钮的代码为:
private void btnCheck_Click( object sender, System.EventArgs e)
{
int year, month, date;

// 先把输入的字符转成int类型,如果非数字型,
// 会触发错误
try
{
year = Convert.ToInt32(txtYear.Text);
month = Convert.ToInt32(txtMonth.Text);
date = Convert.ToInt32(txtDate.Text);
}
catch
{
labCheckInfo.Text = "输入的是非数字字符。";
return ;
}

// 如果第一步检验合格,就把输入的数字转化为日期格式
// 如果不符合日期格式即引发错误
try
{
DateTime dt = new DateTime(year, month, date);
}
catch
{
labCheckInfo.Text = "输入的数字不符合日期格式";
return ;
}

labCheckInfo.Text = "输入正确";
}

嗯,补充一下,关于StringBuider
在处理字符串的时候很多人喜欢+=,其实对于string来说,一旦定义了就无法更改了
所谓的+只是新建的一个新的string变量并赋值
所以对于尽量使用StringBuider的Append的方法,这样将大量的节省服务器的资源

**第三天

** 学习目的:

  • 掌握下拉列表框的用法,并理解AutoPostBack属性;

  • 理解IsPoskBack及用法;

  • 初识DataTable的增加列、行,与下拉列表框绑定的方法。

今天的内容稍多些,而且涉及一些比较常用的,如IsPostBack及DataTable的基本用法。

知识点:
IsPostBack:在页面onLoad之间是false值,而当从服务器回传后,该值变为true。当页面中的Button或ImageButton等触发事件,都会把表单回传到服务器,而返回时又会引发onLoad事件。为了节省服务器资源,有些加载中需进行一次,而不需要在回传后多次发生,可以用!IsPoskBack来作为条件,那么页面第一次加载后,以后就不会发生。该属性可以帮助你提高程序的性能。
DataTable:即数据表,.Net 程序中最常用的类,特别是数据库开发中,没有该类的程序是不可想象的。

先做个小程序来练练手,很简单,就一个下拉菜单,取名dlstWeb。在属性的Itmes选项中打开以下对话框,添加各项:

图片如下:
按Alt+滚轮缩放图片,单击查看完整图片

ASPX中的代码为:

1<asp:dropdownlist autopostback="True" id="dlstWeb" runat="server" style="Z-INDEX: 101; LEFT: 32px;   
2POSITION: absolute; TOP: 32px" width="88px">
3<asp:listitem value="http://www.sina.com.cn">新浪 </asp:listitem>
4<asp:listitem value="http://www.sohu.com">搜狐</asp:listitem>
5<asp:listitem value="http://www.163.com">网易</asp:listitem>
6</asp:dropdownlist>

在下拉框的SelectedIndexChanged事件中的加入代码:
private void dlstWeb_SelectedIndexChanged( object sender, System.EventArgs e)
{
Response.Write("

1<script language="javascript">window.open('" +dlstWeb.Selectedvalue + "');</script>

");
}

按F5运行,可是我们发现这下拉框选择时什么事也没发生。原来原因是出在下拉框的AutoPostBack属性上,把它设为true后再试试,一切OK了。
下面我们增加些难度,下拉框中的内容很多情况下不是事先固定的,而是要动态添加。这里设计是用一数据表DataTable与之联系起来。

另建一文件,按上添加一下拉框,取名dlstWeb,先设AutoPostPack为false,否则在刚启动而面就触发SelectedIndexChanged事件,弹出窗口就乱飞了。
在onLoad事件中添加代码,注意DataTable用法及IsPoskBack
DataTable属于System.Data命名空间,所以如果页面没预添加,可以自行增加这一行。

private void Page_Load( object sender, System.EventArgs e)
{
// 用IsPostBack判断,只在没有回传时才初始化
// 这样可以防止每次刷新或回传时,都执行一次以下代码
// 可以节省服务器的资源了。
if (!IsPostBack)
{
DataTable dt = new DataTable();
DataRow dr;

// 在表中增加字段
dt.Columns.Add("WebName", typeof ( string ));
dt.Columns.Add("WebUrl", typeof ( string ));

// 表中增加行
dr = dt.NewRow();
dr["WebName"] = "新浪";
dr["WebUrl"] = " http://www.sina.com.cn ";
dt.Rows.Add(dr);

dr = dt.NewRow();
dr["WebName"] = "网易";
dr["WebUrl"] = " http://www.163.com ";
dt.Rows.Add(dr);

dr = dt.NewRow();
dr["WebName"] = "搜狐";
dr["WebUrl"] = " http://www.sohu.com ";
dt.Rows.Add(dr);

// 把表与下拉菜单绑定数据
dlstWeb.DataSource = dt;
dlstWeb.DataTextField = "WebName";
dlstWeb.DatavalueField = "WebUrl";
dlstWeb.DataBind();

// 开始时就把下拉菜单的AutoPostBack设为false,
// 防止一开始就乱跳出网页来
dlstWeb.AutoPostBack = true ;
}
}

下面的事件与前面一模一样了
private void dlstWeb_SelectedIndexChanged( object sender, System.EventArgs e)
{
Response.Write("

1<script language="javascript">window.open('" +dlstWeb.Selectedvalue + "');</script>

");
}

小结:今天的一些知识非常重要,为了理解,程序的难度并不高。但这是以后程序设计的基础,所以这些你一定要掌握。

VB.NET增加字段代码稍有不同,如下:

// 在表中增加字段
dt.Columns.Add("WebName", GetType ( String ))
dt.Columns.Add("WebUrl", GetType ( String ))

其它都差不多了。

**每四天

** 学习目的:

  • 学习ADO.NET用法,并如何用DataRearder读取数据

今天练习数据库的最基本用法,如何打开数据库。首先在网站设置文件web.config文件的

  1<configuration>下方加入以下节点:   
  2  
  3<configuration>
  4<appsettings>
  5<add key="数据库1" value="ex01.mdb"></add>
  6</appsettings>   
  7  
  8……   
  9  
 10该节点设置了数据库的路径,这样就可以很方便的调用数据库文件了,调用方法为:   
 11Server.MapPath(ConfigurationSettings.AppSettings["数据库1"])   
 12这是ASP.NET程序的通用方法,以后介绍的SQL SERVER数据库也是在此设置的。   
 13好开始做程序,首先在CS文件的头部加入:   
 14using  System.Configuration;   
 15using  System.Data.OleDb;   
 16using  System.Text;   
 17以下在Page的Load事件中,读取ACCESS数据库,并用表格显示出来:   
 18private void  Page_Load(  object  sender, System.EventArgs e)   
 19{   
 20StringBuilder sbTable =  new  StringBuilder();  // 用于输出表格的语句    
 21  
 22string  strConnection = "Provider=Microsoft.Jet.Oledb.4.0;Data Source="   
 23\+ Server.MapPath(ConfigurationSettings.AppSettings["数据库1"]);   
 24  
 25// 连接数据库的语句    
 26OleDbConnection conn =  new  OleDbConnection(strConnection);   
 27// 建立DbCommand对象    
 28OleDbCommand cmd = conn.CreateCommand();   
 29cmd.CommandText = "SELECT * FROM Book";   
 30  
 31// 打开数据库    
 32conn.Open();   
 33  
 34// 用DataReader读取数据    
 35OleDbDataReader dr = cmd.ExecuteReader();   
 36  
 37sbTable.Append("<table border="1" cellpadding="0" cellspacing="0"><tr>");   
 38sbTable.Append("<td>书名</td><td>作者</td><td>单价<td></td></td></tr>");   
 39while  (dr.Read())   
 40{   
 41sbTable.Append("<tr><td>");   
 42sbTable.Append(dr["BookTitle"].ToString());   
 43sbTable.Append("</td><td>");   
 44sbTable.Append(dr["Author"].ToString());   
 45sbTable.Append("</td><td>");   
 46sbTable.Append(dr["UnitPrice"].ToString());   
 47sbTable.Append("</td><tr>");   
 48}   
 49sbTable.Append("</tr></tr></table>");   
 50  
 51// 记住dr用毕必须关闭,否则会阻塞服务器    
 52dr.Close();   
 53  
 54// DbConnection是受托管的,可以不关闭   
 55// 但为良好的编程习惯,应该关闭    
 56conn.Close();   
 57  
 58Response.Write(sbTable.ToString());   
 59  
 60}   
 61显示结果   
 62  
 63图片如下:   
 64![](http://www.5d.cn/bbs/uploadFiles/2004-11/2_1313241_1.gif)
 65
 66**第五天  
 67  
 68** 学习目的:   
 69
 70
 71* 掌握ADO.NET打开SQL SERVER数据库的方法。   
 72  
 73今天做个非常普通的例子,做一个用户登录框。主要是通过这个练习认识一下SQL SERVER数据库的连接方法。和昨天的例子方法基本相同,很容易掌握的。   
 74先建立SQL SERVER数据库,库名为AspNetABC,并建立一Member新表,建表SQL如下:   
 75  
 76CREATE TABLE [dbo].[Member] (   
 77[MemberID] [int] IDENTITY (1, 1) NOT NULL ,   
 78[MemberName] [nvarchar] (50) COLLATE Chinese_PRC_CI_AS NOT NULL ,   
 79[Password] [nvarchar] (50) COLLATE Chinese_PRC_CI_AS NOT NULL ,   
 80[Gender] [bit] NOT NULL ,   
 81[Birthday] [datetime] NULL ,   
 82[Email] [nvarchar] (50) COLLATE Chinese_PRC_CI_AS NULL   
 83) ON [PRIMARY]   
 84  
 85ALTER TABLE [dbo].[Member] WITH NOCHECK ADD   
 86CONSTRAINT [PK_Member] PRIMARY KEY CLUSTERED   
 87(   
 88[MemberID]   
 89) ON [PRIMARY]   
 90  
 91与上一例子差不多,在web.config文件中再增加一行:   
 92<appsettings>
 93<add key="数据库1" value="ex01.mdb"></add>
 94<add key="SqlDatabase1" value="data source=localhost;user id=sa;password=sa;initial catalog=AspNetABC;Connect Timeout=30"></add>
 95</appsettings>   
 96  
 97在面中添加二个文本框,txtMemberName、txtPassword,并设置txtPassword的TextMode为Password。设置按钮btnLogin。btnLogin的事件代码如下:   
 98  
 99private void  btnLogin_Click(  object  sender, System.EventArgs e)   
100{   
101// 先检验输入正确性    
102if  (txtMemberName.Text == String.Empty || txtMemberName.Text.Trim() == "")   
103{   
104Response.Write("<script language="javascript">alert('帐号不能为空')</script>");   
105return  ;   
106}   
107if  (txtPassword.Text == String.Empty || txtPassword.Text.Trim() == "")   
108{   
109Response.Write("<script language="javascript">alert('没有输入密码')</script>");   
110return  ;   
111}   
112  
113string  strConnection = ConfigurationSettings.AppSettings["SqlDatabase1"];   
114string  sqlMember = "SELECT MemberName ,[Password] FROM Member "   
115\+ " WHERE MemberName = '" + txtMemberName.Text.Trim() + "'"   
116\+ " AND [Password] = '" + txtPassword.Text.Trim() + "'";   
117  
118// 连接SqlServer数据库    
119SqlConnection conn =  new  SqlConnection(strConnection);   
120// 建立SqlCommand    
121SqlCommand cmd = conn.CreateCommand();   
122cmd.CommandText = sqlMember;   
123conn.Open();   
124// 建立DataReader    
125SqlDataReader dr = cmd.ExecuteReader();   
126  
127// 判断DataReader是否为空记录    
128if  (dr.HasRows)   
129{   
130Response.Write("<script language="javascript">alert('" + txtMemberName.Text + "欢迎你!')</script>");   
131}   
132else    
133{   
134Response.Write("<script language="javascript">alert('找不到该会员,或密码错误。')</script>");   
135}   
136  
137// 千万不要忘记关闭DataReader    
138dr.Close();   
139  
140conn.Close();   
141}   
142  
143好了,一个非常简单的登录框做好了。当然在实际程序中还应加入跳转等,这个就留给你做了。   
144
145
146**第六天  
147  
148** 学习目的   
149
150
151* 掌握如何用ADO.NET插入新的记录   
152  
153我们学得好快,今天做一个简易的新闻发布网页,可以说是个演示型的,只是让大家能理插入数据的最主要步骤。掌握今天的内容,我们就有基础可以做一个稍有实用的新闻程序了。   
154为了不使注意力分散,程序没有加入输入的验证,很快我会接下去写一个验证输入的方法。   
155  
156  
157图片如下:   
158![按Alt+滚轮缩放图片,单击查看完整图片](http://www.5d.cn/bbs/uploadFiles/2004-11/4_1315203_1.gif)   
159  
160仍用昨天的方法新建一数据表,SQL语句如下:   
161CREATE TABLE [dbo].[NewsArticle] (   
162[NewsArticleID] [int] IDENTITY (1, 1) NOT NULL ,   
163[Title] [nvarchar] (50) COLLATE Chinese_PRC_CI_AS NOT NULL ,   
164[SubTitle] [nvarchar] (50) COLLATE Chinese_PRC_CI_AS NULL ,   
165[Content] [ntext] COLLATE Chinese_PRC_CI_AS NOT NULL ,   
166[Writer] [nvarchar] (10) COLLATE Chinese_PRC_CI_AS NULL ,   
167[PubTime] [datetime] NOT NULL   
168) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]   
169  
170ALTER TABLE [dbo].[NewsArticle] WITH NOCHECK ADD   
171CONSTRAINT [DF_NewsArticle_PubTime] DEFAULT (getdate()) FOR [PubTime],   
172CONSTRAINT [PK_NewsArticle] PRIMARY KEY CLUSTERED   
173(   
174[NewsArticleID]   
175) ON [PRIMARY]   
176GO   
177  
178按昨天的方法加入头部的语句,在提交按钮中建立以下事件:   
179  
180private void  btnPublish_ServerClick(  object  sender, System.EventArgs e)   
181{   
182string  strConnection = ConfigurationSettings.AppSettings["SqlDatabase1"];   
183  
184// 连接SqlServer数据库    
185SqlConnection conn =  new  SqlConnection(strConnection);   
186// 建立SqlCommand    
187SqlCommand cmd = conn.CreateCommand();   
188cmd.CommandText = "INSERT INTO NewsArticle (Title, SubTitle, Writer, Content) valueS ("   
189\+ "'" + txtTitle.Text + "',"   
190\+ "'" + txtSubTitle.Text + "',"   
191\+ "'" + txtWriter.Text + "',"   
192\+ "'" + txtContent.Text + "')";   
193conn.Open();   
194//Response.Write (cmd.CommandText);    
195  
196// 插入记录    
197try    
198{   
199cmd.ExecuteNonQuery();   
200}   
201catch  (Exception ex)   
202{   
203Response.Write("<script language="javascript">alert('输入错误,数据库不能更新。')</script>");   
204}   
205finally    
206{   
207conn.Close();   
208}   
209}   
210  
211注意Command对象的ExecuteNonQuery()方法使用,该方法可以用于插入、更新、删除等操作,是Command对象的重要方法。今天介绍了Command语句的最基本用法,下次还将介绍占位符的用法。好了,各位先消化一下,明后天将做实用的东东了。 
212
213**第七天  
214  
215** 学习目的   
216
217
218* 接触验证控件   
219  
220昨天介绍了SQL SERVER插入数据,但是我们省略了验证输入这一步。以前的做法是用语句逐个判断输入的正确性,如是否为空,长度是否超过等。现在.NET中有了验证控件,可以使我们在编程的语句中大在简化了。今天介绍验证控件中最基本的一个,RequeiredFieldValidator控件,是用来判别否输入控件是否为空值,如为空则引发错误。   
221  
222RequeiredFieldValidator可以用来验证TextBox、ListBox、DropDownList、RadioButtonList及Html控件中的InputText、TextArea、Select、InputFile等。   
223  
224属性介绍:   
225ControlToValidate  :指点验证某一控件的控件名,如为空,将引发异常;   
226ErrorMessage  :错误提示信息;   
227IsValid  :用于判断是否通过验证;   
228Display  :有三个值,None表示错误时不显示信息,但在ValidationSunmmary控件中显示;Static表示不论错误提示是否出现,都占页面空间;Dymatic:只有错误提示才占用空间。   
229Text  :文本内容。和ErrorMessage一起使用时,将显示Text错误信息。该种情况可以通过ValidationSummay控件显示ErrorMessage属性的提示。   
230  
231使用方法:   
232设置:   
233txtTitle:MaxLength(50);   
234txtSubTitle: MaxLength(50);   
235txtWriter: MaxLength(10);   
236这样可以防止输入过长字符串   
237rfvTitle:ControlToValidate(txtTitle)、ErrorMessage(“标题必须输入。”)   
238rfvContent:ControlToValidate(txtTitle)、ErrorMessage(“内容必须输入。”)   
239  
240这样在没有验证通过时,会出现下图信息提示,并不执行插入语句。直到验证正确后,才执行数据更新。   
241  
242  
243图片如下:   
244![按Alt+滚轮缩放图片,单击查看完整图片](http://www.5d.cn/bbs/uploadFiles/2004-11/5_1316939_1.gif)
245
246**第八天**   
247  
248学习目的   
249
250
251* 学会SQL中的占位符用法   
252  
253在鲸鱼这几天忙死了,好几天没写了,真对不起各位。这几天让XHTML闹得不开心,虽然以前也知道这个,但没太在意。可现在我是如梦初醒,我发觉XHTML是个信号,所以这几天不得不仔细研究一下这个。很笨,我还没发觉XHTML的奥妙。确实如此,没上过台面,真不知这桌菜怎样好吃。少说了,回到正题。   
254  
255先把以前的Command的CommandText重新写过:   
256cmd.CommandText = "INSERT INTO NewsArticle (Title, SubTitle, Writer, Content)"   
257\+ " valueS ( @Title, @SubTitle, @Writer, @Content )";   
258这样代码是否很清晰了,我们可以避免一大串的难以看懂的的语句了。   
259  
260接下来,我们就给这些定位符赋予属性和值了:   
261cmd.Parameters.Add("@Title", SqlDbType.NVarChar, 50);   
262cmd.Parameters.Add("@SubTitle", SqlDbType.NVarChar, 50);   
263cmd.Parameters.Add("@Writer", SqlDbType.NVarChar, 10);   
264cmd.Parameters.Add("@Content", SqlDbType.NText);   
265  
266以上我们给每个占位符定义一个值类型,相信不难看懂吧。接者再给于值:   
267cmd.Parameters["@Title"].value = txtTitle.Text.Trim();   
268if  (txtSubTitle.Text == string.Empty || txtSubTitle.Text.Trim() == "")   
269{   
270cmd.Parameters["@SubTitle"].value = DBNull.value;   
271}   
272else    
273{   
274cmd.Parameters["@SubTitle"].value = txtSubTitle.Text.Trim();   
275}   
276if  (txtWriter.Text == string.Empty || txtWriter.Text.Trim() == "")   
277{   
278cmd.Parameters["@Writer"].value = DBNull.value;   
279}   
280else    
281{   
282cmd.Parameters["@Writer"].value = txtWriter.Text;   
283}   
284cmd.Parameters["@Content"].value = txtContent.Text;   
285  
286其实,也可以这样写:   
287cmd.Parameters.Add("@Title", SqlDbType.NVarChar, 50) .value = txtTitle.Text.Trim();   
288这要看你喜欢了。   
289  
290不错吧,程序是否很有条理。   
291  
292程序代码:   
293private void  btnPublish_ServerClick(  object  sender, System.EventArgs e)   
294{   
295string  strConnection = ConfigurationSettings.AppSettings["SqlDatabase1"];   
296  
297// 连接SqlServer数据库    
298SqlConnection conn =  new  SqlConnection(strConnection);   
299// 建立SqlCommand    
300SqlCommand cmd = conn.CreateCommand();   
301cmd.CommandText = "I</configuration></configuration>
Published At
Categories with Web编程
Tagged with
comments powered by Disqus