1. Trang chủ
  2. » Công Nghệ Thông Tin

Giáo trình Lập trình Web với ASP.NET: Phần 1 - GVC. ThS. Nguyễn Minh Đạo

299 69 1
Tài liệu được quét OCR, nội dung có thể không chính xác

Đang tải... (xem toàn văn)

Tài liệu hạn chế xem trước, để xem đầy đủ mời bạn chọn Tải xuống

THÔNG TIN TÀI LIỆU

Thông tin cơ bản

Định dạng
Số trang 299
Dung lượng 34,3 MB

Nội dung

Giáo trình Lập trình Web với ASP.NET: Phần 1 - GVC. ThS. Nguyễn Minh Đạo cung cấp cho học viên các kiến thức về lập trình ứng dụng Web với công nghệ ASP.NET, tìm hiểu và sử dụng các điều khiển Controls, Master Page - Web Navigation, quản lý trạng thái, sử dụng các Validation Controls, các đối tượng dữ liệu (Rich Controls - Login),... Mời các bạn cùng tham khảo chi tiết nội dung giáo trình!

Trang 2

BQ GIAO DUC VA DAO TAO

TRUONG DAI HQC SU PHAM KY THUAT

THANH PHO HO CHi MINH Xk*ttkÐ a i ak ak i i a i ak ake ake a GVC ThS NGUYEN MINH DAO GIAO TRINH - LẬP TRINH WEB — VỚI ASP.NET

(Giáo trình dùng cho sinh viên ngành Cơng nghệ Thơng tin)

Trang 3

GIAO TRINH

"LẬP TRINH WEB VOI ASP.NET

Nhà xuất bản ĐHQG-HCM và tác giả/đối tác liên kết giữ bản quyên

Sonyeish ™ by VNU-HCM Publishing House and author/co-partnership

All rights reserved

TRUONG DAI HOC SU PHAM KY THUAT TPHCM

Trang 4

LOI NOI DAU

ASP.NET la một nền tảng ứng dung web (web application

##amework) được xây dựng, phát triển bởi tập đồn Microsoft, cho phép các lập trình viên tạo ra những trang web động, những ứng dụng web và

những dịch vụ web Vào tháng 2 năm 2002, phiên bản đầu tiên được đưa

ra thị trường cùng với phiên bản 1.0 của NET framework, ASP.NET là cơng nghệ nối tiếp của cơng nghé Microsoft's Active Server Pages (ASP)

trước đĩ, được biên dịch dưới dạng Common Language Runtime (CLR),

cho phép những người lập trình viết mã ASP.NET với bất kỳ ngơn ngữ

nào (C#, VB.NET, ) được hỗ trợ bởi NET framework

Với xu hướng các ứng dụng web được phát t triển mạnh mẽ, ngày càng cĩ nhiều ú ứng dụng viết bằng ASP.NET, rất nhiều cơng ty đang chọn ASP.NET làm ngơn ngữ phát triển website cho khách hàng cũng như sản phẩm của riêng họ nên việc nắm vững và sử dụng thành thạo về cơng nghệ web nĩi chung và chuyên sâu vê ASP.NET nĩi riêng sẽ là một lợi thế cho các sinh viên và các lập trình viên ứng dụng web

Giáo trình được biên soạn nhằm giới thiệu cơng nghệ lập trình ASP.NET 3.5 chạy trên bộ phần mềm ứng dụng Visual Studio.NET 2008

với phiên bản 3.5 của NET framework N6i dung giáo trình trình bảy các bước từ cơ bản đến chuyên sâu trong việc sử dụng cơng nghệ ASP.NET để xây dựng ứng dụng web Sau khi học xong mơn Lập trình ứng dụng

Web với ASP.NET 3.5, sinh viên sẽ cĩ kiến thức để hiểu và vận dụng

được những kỹ năng trong việc tích hợp các điều khiển và các cơng nghệ

liên quan dé xây dựng các ứng dụng web trong thực tiễn

Giáo trình gồm cĩ 17 chương, bao quát hầu hết các vấn đề cốt lõi

của cơng nghệ lập trình web với ASP.NET 3.5 Phần đầu mỗi chương

đều cĩ tĩm tắt nội dung chương và cuối mỗi chương là phần bài tập dé

sinh viên cĩ thể tự kiểm tra kiến thức của mình Tuy nhiên, giáo trình chắc chắn khơng tránh khỏi những thiếu sĩt Tác giả xin chân thành cám

ơn và mong muốn nhận được những gĩp ý của giảng viên, sinh viên và

những ai quan tâm để giáo trình ngày càng hồn thiện hơn

Mọi ý kiến đĩng gĩp xin vui lịng gửi theo địa chỉ email:

daonm(?fit.hemute.edu.vn

Trang 6

MỤC LỤC LỜI NĨI ĐÀU MỤC LỤC

Chương I Lập trình ứng dụng Web với cơng nghệ ASP.NET 9 1.1 Sự cần thiết phải triển khai ứng dụng Web «ce¿ 9

1.2 Giới thiệu về ASP và ASP.NET .ccccccceceervrrrrree 14

1.3 Web Server IIS «+ v2 th TH 1111211112151 21s c22 21 1.4 Tạo ứng dụng Web với ASP.NET -cccc<cccccScccscrscee 23

1.5 Khao sat giao dién Visual Studio.NET 2008 26

Bài tập chương Ì t1 22 21 HH nàng 11112111011 g1 xe, 30

Chương 2 Tìm hiểu và sử dụng các điều khiển Controls 33

2.1 Cấu trúc một trang ASP.NET

2.2 Biến cố trang ASP.NET

2.3 Giới thiệu ASP.NET Server Controls 58

2.4 HTML Server Controls .ccccceccsssssssssssssssssssessssssacssseseceescacaensss

2.6 Sự kiện PageLoad và thuộc tính IsPostBack . 5s; 115 2.7 Thuộc tính AutoPostBack của một số Web Server Controls 120

100040501 TỶ n6 125 Chương 3 Master Page - Web Navigation -cccccsy

3.1 Master Page cuc H111 611611 111 xe

3.2 Web Navigation s-ctkHn2H22112111011211111 111011111111 cgyy

3.3 Web ser COnIrỌ 5s scst* St 1 1111 1E ExEErerrerkrey

3.4 Đối tượng Request, Response và Server

Trang 7

Chương 4 Quan ly trang thái

4.1 Vấn đề trạng thái các ccticetiiiHrrrrrrde

4.2 Xem trạng thái (View Stat€) cciehhehirererirriee 192

4.3 Chuyển thơng tin giữa các trang .-cccceerrrrrirrrrirerie 195

4.4 Đối tượng Cooki€s -cscccsttrrrtrrrtrrrrrieriiiiriiririe 4,5, DIGi trate Sesstott sscsnsecsssesnascenernsvenenensayversvveervoeseuvenevannsonvnscenns

4.6 Đối tượng Application

4.7 Tập tin GlobaÌ.aSaX cv tha 4,8 Tập tin Web.GOHB 06 0222k ha hán 0 há 208411016 Bài tập chương 4 con 1224 600212 0 11, Chương 5 Sử dụng các Validation Controls §.1 RequiredField Validator sccscvscsvsrsvsrenecssseececeonsertnennteenssenenensnens 5.2 Didu khién RangeValidator cc.ccecsesssesseeceeessessessnsesnessneesesnsense

5.3 Didu khién CompareValidator .cccssecsseeeseeereeseesnessieens

5.4 Điều khiển RegularExpressionValidator ve

5.5 Điều khién Custom Validator .cscssessssssccessesssssssssssssnnsessessees

5.6 Diéu khién ValidationSummary .ccseecseeeeesneeeieesseessiensneess

Bai tap chwong 5 sssscsessesssssssesconssssvescrvcrenvvensservenevansentevenersertenensennunee Chuong 6 Cac déi trong dir ligu (Rich Controls — Login

6.1 Điều khiển hiển thị các trang khác nhau MultiView

6.2 Điểu khiển WiZard 1121112111110 de

6.3 Nhĩm Điều khiển Login - ccc2svcrtiieeeriiieriirirre

Bãi tận chươn Ổ tueesssesesesnasannssideintiaiirtiastsellkxasvinioli 0900003671008

Chương 7 Giới thiệu ADO.NET -cstiieiiree 299

7.1 Kiến trúc ADO.NET - -5s- 52221 111811111,1121121162 299

7.2 Tìm hiểu trình cung cấp dữ liệu của ADO.NET 301

Trang 8

7.4 Tìm hiểu cơ chế kết nối của ADO.NET qua Connected Layer 309 7.5 Disconnected Layer cccssessessssseecsseseesesessesesessseessessesessscenes 343 7.6 Đối tượng dữ liệu SqlIDataSOUr€e cu sievsiceseree 356 Baltap chrome: 7 Hưng gang nhi224038L86E00SBESESRHSSHSSI8051104616ee 364

Chương 8 Tìm hiểu và ứng dụng cơ chế Data Binding 369

8.1 Giới thiệu Data Binding co t1 369

82 Cáo dạng 12ata BÌnHÌTE esndeessat1g11116180.001146150013 400265 nang 370 Bài tập chương 8 các LH H42 111211 gi, 377 Chương 9 Các đối tuong dir ligu (Data Controls)

9.1 Đối tượng dữ liệu GridView - series

9.2 Đối tượng dữ liệu DetailsView ccccccccererrrreeeeerree

9.3 Đối tượng đữ liệu FormVieww -:scccckrveertkerrrkeerrvee

9.4 Đối tượng đữ liệu DataList c2 2cosvscecccveerrrrrereee 9.5 Đối tượng đữ liệu Repeater -cccccccccvrtecerrrreecrrrrkrcee 423

Bài Tập chương Ơ sen nuengBesngigDEG1808801400150040008331893546414010/0888 426

Chương 10 Bảo mật các ứng dụng Web 10.1 Giới Thiệu về Bảo Mật Trong:ASP.NETE seeeseoeeeeserenseo 431 § ng i60 433 Chirong 11 Gi6i thigu AJAX 00 cesetecseneeneetaeneeseeesenaees 439 loi) 1 439 11.2 Ajax làm việc như thế nào? 440 11.3 ASP.NET Ajax & ASP.NET call back 449

11.4 ASP.NET Ajax Server CornIroÌS - - 5 5 ccccccccrerree 450 11.5 Giới thiệu Ajax ControlToolkit . .c-c<xcs<cs2 454

11.6 Tìm hiểu một số diéu khién trong Ajax Control Toolkit 3.5 459

Trang 9

Chuong 12 Lap trimh LINQ w scsscsssssssscsosssscssosessssssssessseecessssesne 541

VDL GiGi thigts LING, scccssrvennencssarescsisurwevcenessussnenseenceneienveveematers 541

12.2 Các khái niệm cơ bản HH He, 344 12.3 LINQ to Objects 549

12.4 LINQ to DataSet nen rên 550 12,5 LING to SQL, seeseeeeensi114/606001515010 36512186 553 Chương 13 Lập trình Web Services no 561 13.1 Giới thiệu Web serViC€s HH, 561 13.2 Kiến trúc và các thành phần Web services 13.3 Xây dựng ứng dụng Web SerVice

Chương 14 Xây dựng Website bán hàng 575

14.1: Thương mại đIỆN LỄ ben tiiA8411551100141810406133639431200868 575 14.2 Khảo sát hiện trạng c2, 580

I6h‹ca n 4AdA 586

Chương 15 Thiết kế Website bán hàng — Mức dữ liệu 587

Chương 16 Thiết kế Website bán hang — Mức xử lý 607

Chương 17 Thiết kế Website bán hàng - Mức trình diễn 633

Trang 10

Chương |

LAP TRINH UNG DUNG WEB VỚI ASP.NET Kết thúc chương này các bạn cĩ thể:

> Nắm vững khái niệm ứng dụng Web

> Hiểu rõ về các khái niệm cơ bản về Web, về mơ hình kiến trúc Client-Server 2 lép (two tier) va 3 lớp (three tier)

> Nhận biết các ngơn ngữ lập trình ứng dung Web: HTML,

DHTML, VBScript, JavaScript

> Cai dat duoc Web Server IIS trên máy chạy hệ điều hành Windows > Trình bày được các đặc điểm của ASP và ASP.NET

> Sử dụng được Visual Studio.Net 2008 để tao ứng dụng Web

1.1 SỰ CÀN THIET PHAI TRIEN KHAI UNG DUNG WEB

Với sự phát triển nhanh chĩng và mạnh mẽ của ngành cơng nghệ thơng tin, đặc biệt là sự phát triển các hệ thống mạng intranet, internet,

trong các lĩnh vực như: thương mại, y tế, giáo dục, nhu cầu trao đổi

thơng tin thực sự là rất cần thiết, giúp cho cơng việc được triển khai dễ

dàng, chính xác, với tốc độ nhanh và tiết kiệm chỉ phí, thơng tin được cập

nhật kịp thời Từ đĩ vấn đề đặt ra ở đây là chúng ta cần phải cĩ một ứng dụng cho phép trao đổi thơng tin mọi lúc, mọi nơi, dễ sử dụng, thơng

qua mơi trường mạng

Ứng dụng Web đáp ứng được các yêu cầu đặt ra với các lý do sau:

v Dễ dàng trao đổi và chia sẽ thơng tin qua mạng

v Sử dụng giao diện đồ họa giúp cho người dùng dễ sử dụng

v Hỗ trợ về multimedia như: hình ảnh, âm thanh, phim ảnh,

Trang 11

> Web client (Browser)

Các máy khách (Client) sẽ sử dụng chương trình để triệu gọi đến các trang web gọi là trình duyệt web hay Web browser Hiện nay,

cĩ rất nhiều trình duyệt web thơng dụng như: Internet Explorer,

Mozila FireFox, Google Chrome, Opera

> Web server

Các máy chủ (Server) chứa các ứng dụng Web, sẵn sàng truy xuất các trang web hay các tài liệu và gửi về cho client khi nhận được yêu cầu từ phía client Hiện nay cĩ rât nhiêu Web server và chạy

trên nhiêu hệ thơng như: Apache, Microsoft, Sun,

> Giao thức HTTP

Quá trình giao tiếp giữa client và server được thực hiện thơng qua giao thức chuân HTTP (HyperText Transfer Protocol) Hình minh họa sau mơ tả việc truy cập ứng dụng Web We c¡ami ĐỀ; — “20000700 (Brower) “m đa = RT pe | Ss Client2 “HN: <a ⁄ (Browser) ais

Hình 1.1: Minh họa truy cập ứng dụng Web

"_ Ứng dụng Web được xây dựng theo mơ hình Khách-Chủ (Clien- Server)

"_ Quá tình giao tiếp giữa client va server được thực hiện thơng qua giao thức chuẩn của Web là HTTP (HyperText Transfer Protocol) " M6 hinh Client-Server la mé hinh Three Tier gdm ba thanh phdn

chinh la: may khach (client tier), may phuc vu (Web server tier) va may chu dit liéu (data server tier) May phuc vu (Web server tier) Sẽ chứa các ứng dụng Web và các ting dung Web nay sé duoc quản lý tập trung boi trinh quan ly goi la Web Server (IS, Tomcat, JBoss, WebLogic, .) Các máy khách (client tier) truy cdp dén img dung web sit dung trinh duyét web (Web browser) Hinh 1.1 trén

minh hoa mét kiến trúc ứng dung Web voi cong nghé cua

Microsoft voi Webserver ld IIS, va tang mdy chi dữ liệu thường là

cơ sở đữ liệu MS Access hoặc MS SQL Server

Trang 12

" Client sử dụng giao thức HTTP Request dé giti yêu cầu (trang web) lên Server, Server xử ly va str dung giao thie HTTP

Response dé giti két qua vé cho Client

> Ngơn ngữ đánh dấu siêu văn bản HTML (HyperText Transfer Markup Language)

" Ngơn ngữ chuẩn được sử dụng để thiết kế một trang Web HTML cho phép người viết cĩ thể phân chia và trình bày thơng

tin trên một trang tin HTML đơn giản, dễ học HTML đơn giản

là tập tin cĩ phần mở rộng htm (hay html), sử dụng các thẻ

(tag): kiểu văn bản, danh sách, các siêu liên kết (hyperlinks), Chúng ta cĩ thể dùng các phần mềm thiết kế web nhữ: FrontPage, DreamWeaver, dé thiết kế các trang HTML " Ngơn ngữ đánh dấu HTML sử dụng các thẻ ký hiệu quy định

săn (được gọi là tag) đê trình bày nội dung văn bản

Nội dung + Địnhdạng = Kết quả hiển thị <Html> <Head> </Head> Trang chủ Windows Server System Microsoft </Html>

Trang 13

> Client Scripting va Server Scripting

Các ngơn ngữ dùng để viết mã lệnh cho trang web Một trang web

được xử lý ở server và trả kết quả về cho client Do đĩ, các ngơn ngữ viết mã cho trang web được chia thành hai dạng:

“ ClientScript: được xử lý tại trình duyệt (Web browser) trên máy client Các ngơn ngữ thường dùng để viết là: VBScript,

JavaScript, DHTML,

o JavaScript là ngơn ngữ phổ biến sử dụng nhiều nhất hiện nay JavaScript được dùng để thực hiện một số tác vụ như kiểm tra thơng tin nhập vào, kiểm tra trình duyệt,

o DTHML: là sự kết hợp của HTML, Style Sheet (CSS) va

JavaScript nhằm làm cho trang web dễ tương tác, điều khiển

và giảm bớt việc xử lý phía Server

o VBSecript là ngơn ngữ script của Microsoft Chức năng của VBScript cũng giỗng như JavaScript

o Sau này cĩ thêm thư viện JavaScript là JQuery rất mạnh được

thiết kế để đơn giản hĩa lập trình phía máy client

" S€TVer Scripting: được xử lý tại Web server trên máy Server Các ngơn ngữ dùng để viết là: ASP, ASP NET, PHP, JSP

Trong chương này, chúng ta sé tìm hiểu ngơn ngữ ASP và ASP.NET > Các mơ hình ứng dụng " M6 hinh ứng dụng hai tầng Client Tier Server Tier

Application Clients Database Server

Hình 1.3: Mơ hình hai tầng (Two Tier)

Đây là một dạng mơ hình đơn giản, khá phổ biến của một ứng dụng

phân tán Trong mơ hình này, việc xử lý dữ liệu được thực hiện trên máy

chủ dữ liệu Database Server, việc nhận và hiện thị dữ liệu được thực hiện ở Client Mơ hình này dùng cho ứng dụng lập trình trên Windows

Trang 14

> Uu diém

Dữ liệu tập trung > đảm bảo dữ liệu được nhất quán

v Dữ liệu được chia sẻ cho nhiều người dùng

> Nhược điểm

v Các xử lý tra cứu và cập nhật dữ liệu được thực hiện ở Database Server, việc nhận kết quả và hiển thị phải được thực hiện ở Client -> Khĩ khăn trong vấn đề bảo trì và nâng cấp

v Khối lượng dữ liệu truyền trên mạng lớn -> chiếm dụng đường truyền, thêm gánh nặng cho Database Server

" M6 hinh tng dung ba tang

Mơ hình hai lớp phần nào đáp ứng được các yêu cầu khắt khe của một ứng dụng phân tán Tuy nhiên, khi khối lượng đữ liệu lớn, ứng dụng địi hỏi nhiều xử lý phức tạp, số người dùng tăng,

mơ hình hai tầng khơng thể đáp ứng được

Mơ hình ba lớp sử dụng thêm WebServer hay cịn gọi là

Applicaton Server giữ nhiệm vụ tương tác giữa Client và Database server, giảm bớt các xử lý trên Database server, tập

trung các xử lý nhận và hiển thị dữ liệu tại Application server

Client Tier Server Tier Data Tier

Request Process

we " Response ụ Fetch

Web Browser/ Database

GUI Window Hes Geer Server

Hinh 1.4: M6 hinh ba tang (Three Tier)

> Ưu điểm

v Hỗ trợ nhiều người đùng

Giảm bớt xử lý cho Client -> Khơng yêu cầu máy tính ở Client

cĩ câu hình mạnh

v Xử lý nhận và hiển thị dữ liệu tập trung tại Application Server > dé quan ly, bao tri và nâng cấp

` * Xử lý truy cap dit ligu tap trung tai Database Server

Trang 15

> Nhược điểm

v⁄ Phải sử dụng thêm một Application Server > tang chi phi

1.2 GIOI THIEU VE ASP & ASP.NET

1.2.1, Giới Thiệu về ASP

Cơng nghệ Active Server Page (ASP) do Microsoft phát triển là

mơi trường lập trình về phía server (server side programming), hé tro

mạnh trong việc xây dựng các ứng dụng thương mại điện tử (các trang Web Ecommerce) Các ứng dụng ASP rất dé viết và dễ sửa đổi, đồng

thời tích hợp các cơng nghệ sẵn cĩ của Microsoft như: COM, DCOM

Từ khoảng cuối thập niên 90, ASP (Active Server Page) đã được nhiều lập trình viên lựa chọn để xây dựng và phát triển ứng dụng web

động trên máy chủ sử dụng hệ điều hành Windows ASP đã thé hiện được những ưu điểm của mình với mơ hình lập trình thủ tục đơn giản, sử dụng hiệu quả các đối trợng COM: ADO (Activex Data Object) - xi ly dit

ligu, FSO (File System Object) - làm việc với hệ thống tập tỉn, ., đồng thời, ASP cũng hỗ trợ nhiều ngơn ngữ: VBScript, JavaScript Chính

những ưu điểm đĩ, ASP đã được yêu thích trong một thời gian dài

Một ứng dụng ASP được triển khai trên Web Server là IIS (Internet

Information Service) cé sin trong mơi trường Windows Để cĩ thể triển

khai ứng dụng ASP trên các mơi trường khác ta phải cài đặt các thư viện hỗ trợ ASP

> Đặc điểm của trang ASP

" ASP là một tập tin văn bản (text file) cĩ phần mở rộng aSp Phần mở rộng này sẽ giúp Web server yêu cầu trình xử lý trang ASP (ASP engine) trước khi trả về cho trình duyệt

" Ngơn ngữ script thơng dụng nhất để viết mã của ASP là VBScript Ngồi ra, ta cũng cĩ thể viết mã bằng các ngơn ngữ khác như: JavaScript, Perl, Python, nếu trên Web server cĩ cài đặt các bộ xử lý ngơn ngữ này

" Các đoạn mã viết trong trang ASP sẽ được các bộ xử lý ngơn

ngữ trên Web server xử lý tuần tự từ trên xuống dưới Kết quả

của việc xử lý này là trả về trang mã HTML cho web server va web server sẽ gửi trang HTML này về cho trình duyệt (Browser) Do đĩ, tại trình duyệt khơng thể thấy được, các đoạn mã chương trình đã viết trong trang ASP

Trang 16

" Mot trang ASP gdm bén phan:

Y Dit liéu van ban (text)

Y Cac thé (tag) HTML

vé Các đoạn mã chương trình phía client đặt trong cặp thẻ

<SCRIPT> va </SCRIPT>

v Mã chương trình ASP được đặt trong cặp thẻ <% và %>

Ba thành phần đầu tiên là cấu trúc của một trang HTML thơng thường, do đĩ, cĩ thê xem một trang ASP là một trang HTML được

Trang 17

> Uu diém

v⁄ Trang ASP được diễn dịch một cách tự động

v⁄ Xây dựng ứng dung Web động v Xử lý dữ liệu động hiệu quả

> Nhược điểm

v Chỉ sử dụng hai ngơn ngữ kịch bản tp dinh kiéu (non-type):

VBScript va JavaScript,

v Sử dụng trình thơng dịch cho các trang ASP

Các đoạn mã lệnh và giao diện (HTML) trộn lẫn với nhau

vˆ Khơng sử dung lai được (reuse) các đoạn mã + Khơng hỗ trợ cơ chế bẫy lỗi (Debug)

1.2.2 Giới thiệu về ASP.NET

Như chúng ta đã biết, ASP vẫn cịn tồn đọng một số khĩ khăn như mã lệnh ASP và HTML lẫn lộn, điều nay làm cho quá trình viết mã khĩ khăn, thể hiện và trình bày mã khơng trong sáng, hạn chế khả năng sử dụng lại mã Bên cạnh đĩ, khi triển khai cài đặt, đo khơng được biên dich

trước nên đễ bị mắt mã nguồn (source code) Thêm vào đĩ, ASP khơng

cĩ hỗ trợ cache, khơng được biên dịch trước nên riêng nào hạn chê về

mặt tốc độ thực hiện Quá trình xử lý Postback khĩ khăn,

Đầu năm 2002, Microsoft giới thiệu một kỹ thuật lập trình Web khá mới mẻ với tên gọi ban đầu là ASP+, tên chính thức sau này là

ASP.NET Với ASP.NET, khơng những khơng cần địi hỏi bạn phải biết các tag HTML, thiết kế web, mà nĩ cịn hỗ trợ mạnh lập trình hướng đối tượng trong quá trình xây dựng và phát triển ứng dụng Web

ASP.NET là kỹ thuật lập trình và phát triển ứng dụng web ở phía Server (Server-side programming) dựa trên nền tang cia Microsoft.NET Framework

Hau hét, những người mới đến với lập trình web đều bắt đầu tim hiểu những kỹ thuật ở phía Client (Client-side) như: HTML, Java Script, CSS (Cascading Style Sheets) Khi Web browser yêu cầu một trang web (trang web sử dụng kỹ thuật Client-side), Web server tim trang web ma

Client yéu cầu, sau đĩ gửi về cho Client Client nhận kết quả trả về từ

Server và hiển thị lên màn hình

ASP.NET sử dụng kỹ thuật lập trình ở phía server thì hồn tồn khác, mã lệnh ở phía server (ví dụ: mã lệnh trong trang ASP) sẽ được

Trang 18

biên dịch và thi hành tại Web Server Sau khi được Server đọc, biên dịch

va thi hành, két qua tự động được chuyên sang HTML/JavaScripUCSS và

trả về cho Client Tất cả các xử lý lệnh ASP.NET đều được thực hiện tại

Server, va do đĩ, gọi là kỹ thuật lập trình ở phía server

ASP.NET duoc Microsoft phdt triển qua nhiều phiên bản từ ASP.NET 1.0, 1.1, 2.0 va gan đây nhất là phiên bản ASP.NET 3.5 chạy trên NET Framework 3.5 sử dụng mơi trường phát triển tích hợp (IDE) Visual Studio.Net 2008 Trong gido trinh nay, ching ta st dung ASP.NET 3.5

Tai sao phai sw dung ASP.NET ?

Yéu cau về xây dựng các ứng dụng thương mại điện tử ngày càng được phát triển và nâng cao Khi đĩ, ASP khơng cịn đáp ứng được yêu cầu đặt ra ASP được thiết kế riêng biệt và nằm ở tầng phía trên hệ điều

hành Windows và Internet Information Service, do đĩ các cơng dụng của

nĩ hết sức rời rạc và giới hạn ASP.NET đưa ra một phương pháp phát

triển hồn tồn mới khác hẳn so với ASP trước kia và đáp ứng được các

yêu cầu đặt ra Hình 1.6 minh họa các thành phần bén trong ASP.NET 3.5

—————NRNET35—————————

k i „NET Framework 3.0 Classes Common Language Runtime 2.0 ; «WPF, WCF, ond wi

C# 3.0 and VB 9.0

ASP NET 2.0 Engine Language Gompilery

.NET Framework 2,0 Classes NET nữ 35

(Core Framework) (LING, ASP.NET AJAX)

L J

Hình 1.6: Các thành phân của ASP.NET 3.5

»> Các ưu điểm của ASP.NET

" ASP chỉ sử dụng VBScript và JavaScript mà khơng sử dụng được các ngơn ngữ mạnh khác: Visual Basic, C++ Trong khi

do, ASP ‘NET TINH TP -RKŠ THUA VBScript,

JavaScript, C#, {gual Basi ý tài an gs SAE

H aa

Trang 19

18

ASP.NET sur dung phong cách lập trình mới: Code behide song

song voi dang Code inline Tach mã riêng, giao diện riêng Dễ

doc, dé quản lý và bảo trì

Trong các trang ASP, chúng ta phải viết mã để kiểm tra đữ liệu nhập từ người dùng, ASP.NET hỗ trợ các validation controls để kiểm tra ching ta khơng cần viết mã,

Hỗ trợ phát triển Web được truy cập trên các thiết bi di động:

PocketPC, Smartphone,

Hỗ trợ nhiều điều khiển phía máy chủ (web server controls) Hỗ trợ thiết kế và xây dựng MasterPage lồng nhau

Hỗ trợ bẫy lỗi (debug) với JavaScript

Cho phép người dùng thiết lập giao diện trang Web theo sở

thích cá nhân sử dụng Theme, Profile, WebPart,

Tăng cường các tính năng bảo mật (security)

Hỗ trợ kỹ thuật truy cập dữ liệu mới LINQ

Hỗ trợ kỹ thuật xây dụng các ứng dụng đa phương tiện SilverLight

Hỗ trợ kỹ thuật bất déng b6 ASP.NET Ajax

ASP.NET hỗ trợ mạnh mẽ bộ thư viện phong phú và đa dạng của NET Framework, làm việc với XML, Web Service, truy

cập cơ sở dữ liệu qua ADO.NET,

ASPX và ASP cĩ thể cùng hoạt động trong một ứng dụng

Kiến trúc lập trình giống ứng dụng trên Windows Hỗ trợ quản lý trạng thai cua cdc control

Tự động phát sinh mã HTML cho các Server control tương ứng với từng loại Browser

Hỗ trợ nhiều cơ chế Cache

Triển khai cài đặt: khơng can lock, khơng cần đăng ký DLL, cho phép nhiều hình thức cấu hình ứng dụng

Hỗ trợ quản lý ứng dụng ở mức tồn cục: Global.aspx cĩ nhiều sự kiện hơn, quản lý session trên nhiều Server, khéng can Cookies

Trang 20

ASP.NET ASPX — R: 3 — 4————————— Response —————- Hil Page

Hinh 1.7: Minh hoa qua trinh bién dich trang ASP.NET Thi du 1.3: Minh hoa trang ASP.NET hién thi ngày hiện hành <%@ Page Language="C#" AutoEvenEWireup="Erue" CodeBeni Inherits="Sample Default" %> d= "Default aspx.cs" <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http: //www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> "http: //www.w3.org/1999/xhtml" > "server"> <title>ASP.Net 3.5</title> </head> <body> <form id="forml" runat="server"> <div>

<asp:Label ID="lbMsg" runat="server"

="Ngày hiện hành: "></asp:Label> </div> </form> </body> </html> Hình 1.8: Nội dung trang Default.aspx using System; using System.Collections; using System.Configuration; using System.Data; using System Linq; using System.Web; using System.Web Security; using System.Web.UI;

using System.Web.UI HtmlControls; s

Trang 21

==" Se OO - le! http:/flocalhost:49576/Default.aspx ~|4| x |[uive Search & 1 We |@ASPNet35 Ngày hiện hành : 01/02/2009 £ ASP.Net 3.5 - Windows Internet Explorer L] my + di» Ey Page ~ G Tools v si [a @ Internet | Protected Mode: Off ®100% ~

Hinh 1.10: Két qua trang Default.aspx

> Quá trình xử lý tập tin ASPX

Khi Web Server nhận được yêu cầu từ phía client, nĩ sẽ tìm kiếm

Trang 22

1.3 WEB SERVER ITS

Trong phần này, chúng ta khảo sát vé IIS (phan mém Web Server

của Microsot dành cho Windows), đồng thời hướng dẫn bạn cài đặt, cầu

hình và kiểm tra Web Server trên các hệ thống sử dụng Windows 2000, Windows XP, Windows Server 2003, Windows Vista,

> Internet Information Services

IS cĩ thể được sử dụng như một Web server, két hợp voi ASP dé

xây dựng các ứng dụng Web tận dụng các điêm mạnh của Server- side Script, COM component, theo mơ hình ClienVServer

IIS cĩ rất nhiều phiên bản, đầu tiên được phát hành rời trong bản

Service pack của WinNT

" Các phiên bản Windows 2000 đã cĩ tích hợp IS 5.0 = Windows XP tich hop IIS 5.5

= Windows Vista tich hgp IIS 6

> Cai dat Web Server

Các bước cài đặt Web Server trén Windows XP Professional Windows XP tích hợp sẵn IIS nhưng khơng tự động cài đặt Do đĩ,

bạn phải tự cài HS theo các bước sau:

Bước 1 Chọn Control Panel | Add/Remove programs Bước 2 Add/Remove Windows Components

‘Windows Components ni een Wizard

‘You can add or remove components of Windows XP

To add or remove a component, click the checkbox A shaded box means that only

palt of the component will be installed To see what's included in a component, click Details Components: 0 P Indexing Service 00MB iA] Internet Explorer 0.0 MB

4 *§ Internet Information Services [IlS) 135MB O 29 Management and Monitoring Tools 2.0 MB

FA Bat Messane Ouening nnwn \™:|

Description: Includes Web and FTP support, along with support for FrontPage, transactions, Active Server Pages, and database connections Total disk space required: 54.2 MB

Space available on disk: 6685.7 MB

Hinh 1,12; Cai dat IS từ đĩa Windows XP

Trang 23

22

Bước 3 Đánh đấu vao muc Internet Information Services (15) Bước 4 Chọn nút Details để chọn các mục chỉ tiết

Bước 5 Chọn các mục cần cài đặt Trong đĩ, bạn nhớ chọn: FrontPage 2000 Server Extensions va Internet Information Services Snap-In

Bước 6 Nhấp nút Next (cĩ thể Windows yêu cầu đĩa CD Windows XP) dé cai dat hoan tat

Bước 7 Dé xác định việc cài thành cơng Web Server, ta cĩ thể

kiêm tra như sau:

Mở trình duyệt (Browser): Microsoft Internet Explorer và gõ http:/1ocalhost/localstart.asp vào hộp địa chỉ và sau đĩ nhấn Enter

thì trang localstart.asp mặc định sẽ xuất hiện như sau A Welcome fe dows XP Server Internet Services - Mi EETEI] Elle Edit View Favorites ‘Tools Help ay a S : »

G35 GD fe) EY BD search ofyravorims €3 3y QB w -

Address | @] http://localhost/lecalstart.asp JMAE]eo Links * Microsoft Windows?" - Professional Your Web service is now running

You do not currently have a default Web page established for your users Any users attempting to connect to your Web site from another machine are currently receiving an Under Construction page Your Web server lists the

following files as possible default Web pages:

default.htm,default.asp,index.htm,iisstart.asp,default.aspx Currently, only lisstart.asp exists

To add documents to your default Web site, save files In

c:\inetpub\wwwroot\,

Welcome to IIS 5.1 Inte Jei

Internet Information Services (IIS) 5.1 WF Intearated Management h ‘You can manage ITS through the

for Microsoft Windows XP Professional Windows XP Computer Management

brings the power of Web computing to 1 by usin ‘cripti Using the

windows With IIS, you can easily share ee ee ey carte har onthe tr

files and printers, or you can create console, you can also share the contents

wpplications to securely nUBIIER of your sites and servers that are

: _ managed with Internet Information

information an the Web to improve the Services to other poople vie the web

information 11S is a secure platform for BF See ees,

@) Done 9 Local intranet

Hình 1.13: Minh hoa cai dat IS thanh céng

% Localhost là địa chỉ của máy cục bộ mà bạn đang làm việc Nếu máy của bạn đang kết nối vào mạng LAN và cĩ một địa chỉ IP, bạn

cĩ thê dùng địa chỉ này thay cho localhost

Để xác định địa chỉ IP của máy mình:

" Vào menu Start[Run và gõ lệnh: coznand hoặc cmđ

Trang 24

= Khi g6 //localhost, ban sé thay trong thanh dia chi tu động đổi thành: http://localhost HTTP là giao thức mặc định được dùng

trên Internet Vì HTTP là một giao thức thuộc bộ TCP/IP, bạn

cần cĩ địa chỉ IP để các máy tính khác trong mạng cĩ thể truy

cập được đến trang web của bạn

" Sau khi cài đặt Web Server, mặc định trên & đĩa C:\ sẽ cĩ sẵn

thư mục C:\inetpub\wwwroot Đây là thư mục ma Web Server

mặc định ánh xạ vào //Iocalhost, do đĩ, các trang web đặt trong

wwwroot cĩ thể được truy cập bởi các máy tính khác

1.4 TẠO MỚI ỨNG DỤNG WEB VỚI ASP.NET

Chúng ta sẽ bắt đầu bằng việc làm quen với mơi trường phát triển ứng dụng (IDE) của Visual Studio.NET VS.NET 2008 cĩ nhiều thay đổi

so với các biên bản trước

Hình dưới là màn hình khởi đầu của VS.NET 2008 Vùng làm việc

chính giữa đang hiển thị trang Start Page, Recent Projects, Visual Studio Developer News

Visual Studio Developer News cần một kết nối với Internet để download các thơng tin từ website của Microsoft về máy tính của chúng ta Recent Projects liệt kê các project mà chúng ta đã làm việc trong thời gian gần đây Trên mục này, chúng ta cũng cĩ thể tạo mới một

project bằng cách nhắn vào nút New Project

{ew Start Page - Microsoft Visual Studio (Administrator) (S18 ata) ic Edit Yiew Tools Test Window Help lỆ £# ad đ |» +3 3|? che 2y ¡0 + —— vl' vas 2 BN @ How Dor = Q Search 3 Index J Contents [Help Favontes | ƒ 47 s

Trang 25

1.4.1 Tao img dung ASP.NET dau tién

Chúng ta cĩ thé tao img dung ASP.NET sit dung Visual C# Project

theo các bước sau:

Bước I Chọn từ thực đơn File | New | WebSite Xuất hiện hộp

thoại tạo mới Project (hình 1.15)

= Chon loai Language la Visual C#

" Chon ASP.NET Web Site tir ving Templates

" Ứng dụng mới được tạo mặc định cĩ tên là WebSiteXX (XX là sơ thứ tự tự động) Chúng ta cĩ thể thay đơi tên của Project tại muc Location Trong ví dụ này, chúng ta thay đổi tên Project 'WebSite1l thành MinhHoa

* Tại mục Location:

Nếu ta chọn giá trị là File System thi ứng dụng sẽ được tạo ra trong

thư mục theo đường dẫn mà ta chỉ định ví du:

D:\DotNet2008\WebSitel, khi ta chay img dung thì VS.Net sẽ tao ra

một Web Server ảo và sử dụng Web server này đề thực thi ứng dụng +ituisdl nh “ : — Thị Templates: [Net Frameworks} (3) Visual Studio installed templates

GB Ase.NeT web Site @, ASP.NET Web Service @ Empty Web Site

ESSwer service JASP.NET Reports Web Site PAASP.NET Crystal Reports Web Site đMy Templates — - = =

LÍ [Search Online Templates

A blank ASP.NET Web site (NET Framework 3.5)

Trang 26

Nếu như ta chọn giá trị là HTTP, ta gõ vào đường dẫn:

http://localhost/WebSite1 thì ứng dụng sẽ được tạo ra trong thư mục mặc

định là C:\Wnetpub\wwwroot với tên là WebSitel, khi ta chạy ứng dụng thì VS.NET sẽ sử dụng Web server là [IS mà ta đã cài đặt trên máy

1.4.2 Thiết kế giao diện thực thi và ứng dụng

Trên hộp cơng cụ (Toolbox), nếu chưa cĩ hộp cơng cụ chọn View/ToolBox, mở thẻ Standard (chứa các Web server control) click vào lần lượt hai điều khiển dạng nhãn (Label control) va dan vào trang Default.aspx Nhập nội dung thuộc tính Text cho hai điều khiển đạng nhãn theo bảng 1.1 Bảng 1.1

Tên điều khiển Thuộc tính Text

IblChao Chào bạn đến với lập trình ASP.NET 3.5 IbIThoiGian [Chuỗi rỗng] WP MinhHoa - Micr 334 Tools Test Window Help y Any CPU tide Objects & Events <br /> <asp:Label ID="Label2" runat="server" Text="Label"> </asp:Label> _ (No Events) : - 7 - 7 eS wei </div> Ll </form> phan ma HTML </body> i </html> a ere TE eae gc , Chào mừng bạn đến với lập trink AP.Net 3.5 Label im À tA

|| 3 Design [mm ]a soưe | [Q[<himb][<body» [<fermwerml»|[<ews|[<aspta phân giao diện [2 Error List| Output]

Ready tn 21 Colt Chit

Hinh 1.16: Man hinh thiét ké trang Default.aspx

25

Trang 27

Để viết lệnh cho trang Default.aspx các bạn vào menu View | Code

hay nhấn phím F7, màn hình viết lệnh xuất hiện như hình 4.10 và viết lệnh cho sự kiện Page_Load: namespace MinhHoa { public partial class Default: System Web.UI.Page { protected void Page Load(object sender, EventArgs e) { IbIThoiGian Text = "Ngày giờ hiện hành" + DateTime.Now.ToString("dd/MM/yyyy hh:mm:ss");

Thực hiện việc gán nội dung cho thuộc tính Text của điều khiển

nhãn IblThoiGian như trong hình Nhấn F5 hoặc Ctrl + F5 để thi hành

ứng dụng Ứng dụng sẽ được biên dịch (compiler) để kiểm tra lỗi và hiện nội dung ra trình duyệt mặc định trên máy Kết quả như hình 1.17

@ ASP.Net & WebForm - Windows Internet Explorer (ao) 2 shies

vị

we | @ ASP.Net & WebForm

Chào mừng bạn đến với lập trình AP.Net 3.5

Ngày giờ hiện hành :06/02/2009 10:41:56

@ © ms |e' http://localhost:51592/Default.as 74] x] | tive Search | 8y 8x 8+iEgev ƯTesosx ^ Done (ei) @ Internet | Protected Mode: Off 100% v

Hinh 1.17: Man hinh két qué hién thi trang Default.aspx

1.5 KHAO SAT GIAO DIEN VISUAL STUDIO.NET 2008 > Solution Explorer

Hiển thị cửa số Solution Explorer: Menu View | Solution Explorer

Trang 28

Retard + @ MinhHoa ai Properties References Lữ App_Data @- (3) Defaultaspx i [3 Web,config

Hinh 1.18: Cia sé Solution Explorer

Đây là cửa số quản lý các “tài nguyên” cĩ trong ứng dụng Thơng

qua cửa số này, chúng ta cĩ thê:

" Thực hiện các chức năng: sao chép, cắt, dán trên tập tin, thu mục như Windows Explorer

Tổ chức thư mục quản lý ứng dụng: Sử dụng chức năng Add | New Folder từ thực đơn ngữ cảnh

Thêm thành phần mới cho ứng dụng: Sử dụng chức năng Add | Add New Item, từ thực đơn ngữ cảnh Xuất hiện hộp thoại Add New Item, hình 1.19

o Web Form: Thém trang Web

o Class: Thêm lớp đối tượng

o Web User Control: Thém điều khiển người dùng, Add New ltem ~ MìnhHoa | Categories: Templates:

Visual || Visual Studio installed templates + Code 48] web Form [Master page | Dats {| Web User Control EJ] web Content Form |

General S2)UAX Client Behavior $3) Wax client Control

i |] &LUAX Client Library (lJ avax Master page

Windows Forms is ae E| wor || ES] ANax Web Form ERG asax-enabled WCF Service 1

LIÊN | (2) pplication Manifest File Assembly Information File ya

Women SD} Browser File Hy class

| 3 Class Diagram t#Ì code File Ễ

jdglOataset EA Debugger Visualizer

{8) Generic Handler 44) Global Application class (4) HTML Page eB) installer Class scp Interface g]sseipt File |] <2 uN to Sat Classes [Nested Master Page

ị Ba Report ae] Report Wizard = = stress xIỀNHmehemsaeogdt 2iƯT| ni tinh sreree ol

A form for Web Applications

Name: WebFormi.aspx

Hình 1.19: Màn hình thêm mới liem

Trang 29

"Xác định trang web khởi động cho ứng dụng trong trường hợp

chúng ta cĩ nhiêu trang web

o Chon trang cần khởi động -> Nhấp chuột phải (xuất hiện thực

đơn ngữ cảnh) -> Chọn Set As Start Page

o Xác định Project khởi động (trong trường hợp Solution cĩ nhiều Project): Chọn Solution và từ (thực đơn) menu ngữ [2 Solution ‘MinhHoa’ (1 project) &- @ MinhHoa l- lã Properties isd References Củ App_Data HH liy & Web.con| Open Ha ta = © | Open With View Cade View Designer View Markup

View Component Designer

View Code Gen File View in Browser Browse With Sets Start Page Check Accessibility Exclude From Project Hình 1.20: Chọn trang thực thì đâu tiên trong ứng dụng > Property Window o Hiển thị cửa số Properties Window: Thực đơn View | Properties Window

© Thơng qua cửa số thuộc tính, chúng ta cĩ thể thiết lập thuộc

tính cho trang web và các đối tượng cĩ trong trang web Hình 1.20

> Toolbox

© Hién thi Toolbox: Thực don View | Toolbox

Trang 30

Properties © ft hess ce 1y (TH IbIThoiGian System.Web.ULWebControls » EÌHIIEIUEEI | (Expressions) (0) AccessKey AssociatedConti BackColor BorderColor BorderStyle BorderWidth CssClass Enabled EnableTheming True | EnableViewState True |EI Font | ForeColor Height SknID | Tablndex 0 CEE tab ToolTip Visible Width IbiThoiGian NotSet True True OOIDOX es aa enw We TRE § ea Standard Gf Standard tH Validation 3 Label is»! TextBox Navigation Bul'on Login WebParts AJAX Extensions Reporting LÍ nmwt h Pointer © Input (Button) @ Input (Submit)

fil Input (Text) | Input (Reset)

Trang 31

BAI TAP CHUONG 1

Bài 1: Tạo ứng dụng cho phép người dùng lựa chọn màu ưa thích trên

trang ASP.NET như sau: Đạn thích những màu nào? L] Đá LÌ Xanh dương LÌ Xanh lục | Bạn thích màu: đỏ, xanh lục, xanh dương

Giao diện của chúng ta cĩ ba checkbox và một button Khi button được click thì hàm xử lý sự kiện button click được thực hiện và kiểm tra checkbox nao duge chon va hién thị nội dung tương ứng lên

Hướng dẫn:

Chúng ta cĩ file aspx như sau: phần nội dung trong thẻ <form> được nhập và kéo thả các điều khiển CheckBox và Button trong thẻ HTML của hộp cơng cụ Toolbox ee TY _/ HtmllinputCheckBox.aspx{ Start Page © Data ki a HTML |||] Ban thích những màu nào? h Pointer Tr Đỏ

© Input (Button) ||| 7 Xanh duong

& Input (Reset) Xanh lục

2 Input (Submit) oor Submit | i

Trang 32

Nội dung trang Default.aspx: <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs” Inherits="_ Default" %> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" “http://www.w3.org/TR/xhtml1/DTD/xhtml -transitional.dtd"> <html xmins="http://www.w3.org/1999/xhtm|"> <head runat="server"> <title></title> </head> <body> <form id="form1" runat="server"> Bạn thích những màu nào? <br />

<input id="red" type="checkbox" runat="server" /> Do <br/>

<input id="blue" type="checkbox" runat="server" /> Xanh dương <br /> <input id="green" type="checkbox" runat="server" /> Xanh luc <br /> <input id="Button1" type="button" value="Submit" OnServerClick="submit" runat="server"/> <p id="p1" runat="server" /> </form> </body> </html> Code xử lý phía server như sau: public partial class _ Default: System.Web.UI.Page { protected void submit(object sender, EventArgs e) { string sResult =""; if (red.Checked) sResult = "đỏ, "; if (green.Checked) sResult = sResult + "xanh lục, "; if (blue.Checked)

Trang 34

File|New|File Chuong 2 TIM HIEU VA SU DUNG CAC SERVER CONTROLS Trong bài này, chúng ta tập trung tìm hiểu các loại Server controls Các vấn đề chính sẽ được đề cập:

v Cấu trúc một trang ASP.NET v Biến cố của trang ASP.NET

v Giới thiệu ASP.NET Server Controls

v Các loại HTML Server Controls và Web server Confrols

v Thuộc tính IsPostBack của trang ASP.NET va AutoPostBack cua cac Web Server Controls

Kết thúc bai này các bạn cĩ thể:

> Sử dụng được các Web Server Controls để xây dựng các trang ASP.NET

2.1 CAU TRUC TRANG ASP.NET

Chúng ta tạo một trang ASP.NET tên ChaoMung.aspx, nhấp chọn ‘Add New Item ~ CAUsers\daonguyenminh\Documents\Vinual Studio 2008\WebSites\WebSiteChapter2\ (a beatae Templates a

{Visual Studio instaled templates

| G]Web Form Master Page HE) Web User Control

SD)AIAX Client Behavior QYWAX Client Control §8)AIAX Client Library

TIAAX Master Page (GIAVAX Web Form ER WAX enabled WCF Service “HÀ Browser File Class A Class Diageam

2) crystal Report jd] Dataset 8) Generic Handter 4a) Global Application Class (e) HTML Page 38)0ScrptFile

| SUNG to SOL Classes LD Report ed Report Waard | GrResource File 3) Site Map Skin File

| U SQL Server Database A} Style Sheet al Tet File | SQwer service 11} Web Configuration File Web Service

XM Fite XML Schema GPXSLT File

My Templates

aL) Search Online Templates

t —— ‘A form for Web Applications

Name ChaoMung aspx

besume (mice) ecg Ci select master page

Hình 2.1: Hộp thoại thêm thanh phan mới vào ứng dụng đang mở

(hoặc Ctrl+N), hoặc trong cửa sơ Solution Explorer nhắp R-Click|Add New Item, xuất hiện hộp thoại sau:

Trang 35

Chon dé muc Web Form, nhập Name: ChaoMung.aspx, nhắp nút

Add, một trang mới được thêm vào ứng dụng

2.1.1 Các phương pháp viết mã trong ASP.NET

34

ASP.NET cho phép viễt mã lệnh theo hai mơ hình sau:

e M6 hinh Code Inline (Code Inline Model) e M6 hinh Code Behind (Code Behind Model) - ®) ChaoMung.aspx.cs 2| Default.aspx - G8) Default.aspx.cs li Default.aspx.resx web.config

Hình 2.2: Trang ChaoMung.aspx mới được thêm vào > Code Inline Model

Trang 36

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="ChaoMung.aspx.cs" Inherits="ChaoMung" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http:/www.w3.org/TR/xhtm]1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtm]"> <% Phần mã ASP NET(code section) %>

<script runat="server" language="ci#"> void Page_Load(object sender, EventArgs e)

IbIChao.Text = "Lap trình Web với ASP.Net 3.5"; } </script> <% Phan ma HTML(content section) %> <head runat="server"> <title>Chao mung</title> </head> <body> <form id="form1" runat="server"> <div> <asp:Label ID="Ib]Chao" runat="server" Width="302px" Height="38px"> </asp:Label> </div> </form> </body> </html>

Kết quả thực thi trang trên:

-Š) Chao mung - Mozilla Firefox

Ti ea Mai thị Lược c sử” Đánh dấu mm cụ 74 Tt] ae eS ene a ie ed | eto ee Ww -

Hinh 2.3: Minh hoa phan HTML code của trang ChaoMung.aspx > Code Behind Model

Trong mơ hình này, phần mã ASP.NET được được sắp xếp trong một tập tin khác riêng biệt với phần mã HTML Ta cĩ thể viết mã theo xử lý biến cố cho trang ChaoMung.aspx theo các bước sau:

Trang 37

Bước 1: Trong cửa số Solution Explorer, chọn trang ChaoMung.aspx, nhân phải chuột và chọn ViewCode

Bước 2: Sau khi VS.Net tạo một tập tin tên là ChaoMung.aspx.cs ta viết lệnh: IblChao.Text = "Lập trình Web với ASP.NET 3.5” vào trong sự kiện Page_Load public partial class ChaoMung: System.Web.UI.Page {

protected void Page_Load(object sender, EventArgs e) IblChao.Text = "Lập trình Web với ASP.Net 3.5"; } } Kết quả như trên: @ Cheo mung - Mozilla Firefox ee ee http://localhost:12656/WebSiteChapter2/ChaoMung.aspx

Hình 2.4: Minh hoa phan Code behind ctia trang ChaoMung.aspx So với Codelnline thì Code Behind viết mã lệnh (code) dé hon do tách được phân giao diện và phân mã HTML riêng biệt đơng thời cĩ thê sử dụng lại các đoạn mã da viét (reuseable codes) trong tap tin aspx.cs 2.1.2 Cấu trúc của trang ASP.NET

Một trang ASP.NET thơng thường gồm ba phan:

Phần 1: Được gọi là Page Direcfives, phần này cung cấp cho

ASP.NET những thơng tin đặc biệt để trình biên dịch biết cách thực thi

Trang 38

e Language: khai bdo ngén ngit duge sử dụng để viết mã cho trang (C#, VB.NET, )

¢ AutoEventWireup: néu giá trị là true thì các sự kiện của trang

được tự động gọi đúng tên như Page_Load mà khơng cân khởi tạo sự kiện chỉ đên phương thức Page_Load

¢ CodeFile: chi r6 tén tap tin code behind cĩ phần mở rộng aspx.cs (chứa các đoạn mã thực thi các biên cơ) được liên kết với trang ASP.NET cĩ phần mở rộng ASDX : ¢ Inherits: cho biết là trang giao diện thừa kế từ lớp nào là tên của

lop (class) của tập tin code behind, theo thí dụ là trang ChaoMung.aspx.cs

Phần 2: <script runat="server"> </script>, phan nay cdn goi la Code Declaration Block, giống như mã @ phia client (Client Side) nhưng cĩ kèm theo thuéc tinh runat="server" cho biét đoạn mã này

được thực thi ở phía server (Server Side) Ta cĩ thể đặt để phần này ở bất cứ nơi nào trong trang web, nhưng để phân biệt mã của ASP.NET với mã của HTML ta nên sắp xếp ở phần đầu tiên của trang

<script runat="server" language="c#"> void Page_Load(object sender, EventArgs e)

IblChao.Text = "Lập trình Web với ASP.Net 3.5"; } </script>

Phần mã này tạo ra một phương thức (hàm) cĩ tên là Page_Load

mac dinh (default) cho cdc trang ASP.NET, phương thức này sẽ thực

hiện gán chuỗi "Lập trình Web với ASP.NET 3.5" vào trong thuộc tính

Text của Label Control mỗi khi trang được thực thị

Phan 3: <html> <html>, day 14 noi ta bat dau phần mã của

HTML Phân này chính là hình thức trình bảy nội dung của trang được

Trang 39

#) Product.cs - [3 App_Data is Default.aspx ị ®% Default.aspx.cs - kã| Garbage.jpg kà 3» web.config

„ Để thêm thư mục App_Code, R-Click trên tên ứng dụng trong cửa

s6 Solution Explorer, chon Add ASP.NET folder va chon tiép

App_Code:

Build Web Site Publish Web Site

Add New Item Add Existing Item New Folder | | Bin

| App_Code — Add Reference | | App_GlobalResources Add Web Reference

Sau đĩ tạo một lớp Product.cs trong thu muc App_Code, R-Click

trén thu muc App_ Code, chon Add New Item:

Templates:

| Visual Studio installed templates

| Bh aiax-enabled WCF Service (aciass| Class Diagram

| Hl Dataset LASLING to SQL Classes [EB Report a) Report Wizard (B) Text File

if] An empty class declaration

Name: Chsskes CƠ”

= ]Pee sodkÌn separate fle

£7] Select master page

Trang 40

Gõ tên trong khung Name 1a Product.es và nhập nội dung sau:

// Define the delegate that represents the event public delegate void PriceChangedEventHandler(); public class Product

{

private string name; private decimal price; private string imageUrl;

public string Name

{

get {return name; } set { name = value; }

}

// Define the event

public event PriceChangedEventHandler PriceChanged;

public decimal Price { get {return price; } set { price = value; // Fire the event, provided there is at least one listener if (PriceChanged != null) { PriceChangedQ; } public string ImageUrl {

get {return imageUrl; }

Ngày đăng: 17/12/2021, 10:05

TỪ KHÓA LIÊN QUAN

TÀI LIỆU CÙNG NGƯỜI DÙNG

TÀI LIỆU LIÊN QUAN