成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

用C#創建Web應用程序

開發 開發工具 后端
使用微軟正在推行的.NET技術和C#語言可以快速建立Web應用程序,其安全性和可升級性都大大勝過普通的ASP應用程序。在這篇文章里,我們將使用.NET和C#一步一步的建立一個應用程序。

系統需求:

Internet Explorer 5.5

Windows 2000 Professional, Server 或 Advanced Server

ASP+/Microsoft .NET (預覽版可以在 http://msdn.microsoft.com/net 下載)

SQL Server 7.0 + SP1 或更高版本

使用微軟.NET的高級對象模型(Advanced Object Model)可以快速建立安全的,易于升級性的Web應用程序。

微軟的.NET是一個開發商業解決方案的理想技術。.NET技術結合C#的彈性和高性能,開發商業程序比以往僅僅使用ASP的方法更為簡單。

在這篇文章里,我們將使用.NET和C#來建立一個簡單的商業應用程序--一個能夠讓客戶瀏覽你的產品目錄的程序。

這個程序包含了最基本的.NET和C#技術,在本文中,將涉及到如何建立和編譯C#的商業應用層組件。也將談到怎樣使用ASPX頁面存取組件和綁定數據。綜合使用這些技術,可以花費比傳統的ASP方法更少的時間建立Web應用程序。

穩固的.NET應用程序仍然依靠于穩固的數據庫計劃和精心編寫的存儲過程。

應用程序可以通過組件調用已經寫好的存儲過程。大部分多層方法都不推薦直接從程序中調用數據,那樣會降低程序的速度,也不利于調試。

本文主要討論C#和ASP+,不過多的討論建立數據庫和存儲過程。

組件的開發

我們將要編寫的c#組件同時作為邏輯層和數據存取層。

如果打算將來把程序移植到另一種數據庫中,比如Oracle,那么需要把邏輯層和數據存取層分別放在兩個組件中。本文中只使用SQL Server,所以不需要分開它們。

這個應用程序需要兩個頁面:Default.aspx 和 ProductList.aspx。 Default.aspx 是用戶訪問Web首先看見的頁面,它列出所有的產品種類。用戶從Default.aspx菜單中選擇種類后,將進入ProductList.aspx頁面,這個頁面顯示了當前類所有產品的列表。

在用戶使用這兩個頁面的過程中,發生了兩個動作:***個是在菜單中列出產品種類(Default.aspx),第二個是在產品列表的頁面中列出產品(ProductList.aspx)。我們可以建立兩個函數來完成這兩個任務,這兩個函數都通過調用存儲過程獲取數據。對應這兩個函數,我們在一個叫做CommerceDotNet的名字空間中建立起兩個類:Category 和 Product。(圖1)使用CommerceDotNet.Categories實例化Categories類,使用CommerceDotNet.Products實例化Products類。為了使代碼清晰,我們在不同的文件中分別聲明這兩個類。由于他們共享一個名字空間,即使在不同的文件聲明,在編譯后也將成為一個單獨的組件。

CategoryList方法傳遞了一個包含所有產品種類的數據集給系統。在Categories類中加入CategoryList的方法。

代碼如下:

namespace CommerceDotNet { 

   public class Categories { 

     public DataSet CategoryList() { 

     } 

   } 

   } 

#p#

建立了這個類以后,開始為CategoryList方法添加代碼。

CategoryList方法獲取數據的過程分為四步:1.通過SQLConnection和SQLDataSetCommand對象建立數據連接和命令對象。2.把命令對象類型設置為存儲過程。3.把存儲過程ListCategory的結果送入數據集。4.把包含結果的數據集返回給調用它的函數。

完整的CategoryList方法代碼如下:

 public DataSet CategoryList() { 

     // 建立數據連接和命令對象 

     SQLConnection myConnection = new SQLConnection 

     ("server=localhost;uid=sa;pwd=;database=commercedotnet"); 

     SQLDataSetCommand myCommand = new SQLDataSetCommand("ListCategory", myConnection); 

     // 設置命令對象類型為存儲過程 

     myCommand.SelectCommand.CommandType = CommandType.StoredProcedure; 

     // 建立和填充數據集 

     DataSet myDataSet = new DataSet(); 

     myCommand.FillDataSet(myDataSet, "CategoryList"); 

     // 返回數據集 

     return myDataSet; 

   } 

ProductsList方法和CategoryList方法類似,但是ProductsList向存儲過程傳遞了一個參數。

代碼如下:

public DataSet ProductsList(int categoryID) { 

     // 建立數據連接和命令對象 

     SQLConnection myConnection = new SQLConnection 

     ("server=localhost;uid=sa;pwd=;database=commercedotnet"); 

     SQLDataSetCommand myCommand = new SQLDataSetCommand("ListProducts", myConnection); 

     // 設置命令對象類型為存儲過程 

     myCommand.SelectCommand.CommandType = CommandType.StoredProcedure; 

     // 向存儲過程傳遞參數 

     SQLParameter parameterCategoryID = new SQLParameter("@CategoryID", SQLDataType.Int, 4); 

     parameterCategoryID.Value = categoryID; 

     myCommand.SelectCommand.Parameters.Add(parameterCategoryID); 

     // 建立和填充數據集 

     DataSet myDataSet = new DataSet(); 

     myCommand.FillDataSet(myDataSet, "Products"); 

     // 返回數據集 

     return myDataSet; 

   } 

兩個類都建立好以后,編譯程序。

使用命令:

csc /out:../bin/CommerceDotNet.dll /t:library /r:System.Data.dll CategoryDB.cs ProductDB.cs

"/out:"開關指定編譯庫名和存放位置,"/t:"開關告訴編譯器建立庫,"/r:"開關指出組件涉及到的其他庫,完整的源程序在文末后面列出。

ASP+頁面的開發

建立好組件以后,下面的工作是開發作為用戶界面ASP+頁面。前面的部分,我們設計了default.aspx 和 productslist.aspx 頁,Default.aspx頁是站點被裝入后的***頁,我們就從建立這個缺省頁面開始。

當頁面讀入時,觸發Page_Load()方法,這個方法完成了從數據庫獲取的數據并綁定到MyList的任務。首先,聲明一個ICollection型變量menuItems。然后,實例化組件,調用CategoryList方法,把數據集存放在menuItems對象中。設置MyList的數據源為menuItems。執行MyList.DataBind方法把數據綁定到MyList。

這部分代碼如下:

 <script language="C#" runat="server"> 

   void Page_Load(Object sender, EventArgs e) { 

   ICollection menuItems; 

     CommerceDotNet.Categories categories = new CommerceDotNet.Categories();

menuItems = categories.CategoryList().Tables[0].DefaultView; 

     MyList.DataSource = menuItems; 

     MyList.DataBind(); 

   } 

   </script> 

default.aspx中其他代碼與傳統的ASP頁面類似,請參見文末列出的代碼。

ProductList.aspx與default.aspx類似,但是,綁定數據的代碼有些變化,因為,在開發C#組件的時候,我們在CommerceDotNet.ProductsList方法中向存儲過程中傳遞了參數,所以,ASP+頁面中也需要有相應的變化。

CommerceDotNet.Products products = new CommerceDotNet.Products();

MyProductList.DataSource = products.ProductsList(categoryId).Tables[0].DefaultView;

MyProductList.DataBind();

至此,兩個ASP+頁面也創建完畢。

這樣,結合C#和ASP+的最基礎的應用程序就創建好了。

這個程序展示了微軟.NET和C#技術的強大威力,在這個基礎上,再作進一步的增添和修改,很容易開發出強大的站點。

【編輯推薦】

  1. 跟MVP學C#視頻教程
  2. 如何使用C#與XML創建動態分層菜單
  3. C#中的Namespace詳解
責任編輯:楊鵬飛 來源: PCPPC.CN
相關推薦

2009-09-03 17:36:13

C#創建Web應用程序

2009-08-25 09:39:21

創建C# Window

2009-08-24 09:25:18

Visual C# ..NET應用程序

2009-08-24 14:19:27

C# Windows應

2009-08-06 10:27:08

C#應用程序域

2009-08-24 13:30:50

C# Windows

2009-08-28 16:43:08

AutoCAD托管C#

2009-08-24 13:40:58

C# Windows

2009-08-24 16:02:10

C# Windows應

2009-09-22 12:22:54

ibmdwLotus

2012-03-21 09:36:33

ibmdw

2013-06-24 10:21:47

面向對象Web應用JavaScript

2012-03-15 15:35:51

iUI框架EclipseiOS Web

2010-05-20 09:48:36

2011-03-22 14:12:17

LAMP

2011-07-08 15:27:03

jQuery Mobi

2009-08-14 17:27:30

C#Windows應用

2009-08-11 13:27:22

C#創建Web Ser

2012-05-29 10:04:08

2009-08-19 15:31:32

C#控制臺應用程序
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产成人一区在线 | 免费视频一区 | 精品国产一区二区三区在线观看 | 91久久国产综合久久91精品网站 | 紧缚调教一区二区三区视频 | 欧美一级在线观看 | 亚洲精品在线看 | 九九综合 | 日日夜夜草 | 99精品国产一区二区青青牛奶 | 人妖一区| 天天艹日日干 | 天天爽综合网 | 久久一区二 | 久久久久亚洲 | 在线免费观看a级片 | www天天操 | 欧美性猛片aaaaaaa做受 | 中文字幕第100页 | 国产精品国产成人国产三级 | a在线视频观看 | 国产精品久久久久久久久久 | 国产精品伦理一区 | 国产精品日日夜夜 | 国产精品欧美精品日韩精品 | 久久久影院| 精品国产乱码久久久久久丨区2区 | 亚洲综合大片69999 | 欧美成人一区二免费视频软件 | 国产精品1区| 日韩伦理一区二区 | 日韩av成人 | 欧美日韩亚洲系列 | 成人免费小视频 | 亚洲精品9999 | 欧美激情综合色综合啪啪五月 | 国产在线一 | 亚洲一区二区三区四区五区午夜 | 综合亚洲视频 | 在线中文字幕av | 在线观看国产视频 |