Bài 1: Giới thiệu Asp.net
• HTTP và HTML - Nền móng của Kỹ thuật lập trình web • Tìm hiểu các mô hình ứng dụng • Web Application
Bạn đang xem trước 20 trang tài liệu Bài 1: Giới thiệu Asp.net, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
/42
Bài 1: GIƠ ́I THIỆU ASP.NET
1.1. Mở đầu
1.2. Giới thiệu ASP.NET
1.3. Kiến trúc ứng dụng của web
1.4. Web server
1.5. Tạo và chạy ứng dụng
1.6. Cấu trúc các ứng dụng
1.7. Cách viết code trong chương trình
1.8. Các thành phần có thể chứa trong trang
1
/42
1.1. Mở đầu
• HTTP và HTML - Nền móng của Kỹ thuật lập trình web
• Tìm hiểu các mô hình ứng dụng
• Web Application
2
/42
HTTP (Hypertext Transfer Protocol)
• HTTP :
– Kỹ thuật cơ bản của lập trình ứng dụng web
– Là một giao thức cho phép các máy tính trao đổi thông tin với
nhau qua mạng máy tính
– Được xác định qua URLs (Uniform Resource Locators), với cấu
trúc chuỗi có định dạng như sau:
http: // [: ] [ [? ]]
• Một số thuật ngữ:
– Internet
– WWW
– Web Server
– Web Client
– Web Browser
3
/42
HTML (Hypertext Markup Language)
ASP.Net
Chào các bạn đã đến với ASP.Net!!!
4
/42
Tìm hiểu các mô hình ứng dụng
• Dữ liệu tập trung => đảm bảo
dữ liệu được nhất quán
• Dữ liệu được chia sẻ cho
nhiều người dùng
• 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
• 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.
5
/42
• Hỗ trợ nhiều người dù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
• Xử lý nhận và hiển thị dữ liệu tập
trung tại Application Server => dễ
quản lý, bảo trì và nâng cấp
• Xử lý truy cập dữ liệu tập trung
tại Database Server
Phải sử dụng thêm một
Application Server =>
Tăng chi phí.
6
/42
Web Application
• Là 1 loại ứng dụng client/server
• Thành phâǹ:
– Web Client
– Web Browser
– Web Server
7
/42
Web Application
user
http
SQL
Access
8
/42
1.2. Giới thiệu ASP.NET
• Visual Studio .Net là bộ phần mềm được dùng để xây
dựng và phát triển các ứng dụng
• Đặc điê ̉m:
– Visual Studio .Net bao gồm các ngôn ngữ lập trình:
C++.Net, Visual Basic.Net, ASP.Net, C# và J#
– Tất cả các ngôn ngữ này được xây dựng dựa trên
nền .Net Framework
9
/42
• Các hàm API của Windows
• Microsoft Transaction Server (MTS)
• Internet Information Server (IIS)
• Là thành phần "kết
nối" giữa các phần
khác trong .NET
Framework với hệ
điều hành
• CLR giữ vai trò quản
lý việc thi hành các
ứng dụng viết bằng
.NET trên Windows
Thư viện các lớp
cơ bản nhất,
được dùng trong
khi xây dựng
.NET Framework
Gồm các lớp dùng
để xử lý dữ liệu
• Là kỹ thuật lập trình và phát triển ứng dụng web
ở phía Server (Server-side)
• Thư viện các lớp đối tượng dùng trong việc
xây dựng các ứng dụng Web
• Web services có thể hiểu là các dịch vụ được
cung cấp qua Web (hay Internet)
Gồm các lớp đối tượng
dành cho việc xây
dựng các ứng dụng
Windows
10
/42
Quan điểm lập trình web
Lập trình phía Client:
HTML, Java Script, CSS
(Cascading Style Sheets)
Hoạt động:
– Khi Web browser yêu
cầu một trang web
– Web server tìm trang
web mà Client yêu cầu
– Gởi về cho Client
– Client nhận kết quả trả
về từ Server; Xử lý ;
hiển thị lên màn hình
Lập trình phía Server:
ASP.Net
Hoạt động:
– Trang ASP sẽ được biên dịch và thi
hành tại Web Server
– Kết quả tự động được chuyển sang
HTML/JavaScript/CSS
– Khi Web browser yêu cầu một
trang web
– Web server tìm trang web mà
Client yêu cầu
– Trả về cho Client
– Client nhận kết quả trả về từ
Server và hiển thị lên màn hình
11
/42
Ví dụ
Trang1.html
Xin chao ban
Trang2.asp
Các điều khiển giao diện
12
/42
Ưu điểm của ASP.Net
• Nhiều ngôn ngữ lập trình
mà bạn yêu thích: Visual
Basic.Net, J#, C#,…
• 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 CSDL qua
ADO.Net, …
• ASP.Net sử dụng phong
cách lập trình mới Code
behide
13
/42
Static Web Pages
• Được thiết kế bằng kỹ thuật HTML (Hypertext Mark-up
Language)
• Chỉ đáp ứng việc giới thiệu thông tin cho người dùng xem
• Cao nhất là sử dụng một Form trực tuyến (Online Form) để
thu nhận ý kiến của người xem và gửi về e-mail định danh
trước
• Website tĩnh có thể được trang bị các kỹ thuật như Java
Script, Flash Macromedia hay Animation Gif, giúp cho giao
diện của các trang web thêm sống động và hấp dẫn
• Ví dụ:
14
/42
Dynamic Web Pages
• Được thiết kế bằng kỹ thuật ASP (Active Server Pages) chạy Windows hay
PHP (PHP Hypertext Preprocessor) với Linux.
• Phải có cơ sở dữ liệu và tùy theo mục đích của website, nó có thể có các
thành phần như:
1. Inner search: Phần tìm kiếm
2. Member account: tài khoản dành cho Hội Viên. Với một Username
và Password
3. Shopping Cart: Thành phần giúp cho việc mua bán trên mạng (online
trading) được thực hiện thông qua giả định việc chọn và bỏ món
hàng đã chọn vào giỏ mua hàng. Các thông số liên quan đến món
hàng sẽ được cập nhật vào tài khoản của người Mua, giúp cho việc
xác định công nợ và thanh toán.
4. Online Payment: Thành phần giúp cho việc buôn bán trên mạng
được khả thi: Tiền được trao cho Bên Bán và hàng sẽ được chuyển
cho Bên Mua
5. Forum: Diễn đàn trực tuyến
15
/42
1.3. Kiến trúc ứng dụng của web
16
/42
Tầng trình diễn (Presentation Tier)
• Người dùng có nhiều lựa chọn về nền trình diễn
• Hệ thống sẽ tự động gọi các tệp cấu hình sẵn cho tầng nền
• Tầng trình diễn chịu trách nhiệm :
– Cung cấp giao diện cho nhiều loại người dùng khác nhau
– Lấy các yêu cầu, dữ liệu từ người dùng, có thể định dạng nó
theo những qui tắc đơn giản (dùng các ngôn ngữ Script)
– Gọi các component thích hợp từ tầng Business Logic để xử
lý các yêu cầu
• Kết quả sau xử lý được trả lại cho người dùng
17
/42
Tầng Logic (Bussiness Logical Tier)
• Web server :
– Đảm nhận nhiệm vụ đón các yêu cầu từ tầng trình diễn
(yêu cầu phía client) và trả về kết quả cho phía client
– Có nhiệm vụ thực thi các thành phần điều khiển trình diễn
của ứng dụng chủ
– Quy trình xử lý nghiệp vụ và điều khiển sẽ do thành phần
thứ hai đảm trách
• Thành phần ứng dụng chủ :
– Thành phần này chứa các tập API để truy nhập và thao tác
với cơ sở dữ liệu ở tầng thứ ba - tầng cơ sở dữ liệu
– Các API được dùng để tạo ra các dự liệu XML và sau đó
kết hợp với các tham số được định sẵn trong bộ Stylesheet
để tạo ra các trang HTML, WML theo từng nền trình diễn
18
/42
Tầng dữ liệu (Data Tier)
• Tầng này đảm trách việc lấy, lưu trữ và cập nhật dữ liệu
• Vì vậy có thể nhìn nhận tầng này thể hiện cho 1 cơ sở dữ
liệu
• Chứa CSDL của toàn trang
• Ngoài ra tầng này còn có thể chứa CSDL của các ứng dụng
được tích hợp khác
19
/42
Các phần mêm̀
• Hệ điều hành (Windows 2000, XP, 7 … )
• .NET framework SDK (Software Development Kit)
• Cài đặt một cơ sở dữ liệu (Database) vững mạnh
20
/42
Phương pháp làm việc
• Kiểu mẫu RESQUEST/RESPONSE
• Kiểu mẫu EVENT-DRIVEN
21
/42
Kiê ̉u mẫu RESQUEST/RESPONSE
1. Client (thông qua Internet Browser) xác định vị trí của Web
Server qua URL (Universal Resource Locator)
2. Client sẽ yêu cầu được tham khảo 1 trang trong mạng đó và
thường là trang chủ (home page)
3. Server đáp ứng bằng cách hoàn trả hồ sơ mà Client đã yêu
cầu
4. Client nhận được hồ sơ gởi về và hiển thị (display) trong
browser của mình
Lưu ý:
• Còn gọi là 'response to your request', chờ yêu cầu từ phía client
• Khi Client đã nhận được hồ sơ thì quá trình trao đổi sẽ kết thúc ngay lập
tức 22
/42
• Kiểu mẫu event-driven dùng với ASP.NET
• Server sẽ không chờ client yêu cầu tham khảo 1
trang nào đó trong mạng
• Server đã bố trí sẵn trước tất cả mọi tình huống để
có thể đáp ứng kịp thời mỗi khi Client yêu cầu làm 1
điều gì đó
• Vì vậy kiểu mẫu event – driven còn được gọi là
'response to your action‘, server có thể phát hiện ra
các hành động của Client để phản ứng cho thích
hợp
Kiê ̉u mẫu EVENT-DRIVEN
23
/42
1.4. Web server
• Web server :
– Là một máy chủ hoặc một phần mềm trên máy mà nó có
thể đáp lại các yêu cầu dữ liệu từ phía trình duyệt sử
dụng giao thức HTTP cho phép người dùng có thể truy
cập file HTML
– Webserver biên dịch mã lệnh thành trang HTML trước khi
gửi về cho client
• Các phâǹ mềm tạo web server thông dụng :
– IIS
– Tomcat
24
/42
Internet Information Services
• IIS có thể được sử dụng như một Web server
• IIS kết hợp với ASP để 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 Client/Server
• Các bước thực hiện:
• Thiết lập Internet Information Service
• Kiê ̉m tra
• Cấu hình Internet Information Services
• Tạo các ứng dụng web trên IIS
25
/42
Thiết lập Internet Information Service
1. Mở Control Panel
2. Click Programs and Features
3. Click Turn Windows features on
or off
4. Click Internet Information
Services
5. Mở rộng cây thư mục Expand
Internet Information Services >
World Wide Web Services >
Application Development
Features > Click ISAPI Extensions
6. Click chuột vào OK cho máy cài
giùm mình IIS7
7. Khi Windows Features đóng lại
thì cũng là lúc IIS7 được cài xong
26
/42
Kiểm tra
Web Server mặc định
ánh xạ vào //localhost
27
/42
Cấu hình Internet Information Services
• Để cấu hình IIS, vào Control Panel Administrative Tool
Internet Information Services Manager
• Cài Internet Information Services
28
/42
1.5 Tạo các ứng dụng web trên IIS
• Một Web Server có thể quản lý nhiều ứng dụng Web
đồng thời
• Cách quản lý:
– Thông thường bạn sẽ tổ chức một thư mục con trong
wwwroot cho mỗi ứng dụng (IIS sẽ tự động liệt kê nó
trong mục Default Web Site)
– Bạn cũng có thể tạo ánh xạ từ một thư mục khác (tạo
một thư mục nằm ngoài thư mục wwwroot)
29
/42
Tạo Virtual Directory
30
/42
1.6 Cách tạo và chạy ứng dụng
Tạo ứng dụng web trong Visual Studio.NET
Khởi động Visual Studio.NET
Chọn File –> New –> Website
Trong hộp thoại New Website
1
3
2
31
/42
Cách tạo và chạy ứng dụng
•
32
/42
Cách tạo và chạy ứng dụng
• Nhấn F5 để chạy ứng dụng
33
/42
1.5. Cấu trúc các ứng dụng
Folder chứa các trang phụ liên quan đến Account
Folder chứa dữ liệu
File cấu hình; Định dạng file này theo kiểu XML
File CSS (Xác định các kiểu hiển thị)
Trang mặc định khi chạy website
Các File sử dụng cho các tiến trình phía Client
34
/42
1.7. Cách viết
code
HTML hoặc XML
và server controls
Bất kỳ ngôn ngữ lập
trình nào được hỗ trợ
bởi CLR
Giao diện
người dùng
Xử lý logic
bên trong
Trang
Asp.net
35
/42
Code Inline
36
/42
Code Behind
Khai báo nơi chứa Code
File chứa Code
37
/42
1.8. Các thành phần có thể chứa trong
trang
• Không gian tên (Namespaces)
• Khai báo Namespace
• Namespaces và chức năng
• Các chỉ thị (instructions)
38
/42
Không gian tên (Namespaces)
• NameSpace là một tập hợp Logic các nhóm thư viện có liên quan
đến nhau, giúp người lập trình dễ sử dụng và dễ tìm kiếm
• Namespaces có kiến trúc phân cấp. Muốn truy nhập vào một chức
năng hay một đối tượng của NameSpace cần phải biết được sõ đồ
phân cấp của NameSpace đó
• Mỗi NameSpace được chứa trong các file gọi là file Assembly, có
phần mở rộng là .dll. NameSpace có thể xem như các file thư viện
liên kết động DLL
• System là một NameSpace gốc của framework.NET. Nó chứa tất cả
các kiểu dữ liệu nguyên thuỷ (Primitives) và các NameSpace khác
39
/42
Khai báo Namespace
%>
40
/42
Namespaces và chức năng
Collections Chứa các đối tượng như Danh sách, hàng đợi và bảng băm
ComponentModel Chứa các lớp cho phép thay đổi các control và component trong cảlúc chạy và lúc thiết kế.
Configuration Cung cấp các phương thức và đối tượng cho phép truy cập đến cácthông số cấu hình cho .NET
Data Chứa các lớp cho phép tương tác với nguồn dữ liệu, Hình thành nênADO.NET
Math Chứa các hàm và hằng số liên quan đến xử lý toán học.
Web
Cung cấp cơ chế truyền thông giữa Client/Browser; Nó mô tả các
đối tượng được sử dụng với ASP.NET
XML Chứa các lớp để xử lý dữ liệu XML
Drawing Chứa các lớp cho phép sử dụng khả năng về đồ hoạ
41
/42
Các chỉ thị (instructions)
Các chỉ thị được sử dụng để khai báo các kế thừa
từ framework hoặc từ những source code khác,
một chỉ thị đựơc bắt đầu bởi ký tự @
Cú pháp:
42