VI.1. Tổ chức lưu trữ ứng dụng
VI.1.1.Màn hình giao diện
Giao diện ứng dụng quản lý bán hàng qua mạng
Kinh nghiệm giảng dạy:
Trong phần này, giáo viên hướng dẫn học viên truy cập vào các trang web với nhiều thể loại khác nhau: Tin tức, bán hàng trực tuyến, học tập trực tuyến, …
Dựa trên những trang web đĩ, giáo viên giúp học viên xác định các thành phần cĩ trên trang web cũng như trình bày cho học viên thấy được bố cục (hình thức trình bày) của các trang web.
VI.1.2.Tổ chức lưu trữ
Tổ chức lưu trữứng dụng
Css: Lưu trữ các tập tin *.css - tập tin qui định hình thức hiển thị.
Data: Lưu trữ tập tin *.mdb - tập tin cơ sở dữ liệu.
Hinh_minh_hoa: Lưu trữ các tập tin hình ảnh (*.bmp, *.gif, *.png, …)
Trong thư mục này, chúng ta cĩ thể tổ chức các thư mục con để lưu trữ hình ảnh theo chủ đề, ngày, …
The_hien: Lưu trữ các điều khiển do người dùng tạo - các đối tượng thể hiện.
Thu_vien: Lưu trữ các tập tin thư viện dùng chung của ứng dụng.
Trang: Lưu trữ các màn hình - các trang Web (*.aspx)
Xu_ly: Lưu trữ các lớp xử lý dữ liệu
VI.2. Xây dựng ứng dụng
VI.2.1.Xây dựng lớp Xử lý dữ liệu
Ứng với mỗi bảng trong cơ sở dữ liệu, chúng ta xây dựng các lớp xử lý tương ứng. Các lớp xử lý dữ
liệu xây dựng tương tự như lớp XL_SACH. (đã trình bày ở chương 5 phần I)
Thiết kế cơ sở dữ liệu của ứng dụng Quản lý bán hàng được trình bày trong phụ lục A - Cơ sở dữ
liệu Quản lý bán hàng. *.css *.mdb *.ascx *.bmp, *.gif, *.png *.vb *.aspx
Danh sách các lớp xử lý
VI.2.2.Thiết kế trang Web
Trước khi bắt tay vào thiết kế các đối tượng thể hiện và màn hình giao diện cho ứng dụng, chúng ta cũng nên nghĩ tới sẽ thiết kế trang web chạy trên màn hình cĩ độ phân giải nào (thường dùng hiện nay là 800x600). Yếu tố này tuy khơng quan trọng nhưng nĩ cũng phần nào quyết định bố cục trình bày của trang web.
Header - Tiêu đề
Các chủđề, chức năng chính của
ứng dụng
Các thơng tin liên quan: Thống kê số lần truy cập Đăng nhập Quảng cáo … Nội dung hiển thị
Các nội dung, bài viết liên quan
Các thơng tin liên quan:
Quảng cáo
Tin nĩng
…
Footer – Thơng tin cơng ty, tác giả, bản quyền …
Kiến trúc tổng thể trang web
Tùy theo yêu cầu và thể loại của ứng dụng mà chúng ta quyết định các kích thước (w, h) cho từng trường hợp cụ thể.
w1 w2
w
Bài 7 WEB SERVICE Tĩm tắt Lý thuyết 3 tiết - Thực hành 5 tiết Mục tiêu Các mục chính Bài tập Tìm hiểu Web Services
Xây dựng và sử dụng Web Services
1. Tìm hiểu về Web Services 2. Xây dựng Web Services 3. Sử dụng Web Service
4. Xây dựng Web Services truy xuất dữ liệu
7.1, 7.2 Bài làm thêm 7.3, 7.4, 7.5, 7.6, 7.7
Trong phần này, chúng ta sẽ tìm hiểu Web services là gì? Cơng dụng của nĩ như thế nào? Sau khi hiểu được ý nghĩa và tầm quan trọng của nĩ, chúng ta sẽ bắt tay vào xây dựng Web Services.
I. Tìm hiểu về Web Services
Khi bạn xây dựng và phát triển một ứng dụng phân tán với số lượng người dùng lên đến hàng trăm, hàng nghìn người ở nhiều địa điểm khác nhau, khĩ khăn đầu tiên mà bạn gặp phải là sự giao tiếp giữa Client và Server bị tường lửa (firewalls) và Proxy Server ngăn chặn lại.
Như các bạn biết DCOM (Distribited Component Object Model) làm việc thơng qua việc gởi các thơng tin dưới dạng nhị phân (binary) và chủ yếu hoạt động dựa trên giao thức TCP/IP. Thật là khơng dễ dàng để sử dụng DCOM trong trường hợp này.
Nếu khơng cấu hình lại Firewall, DCOM khơng cĩ khả năng vượt qua Firewall
COM Client COM Server
Web Services cĩ thể giúp bạn giải quyết vấn đề khĩ khăn nêu trên. Chúng ta cĩ thể hiểu rằng Web Services (tạm dịch là dịch vụ web) là tập hợp các phương thức của một đối tượng mà các Client cĩ thể gọi thực hiện.
Kiến trúc Web Services
Web Services được xây dựng dựa trên SOAP (Simple Object Access Protocal). Khơng giống như
DCOM, SOAP cĩ thể được gọi thực hiện và trả về kết quả Text (theo định dạng XML) và cĩ khả
năng hoặt động "xuyên qua" tường lửa.
Ngồi khả năng ưu việt trên, Web Services cĩ thể phối hợp hoạt động giữa các ứng dụng rất tốt. Hình minh họa trang bên là một ví dụ minh họa về sự phối hợp hoạt động giữa các ứng dụng. Các nhà hàng, khách sạn cung cấp các Web Services cho phép đặt phịng, đặt tiệc. Đường sắt Việt Nam cung cấp các Web Services cho phép đặt vé tàu. Việt Nam Airline cung cấp các Web Services cho phép đặt vé cho các chuyến bay.
Các cơ quan, cơng ty, hay khách du lịch cĩ nhu cầu tổ chức, tham gia các chuyến du lịch cĩ thể truy cập vào website của các cơng ty dịch vụ lữ hành đăng ký tham gia các "tour" do họ tổ chức.
Cơng ty du lịch sẽ sử dụng Web Services được cung cấp đĩ để tiến hành đặt vé tàu lửa, máy bay và
đặt phịng cho chuyến du lịch theo yêu cầu của khách hàng.
Web Client
Windows Client
Other
Phatforms Web Server
SOAP Request
Phối hợp hoạt động giữa các ứng dụng
Web Services là một chuẩn mới để xây dựng và phát triển ứng dụng phân tán, cĩ khả năng làm việc trên mọi hệ điều hành, mở rộng khả năng phối hợp giữa các ứng dụng, cĩ thể tái sử dụng, tăng cường sự giao tiếp giữa Client và Server thơng qua mơi trường Web.
XML là định dạng dữ liệu chuẩn để trao đổi giữa các Web Services
C Clliieenntt W WeebbSSeerrvviiccee W WeebbSSeerrvviiccee WWeebbSSeerrvviiccee W WeebbSSeerrvviiccee ..NNeettMMyySSeerrvviiccee Internet Đường sắt Việt Nam Việt Nam Airline Khách sạn Nhà hàng Khách du lịch Cơng ty du lịch
II. Xây dựng Web Services
II.1. Tạo Web Services trong VS .Net
Trong phần này, chúng ta sẽ xây dựng một Web Service đơn giản cĩ tên WS_PHEP_TOAN, với phương thức Cong_hai_so trong Visual Studio .Net
Chọn Add|Add New Items… từ thực đơn ngữ cảnh của Project. Chọn mục Web Service trong khung Template. Đổi tên Web Service cần tạo thành WS_PHEP_TOAN.
Tạo mới Web Service
Trong cửa sổ viết lệnh, cĩ một phương thức mẫu được tạo sẵn: phương thức HelloWorld.
2
Bạn cĩ nhận thấy rằng trước phương thức HelloWorld cĩ sẵn từ khĩa <WebMethod()>. Chúng ta sẽ bổ sung vào phương thức Cong_hai_so.
<WebMethod()> _
Public Function Cong_hai_so(ByVal pA As Integer, _
ByVal pB As Integer) As Integer
Dim lTong As Integer lTong = pA + pB Return lTong End Function
II.2. Kiểm tra Web Service
Sau khi xây dựng thành cơng Web Service, trước khi đưa vào sử dụng, chúng ta cũng nên tiến hành kiểm tra Web Service. Các Web Service được xây dựng trong VS.Net tự động phát sinh ra các trang kiểm tra tương ứng. Để thực hiện điều này, các bạn chọn WS_PHEP_TOAN.asmx làm trang khởi
động, nhấn F5 để thi hành ứng dụng.
Màn hình kiểm tra Web Service
Trang kiểm tra Web Service sẽ liệt kê các phương thức hiện cĩ trong Web Service được chọn thi hành. Chọn phương thức cần kiểm tra. Ở đây, chúng ta chọn phương thức Cong_hai_so. Xuất hiện màn hình nhập các tham số cho phương thức Cong_hai_so.
Nhập các tham số cần thiết và nhấn nút Invoke để thi hành, chúng ta sẽ thấy xuất hiện trang kết quả như hình bên dưới.
III. Sử dụng Web Service
Sau khi hồn tất việc xây dựng, kiểm tra độ tin cậy và tính chính xác của Web Service, chúng ta sẽ
tiến hành đưa Web Service đi vào sử dụng.
Để sử dụng một Web Service, Client cần phải biết Web Service đĩ hỗ trợ những phương thức nào, phương thức cần cĩ những tham số nào, kết quả trả về ra sao…
Những thơng tin này của một Web Service được mơ tả bởi tài liệu WSDL (Web Service Description Language). WSDL là định dạng chuẩn để mơ tả các Web Service, sử dụng ngơn ngữ XML.
Chúng ta cĩ thể xem WSDL của một Web Service bằng cách thêm vào chuỗi tham số wsdl vào sau chuỗi URL:
Ví dụ:
http://localhost/MinhHoa/Chuong09-WebService/WS_PHEP_TOAN.asmx?wsdl
III.1. Sử dụng Web Service do người dùng xây dựng
Sử dụng Web Service do chúng ta xây dựng tương tự như việc sử dụng các lớp đối tượng.
Ví dụ:
Dim phep_toan As New WS_PHEP_TOAN
lblKet_qua.Text = phep_toan.Cong_hai_so(4, 6)
III.2. Sử dụng Web Services được cung cấp miễn phí trên mạng
Để biết được những Web Services được cung cấp miễn phí trên mạng, các bạn cĩ thể dùng google
để thực hiện tìm kiếm. Ở đây, chúng tơi giới thiệu đến các bạn trang: http://www.webservicex.net
cung cấp khá nhiều các Web Services hữu ích.
Trong phần này, chúng tơi sẽ hướng dẫn bạn sử dụng các Web Services để lấy thơng tin tỷ giá ngoại tệ, thơng tin thời tiết, các thành phố chính của một quốc gia và các đơn vị tiền tệ của các quốc gia trên thế giới.
Các bước thực hiện:
Bước 1. Chọn Add Web Reference… từ thực đơn ngữ cảnh của ứng dụng
Thêm WebService vào ứng dụng
Bước 2. Nhập thơng tin đường dẫn của WebService, nhấn để thực hiện việc xác thực Web Service.
Bước 3. Nếu Web Service được xác thực thành cơng, thơng tin mơ tả về Web Service sẽđược hiển thị ngay phía bên dưới. Trong ví dụ này, chúng ta lần lượt xác thực 3 Web Service sau:
http://www.webservicex.net/country.asmx?WSDLỴ Các quốc gia
http://www.webservicex.net/globalweather.asmx?WSDL Ỵ Thời tiết
Tham chiếu Web Service
Bước 4. Đặt tên tham chiếu cho WebService: Web reference name.
Bước 5. Nhấn Add Referenceđể hồn tất tham chiếu WebService. Bảng trên mơ tả các phương thức và tài liệu hướng dẫn của WebService
Bước 6. Thiết kế màn hình
Màn hình thiết kế
Viết lệnh xử lý:
'Lấy tỉ giá ngoại tệ
Dim tgNgoai_te As New Ws_Ty_gia.CurrencyConvertor lblUSD.Text = tgNgoai_te.ConversionRate( _ Ws_Ty_gia.Currency.USD, Ws_Ty_gia.Currency.VND) lblEUR.Text = tgNgoai_te.ConversionRate( _ Ws_Ty_gia.Currency.EUR, Ws_Ty_gia.Currency.VND) lblGBP.Text = tgNgoai_te.ConversionRate( _ Ws_Ty_gia.Currency.GBP, Ws_Ty_gia.Currency.VND) 'Lấy thơng tin thời tiết các thành phố chính
Dim lWeather As New Ws_Thoi_tiet.GlobalWeather
lblHN.Text = lWeather.GetWeather("Ha Noi", "Viet Nam")
lblHCM.Text = lWeather.GetWeather("Ho Chi Minh", "Viet Nam") lblThanh_pho.Text = lWeather.GetCitiesByCountry("Viet Nam")
'Lấy tên các quốc gia và đơn vị tiền tệ trên thế giới
Dim lCountry As New Ws_Quoc_gia.country lblDon_vi.Text = lCountry.GetCurrencyCode() lblQuoc_gia.Text = lCountry.GetCountries()
Tỷ giá ngoại tệ và thơng tin thời tiết được lấy từ WebService vào lúc: 9:30:00 AM ngày 13/06/2005 (giờ Việt nam). Lúc các bạn thi hành, các giá trị này cĩ thể thay đổi.
IV. Xây dựng Web Services truy xuất dữ liệu
IV.1. Web Service: WS_KHACH_HANG
Trong phần này, chúng ta phối hợp các lớp xử lý đã cĩ để xây dựng Web service WS_KHACH_HANG. Trong ví dụ minh họa dưới đây, chúng ta xây dựng ba thủ tục:
Doc_danh_sach_khach_hang
Them_khach_hang
Xoa_khach_hang <WebMethod()> _
Public Function Doc_danh_sach_khach_hang() As DataSet Dim lKhach_hang As New XL_KHACH_HANG
Dim lDataset As New DataSet
lDataset.Tables.Add(lKhach_hang) Return lDataset
End Function <WebMethod()> _
Public Function Them_khach_hang(ByVal pHo_kh As String, _ ByVal pTen_kh As String, _
ByVal pNgay_sinh As Date, _ ByVal pGioi_tinh As Boolean, _ ByVal pDia_chi As String, _ ByVal pTen_dn As String, _
ByVal pMat_khau As String) As Boolean Try
Dim lKhach_hang As New XL_KHACH_HANG Dim lDr As DataRow lDr = lKhach_hang.NewRow() lDr("Ho_khach_hang") = pHo_kh lDr("Ten_khach_hang") = pTen_kh lDr("Ngay_sinh") = pNgay_sinh lDr("Gioi_tinh") = pGioi_tinh) lDr("Dia_chi") = pDia_chi lDr("Ten_dang_nhap") = pTen_dn lDr("Mat_khau") = pMat_khau lKhach_hang.Rows.Add(lDr) lKhach_hang.Ghi_du_lieu() Return True
Return False End Try
End Function <WebMethod()> _
Public Function Xoa_khach_hang(ByVal pMkh As Long) Dim lKhach_hang As New XL_KHACH_HANG
lKhach_hang.Xoa_dong(pMkh) End Function
Trong Web service trên, chúng ta cĩ sử dụng một số phương thức từ lớp XL_KHACH_HANG. Để sử
dụng, chúng ta cần bổ sung các phương thức sau vào lớp XL_KHACH_HANG: 'Xác định chỉ số của dịng cĩ mã số tương ứng
Public Function Lay_chi_so(ByVal pMa_so As Integer) As Long Dim i as Long
For i = 0 To Me.So_dong() - 1
If Me.Rows(i)(Khoa) = pMa_so Then
Return i
End If
Next Return -1 End Function
Public Sub Xoa_dong(pMa_so as Long)
Dim lChi_so as Long = Lay_chi_so(pMa_so) If lChi_so >= 0 Then Try Me.Rows(lChi_so).Delete() Ghi_du_lieu() Catch e As Exception End Try End If End Sub
Public Sub Ghi_du_lieu() Try
mDa_Bo_doc_ghi.Update(Me) Me.AcceptChanges()
End Sub
IV.2. Sử dụng WS_KHACH_HANG
IV.2.1.Kiểm tra Web Service
Sau khi thiết kế thành cơng WS_KHACH_HANG, chúng ta tiến hành kiểm tra Web service vừa tạo.
Danh sách các phương thức của WS_KHACH_HANG
Chọn chức năng Doc_danh_sach_khach_hang.
Thi hành phương thức Doc_danh_sach_khach_hang
Kết quả:
Kết quả dưới dạng XML
IV.2.2.Sử dụng Web Service WS_KHACH_HANG
Sau khi xây dựng và kiểm tra thành cơng WS_KHACH_HANG, chúng ta sử dụng web service vừa tạo vào ứng dụng.
Private Sub Page_Load(…) Handles MyBase.Load Dim lKhach_hang As New WS_KHACH_HANG
dtgKhach_hang.DataSource = lKhach_hang.Doc_danh_sach_khach_hang dtgKhach_hang.DataBind()
End Sub
Màn hình kết quả:
Bài 8 PHỤ LỤC Tĩm tắt Mục tiêu Các mục chính Bài tập Giới thiệu về các phụ lục đính kèm tài liệu. 1. Cơ sở dữ liệu dùng trong ứng dụng 2. Giới thiệu về các tag HTML
3. Cascading Style Sheets - CSS 4. Giới thiệu lớp xử lý dữ liệu
I. Cơ sở dữ liệu dùng trong ứng dụng
I.1. Thiết kế cơ sở dữ liệu
I.1.1. Cấu trúc bảng dữ liệu a. Bảng Chủđề - CHU_DE
Field Name Field Type Field Size Description
Mcd Autonumber Long Integer
Ten_chu_de Text 50
b. Bảng Sách - SACH
Field Name Field Type Field Size Description
Ms Autonumber Long Integer
Ten_sach Text 100 Don_vi_tinh Text 50
Don_gia Number Currency
Mo_ta Memo Tĩm tắt nội dung
Hinh_minh_hoa Text 50 Ảnh minh họa
Mcd Number Long Integer Mã chủđề
Mnxb Number Long Integer Mã nhà xuất bản
Ngay_cap_nhat Date/Time Ngày cập nhật
So_luong_ban Number Long Integer
So_lan_xem Number Long Integer
c. Bảng Khách hàng - KHACH_HANG
Field Name Field Type Field Size Description
Mkh Autonumber Long Integer
Ho_khach_hang Text 50 Ten_khach_hang Text 50 Dia_chi Text 50 Dien_thoai Text 10 Ten_dang_nhap Text 15 Mat_khau Text 15 Ngay_sinh Date/Time
Gioi_tinh Yes/No Yes: Nam
Email Text 50
Da_duyet Yes/No Yes: Đã duyệt
d. Bảng Đơn đặt hàng - DON_DAT_HANG
Field Name Field Type Field Size Description
Sdh Autonumber Long Integer
Mkh Number Long Integer
Ngay_dat_hang Date/Time
e. Bảng Chi tiết đặt hàng - CT_DAT_HANG
Field Name Field Type Field Size Description
Sdh Number Long Integer
Ms Number Long Integer
So_luong Number Long Integer
Don_gia Number Double
Thanh_tien Number Double
f. Bảng Nhà xuất bản - NHA_XUAT_BAN
Field Name Field Type Field Size Description
Mnxb Autonumber Long Integer
Ten_nha_xuat_ban Text 100
Dia_chi Text 150
Dien_thoai Text 15
g. Bảng Tác giả - TAC_GIA
Field Name Field Type Field Size Description
Mtg Autonumber Long Integer
Ten_tac_gia Number Long Integer
Dia_chi Text 100
Dien_thoai Text 15
h. Bảng Viết Sách – VIET_SACH
Field Name Field Type Field Size Description
Stt Autonumber Long Integer
Mtg Number Long Integer
Ms Number Long Integer
Các bảng dưới đây được dùng để Thăm dị dư luận & Quảng cáo i. Bảng Thăm dị - THAM_DO
Field Name Field Type Field Size Description
Mch Autonumber Long Integer
Ngay_dang Date/Time
Noi_dung Text 255 Tong_so_binh_chon Number Long Integer Mặc định = 0
j. Bảng Thăm dị chi tiết - THAM_DO_CT
Field Name Field Type Field Size Description
Mch Number Long Integer
Stt Number Long Integer 1,2,3,4,… ứng với chọn A,B,C,D,…
Noi_dung Text 255
k. Bảng Quảng cáo - QUANG_CAO
Field Name Field Type Field Size Description
Stt Autonumber Long Integer
Ten_Cong_ty Text 200
Hinh_minh_hoa Text 100 Ảnh minh họa
Duong_dan Text 100 (đến trang q.cáo)
Ngay_ky_hd Date/Time Ngày ký hợp đồng
Ngay_bat_dau Date/Time Bắt đầu quảng cáo
Ngay_ket_thuc Date/Time Hết hạn quảng cáo
I.2. Dữ liệu thử
I.2.1. Bảng Chủđề - CHU_DE
Mcd Ten_chu_de
1 Tiếng Việt 2 Ngoại ngữ
3 Cơng nghệ thơng tin 4 Luật
I.2.2. Bảng Nhà xuất bản – NHA_XUAT_BAN
Mnxb Ten_nha_xuat_ban Dia_chi Dien_thoai
1 Nhà xuất bản Trẻ 123 Nguyễn Du 19001560
2 NXB Thống kê 456 Cống Quỳnh 19001511
3 Kim đồng 789 Nguyễn Trãi 19001570
4 Văn hĩa nghệ thuật 357 Cộng Hịa 0903118833
I.2.3. Bảng Tác giả – TAC_GIA
Mtg Ten_tac_gia Dia_chi Dien_thoai
1 TS. Nguyễn Phương Liên 45 Lê Lợi 98877668
2 BS. Vũ Thị Uyên Thanh 18 Tơ Hiến Thành 19001611
3 Nguyễn Ngọc Minh 27 Nguyễn Huệ 19001570
4 Nguyễn Thiên Bằng 66 Trần Hưng Đạo 8504122
I.2.4. Bảng Thăm dị - THAM_DO
Mch Noi_dung Ngay_dang
1 Qua trận thắng trước Jubilo, bạn dựđốn
tuyển VN sẽ thi đấu thế nào ở Cup Honda? 01/06/2005
I.2.5. Bảng Thăm dị chi tiết - THAM_DO_CT