Professional Documents
Culture Documents
NET
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:
4 /42
Tìm hiểu các mô hình ứng dụng
7 /42
Web Application
http
user
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
• Là kỹ thuật lập trình và phát triển ứng dụng web ở
phía Server (Server-side) Gồm các lớp đối tượng
• Thư viện các lớp đối tượng dùng trong việc dành cho việc xây
xây dựng các ứng dụng Web dựng các ứng dụng
• Web services có thể hiểu là các dịch vụ được Windows
cung cấp qua Web (hay Internet)
10 /42
Quan điểm lập trình web
Lập trình phía Server:
ASP.Net
Hoạt động:
Lập trình phía Client:
– Trang ASP sẽ được biên dịch và thi
HTML, Java Script, CSS hành tại Web Server
(Cascading Style Sheets) – Kết quả tự động được chuyển sang
Hoạt động: HTML/JavaScript/CSS
– Khi Web browser yêu – Khi Web browser yêu cầu một
cầu một trang web trang web
– Web server tìm trang – Web server tìm trang web mà
web mà Client yêu cầu Client yêu cầu
– Gởi về cho Client – Trả về cho Client
– Client nhận kết quả trả – Client nhận kết quả trả về từ
về từ Server; Xử lý ; Server và hiển thị lên màn hình
hiển thị lên màn hình
11 /42
Ví dụ
Trang1.html Trang2.asp
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ụ: http://namchautourist.com/
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
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ần 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
27 /42
Cấu hình Internet Information Services
• 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
2
1
3
31 /42
Cách tạo và chạy ứng dụng
•
32 /42
Cách tạo và 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
File cấu hình; Định dạng file này theo kiểu XML
34 /42
Trang 1.7. Cách viết
Asp.net code
35 /42
Code Inline
36 /42
Code Behind
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
Chứa các lớp cho phép thay đổi các control và component trong cả
ComponentModel
lúc chạy và lúc thiết kế.
Cung cấp các phương thức và đối tượng cho phép truy cập đến các
Configuration
thông số cấu hình cho .NET
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ên
Data
ADO.NET
Math Chứa các hàm và hằng số liên quan đến xử lý toán học.
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ú pháp:
<%@IntructionsName Listattribute%>
42 /42