Tìm hiểu về xml và xslt web 2.0 ứng dụng trong thương mại điện tử
PHẦN I: TỔNG QUAN
I. Xu hướng chung:
Ngày nay, thương mại điện tử đã trở nên rất phổ biến.Với ưu điểm là tiết kiệm
chi phí marketing cũng như tạo sự thuận lợi cho người dùng có nhu cầu trang
bị đồ dùng cho mình. Thương mại điện tử hầu như hiện diện ở khắp nơi trên
thế giới đặc biệt là ở những quốc gia có nền kinh tế phát triển.
Tại Việt Nam những năm gần đây thì các doanh nghiệp vừa và nhỏ hầu như
đều tiếp thị sản phẩm của mình cũng như bán hàng trực tuyến trên internet.
II. Hình thức thương mại điện tử:
1. Khách hàng từ một máy tính tại một nơi nào đó, điền những thông tin thanh
toán và địa chỉ liên hệ vào đơn đặt hàng (Order Form) của Website bán
hàng (còn gọi là Website thương mại điện tử). Doanh nghiệp nhận được
yêu cầu mua hàng hoá hay dịch vụ của khách hàng và phản hồi xác nhận
tóm tắt lại những thông tin cần thiết những mặt hàng đã chọn, địa chỉ giao
nhận và số phiếu đặt hàng .
2. Khách hàng kiểm tra lại các thông tin và kích (click) vào nút (button) "đặt
hàng", từ bàn phím hay chuột (mouse) của máy tính, để gởi thông tin trả về
cho doanh nghiệp.
3. Doanh nghiệp nhận và lưu trữ thông tin đặt hàng đồng thời chuyển tiếp
thông tin thanh toán (số thẻ tín dụng, ngày đáo hạn, chủ thẻ .) đã được mã
hoá đến máy chủ (Server, thiết bị xử lý dữ liệu) của Trung tâm cung cấp
dịch vụ xử lý thẻ trên mạng Internet. Với quá trình mã hóa các thông tin
thanh toán của khách hàng được bảo mật an toàn nhằm chống gian lận
trong các giao dịch (chẳng hạn doanh nghiệp sẽ không biết được thông tin
về thẻ tín dụng của khách hàng).
4. Khi Trung tâm Xử lý thẻ tín dụng nhận được thông tin thanh toán, sẽ giải
mã thông tin và xử lý giao dịch đằng sau bức tường lửa (FireWall) và tách
rời mạng Internet (off the Internet), nhằm mục đích bảo mật tuyệt đối cho
các giao dịch thương mại, định dạng lại giao dịch và chuyển tiếp thông tin
thanh toán đến ngân hàng của doanh nghiệp (Acquirer) theo một đường dây
thuê bao riêng (một đường truyền số liệu riêng biệt).
5. Ngân hàng của doanh nghiệp gởi thông điệp điện tử yêu cầu thanh toán
(authorization request) đến Ngân hàng hoặc Công ty cung cấp thẻ tín dụng
của khách hàng (Issuer). Và tổ chức tài chính này sẽ phản hồi là đồng ý
hoặc từ chối thanh toán đến trung tâm xử lý thẻ tín dụng trên mạng Internet.
6. Trung tâm xử lý thẻ tín dụng trên Internet sẽ tiếp tục chuyển tiếp những
thông tin phản hồi trên đến doanh nghiệp, và tùy theo đó doanh nghiệp
thông báo cho khách hàng được rõ là đơn đặt hàng sẽ được thực hiện hay
không.
7. Toàn bộ thời gian thực hiện một giao dịch qua mạng từ bước 1 -> bước 6
được xử lý trong khoảng 15 - 20 giây.
III.
Lý do và mục tiêu của đề tài:
Như chúng ta thấy thương mại điện tử ngày trở nên phổ biến và cùng với
những lợi ích mà thương mại điện tử đem lại cho doanh nghiệp và người dùng
như :
1. Thương mại điện tử (TMĐT) giúp cho các doanh nghiệp nắm được thông
tin phong phú về thị trường và đối tác.
2. TMĐT giúp giảm chi phí sản xuất.
3. TMĐT giúp giảm chi phí bán hàng và tiếp thị.
4. TMĐT qua Internet giúp người tiêu dùng và các doanh nghiệp giảm đáng
kể thời gian và chi phí giao dịch.
5. Tạo điều kiện sớm tiếp cận nền kinh tế số hóa.
Nhận thức rõ về những lợi ích mà thương mại điện tử đem lại nên em quyết định tìm hiểu
và nghiên cứu xây dựng một website giơi thiệu và bán sản phẩm trực tuyến trên internet.
IV.
Cấu trúc báo cáo:
Từ những mục tiêu và lợi ích trên em đã thực hiện các công việc và kết quả các
công việc được thể hiện trong báo cáo luận văn này theo cấu trúc sau:
Báo cáo luận văn gôm 3 phần:
Phần I .Tổng quan: Xu hướng thương mại điện tử hiện nay nêu lên nhu cầu
thực tế và lý do thực hiện đề tài .
Phần II. Tìm hiểu về XML và XSLT
Chương I. Tìm hiểu về XML và XSLT: Giới thiệu về ngôn ngữ XML đồng
thời cũng giới thiệu sơ lược về hợp khuôn dạng (Well-formed) và tính hợp lệ
(validation).
Chương II. Xây dựng tài liệu XML hợp khuôn dạng: Giới thiệu cụ thể cấu trúc
bên trong của một tài liệu XML.
Chương III. Định nghĩa kiểu tư liệu DTD và kiểm tra tính hợp lệ cảu tài liệu
XML:
Giới thiệu về cách định nghĩa và khai báo các phần tử (Element) được sử dụng
trong tài liệu XML để tạo nên một tài liệu có cấu trúc dạng cây.
Chương IV. Lược đồ XML (Schema XML) :
Giới thiệu về chức năng của lược đồ XML và sự cần thiết của lược đồ XML
Chương V: Sử dụng XSLT để transform dữ liệu XML: Giới thiệu về XSLT và
các lệnh cũng như cấu trúc của một file XSLT.
Chương VI. Chương trình ứng dụng: Xây dựng website giới thiệu và bán hàng
trực tuyến.
98 trang |
Chia sẻ: lvcdongnoi | Lượt xem: 3497 | Lượt tải: 0
Bạn đang xem trước 20 trang tài liệu Tìm hiểu về xml và xslt web 2.0 ứng dụng trong thương mại điện tử, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
ta sử dụng cách thứ hai sử dụng file xsl để chỉ cho trình duyệt hiểu những
thẻ ta đặt ra.
Đây là toàn bộ nội dung file hello.xslt.
- 8 -
<xsl:stylesheet version="1.0"
xmlns:xsl=""
xmlns:msxsl="urn:schemas-microsoft-com:xslt" exclude-result-
prefixes="msxsl"
>
Cũng như CSS chúng ta cũng cho file xml tham chiếu tới file xsl
Hello XML
Welcome to XML
Chúng ta sẽ tìm hiểu về XSLT ở những phần sau.
Sau khi đưa file xslt vào thì file xml được hiển thị trên trình duyệt như hình 1-2:
- 9 -
Hình 1-2 Tài liệu XML được hiển thị kết với XSLT trong IE 7.0
V. Điều tuyệt diệu về XML
XML trở nên phổ biến có rất nhiều nguyên do và chúng ta sẽ xem xét các nguyên
do này trong phần tổng quát dưới đây.
Điểm quan trọng nhất là XML cho phép dễ dàng xử lý chuyển tải và trao đổi dữ
liệu rất nhiều ứng dụng và tài liệu người dùng với các định dạng khác nhau.
1. Dễ dàng trao đổi dữ liệu
Nếu ta làm việc với máy tính trong một thời gian dài chúng ta sẽ thấy xung quanh
ta có rất nhiều loại file. Chuyển đổi dữ liệu giữa chúng là một vấn đề nan giải mặc dù đã
có không ít trình ứng dụng hỗ trợ. Ví dụ .doc, .xsl,.mdb vv.vv
Trong XML dữ liệu và định dạng được lưu ở dạng text và chúng ta có thể dễ dàng
cấu hình cũng như thay đổi chúng bằng các trình soạn thảo XML chuyên nghiệp để soạn
thảo nội dung XML. Tuy nhiên thì trường hợp đơn giản bạn có thể dùng trình soạn thảo
- 10 -
Notepad trong window để chỉnh sữa file xml. Dữ liệu và các thẻ trong XML cũng không
mã hóa theo một thuật giải đòi hỏi bản quyền nào cả.
2. Tùy biến ngôn ngữ định dạng
Ta có thể tạo ra các ngôn ngữ định dạng tùy biến dựa trên XML, đây là một trong
những khả năng mạnh nhất của XML. Hàng trăm ngôn ngữ định dạng chuyên dụng dựa
trên XML ra đời như:
Ngôn ngữ văn phòng về kỹ thuật nghiệp vụ ngân hàng (BITS Banking Industry
Technology Secretariat)
Trao đổi dữ liệu tài chính (IFX Financial Exchange)
Hệ thống thanh toán qua Internet của nghiệp vụ ngân hàng (BIPS Banking Internet
Payment System).
Định dạng trao đổi viễn thông (TIM Telecommunication Interchanged Markup).
Thư viện kinh doanh thông dụng (CBL Common Business Library).
Khởi đầu XML kinh doanh điện tử (ebXML).
Ngôn ngữ định dạng dữ liệu sản phẩm (PDML Product Data Markup Language)
Giao thức trao đổi thông tin tài chính (FIX Financial Information eXchange
protocol).
Một vài ngôn ngữ định dạng tùy biến như ngôn ngữ định dạng trong lĩnh vực hóa
học (CML Chemical Markup Language) cho phép bạn biểu diễn các công thức hóa hóa
và hóa trị của phân tử ở dạng đồ họa. Tương tự hãy tưởng tượng thật tiện lợi nếu XML có
thể diễn đạt được thông tin các ảnh đồ họa của những thiết kế mô hình nhà và trình duyệt
sẽ hiển thị lên toàn bộ ngôi nhà của bạn dựa vào XML.
- 11 -
Chúng ta không chỉ có thể tạo ra một tập ngôn ngữ con dựa vào XML mà còn có
thể mở rộng chúng. Thí dụ như nếu một người hay một nhóm nào đó đã tạo ra ngôn ngữ
định dạng con của XML ta sử dụng và cảm thấy thiếu một số thẻ. Ta có thể thêm vào các
thẻ khác, mà theo đó giúp ta thực hiện diễn đạt cũng như lưu trữ dễ dàng hơn. Thực tế thì
điều đó đang diễn ra với XHTML.
3. Dữ liệu có cấu trúc và tích hợp:
Một khía cạnh mạnh mẽ khác của XML là không chỉ cho phép bạn lưu dữ liệu vào
file XML dựa trên thẻ con mà còn tổ chức dữ liệu theo cấu trúc. XML cho phép các phần
tử thẻ tích hợp với nhau tạo nên một cấu trúc dữ liệu phân cấp hoàn chỉnh. Điều này cực
kỳ quan trọng khi bạn cần đến khả năng định nghĩa dữ liệu có cấu trúc. Ví dụ ta muốn mô
ta một cấu trúc lớp học ta có thể định nghĩa lớp học theo XML như sau:
XML in the real world!
XML
29/12/2008
Như Ý
Lý
- 12 -
Thạnh Trung
Hồ
Ta vừa thiết lập thông tin về một lớp hội thảo bằng XML. Có hai sinh viên đưa
vào buổi hội thảo này. Với mỗi phần tử sinh viên cần kèm theo thông tin về họ
và tên bằng thẻ và . được xem là một bảng dữ liệu
đồng nhất không thể chen ngang thẻ vào bên trong nội dung thẻ
được. Điều này sẽ làm cho tài liệu không có ý nghĩa. Chúng ta sẽ tìm hiểu về “Tìm hiểu
tài liệu XML hợp khuôn dạng” ở phần sau.
Tuy nhiên trong chương đầu tiên chúng ta sẽ được thấy cái tổng quát của tài XML
có hợp khuôn dạng (well-formed) và kiểm tra tài liệu có hợp lệ (valid) hay không.
4. Tài liệu XML hợp khuôn dạng (Well-formed)
Tài liệu hợp khuôn dạng là gì? Để hợp khuôn dạng, một tài liệu XML cần phải
tuân theo quy tắc cú pháp thiết lập cho XML bởi tổ chức quốc tế W3C. Các quy tắc này
được nêu ra trong đặc tả XML 1.0. Trước hết để hiểu được tài liệu khuôn dạng hợp lệ
chúng ta hay nhìn vào những tài liệu không hợp khuôn dạng. Đây là tài liệu mà có các thẻ
được đặt không sắp xếp theo một trật tự nào cả lồng và đan chéo lẫn nhau. Bao gồm
nhiều phần tử cùng làm thẻ gốc. Tài liệu có thẻ mở mà không có thẻ đóng…
Ví dụ:
- 13 -
Hello XML
Welcome to XML
Nếu là các thẻ HTML thì không có vấn đề gì cả. Trình duyệt vẫn hiểu và hiển thị
đúng nhưng đối với XML thì bạn sẽ bị trình duyệt bắt lỗi chỉ ra đúng vị trí không hợp
khuôn dạng của tài liệu.
5. Tài liệu XML hợp lệ (Valid document)
Hầu hết các trình duyệt trước hết kiểm tra xem tài liệu XML của bạn có hợp
khuông dạng không đã. Tiếp theo một vài trình duyệt có thể kiểm tra thêm tính hớp lệ của
tài liệu. Một tài liệu XML được gọi là hợp lệ khi nó là tài liệu được kết hợp với định
nghĩa kiểu tư liệu (Document Type Definition DTD) và tuân theo chuẩn DTD.
Các định nghĩa DTD nhằm xác định cú pháp đúng đắn cho tài liệu. DTD có thể
được chứa trong một file tách biệt hoặc chứa ngay trong chính tài liệu. DTD sử dụng
phần tử hay thẻ . Dưới đây là một ví dụ về định nghĩa kiểu tư liệu DTD
được chúng ta thêm vào file tài liệu XML hello.xml.
<!DOCTYPE Document [
- 14 -
]>
Hello XML
Welcome to XML
Chúng ta sẽ tìm hiểu chi tiết về DTD ở phẩn sau. Nhưng ở đây ta có thể thấy DTD
chỉ định rằng bạn có thể có hai thẻ Greeting và Message được định nghĩa là các thẻ có thể
mạng theo dữ liệu văn bản.
Chúng ta đã có cái nhìn tổng quan về tài liệu XML như: làm thế nào để hiển thị
nội dung XML với bảng định kiểu CSS,XSLT. Tài liệu XML hợp khuôn dạng và hợp lệ
là gì. Tại sao phải kiểm tra cú pháp của XML nghiêm ngặt. Mặc dù vậy, đó chỉ là một
phần mà bạn thấy qua về XML. Rất nhiều tài liệu XML được dùng cho mục đích không
phải hiển thị trên trình duyệt, XML được dùng để chứa dữ liệu, phục vụ mọi nhu cầu của
chương trình ứng dụng. Tuy không cần hiển thị nội dung XML dựa vào CSS hay XSL
nhưng chúng ta phải biết cách phân tích (Parse) nội dung tài liệu XML rút trích ra nội
dung trong thẻ. Xml có thể dùng để mô tả và biểu diên một cơ sở dữ liệu hoàn chỉnh.
Chương II: I. XÂY DỰNG TÀI LIỆU XML HỢP KHUÔN DẠNG
Trong HTML có khoảng 100 thẻ (tag) đã được định nghĩa. Trình duyệt có thể
kiểm tra các thẻ này và hiển thị nội dung tài liệu trong khuôn khổ các thẻ quy định trước.
Trái lại, với XML bạn hoàn toàn tự do định nghĩa các thẻ nên bạn phải có trách nhiệm
với chúng. Với XML bạn tự định nghĩa thẻ và tùy ý quyết định mục đích sử dụng của thẻ.
Mặc dù được tự do định nghĩa nhưng các thẻ XML phải tuân theo một quy tắc định nghĩa
bắt buộc. Nếu ta không theo những quy tắc này khi định nghĩa thẻ các bộ phân tích cú
pháp XML sẽ không chịu làm việc với tài liệu của chúng ta. Như đề cập ở trên tài liệu
XML của chúng ta phải thỏa mãn hai điều kiện đó là hợp khuôn dạng và hợp lệ. Tài liệu
được coi là hợp khuôn dạng khi theo đúng các bước thiết kế và xây dựng XML do W3C
- 15 -
đưa ra. Nói chung ta phải theo cú pháp khi khai báo thẻ XML và tuân theo cách đặt các
thẻ XML theo một trật tự có thể phân tích được bởi các bộ phân tích (Parse).
Chúng ta băt đầu xây dựng một tài liệu XML hợp khuôn dạng
Hide your heart
Bonnie Tyler
UK
CBS Records
9.90
1988
Lưu tài liệu XML này với tập tin catalog.xml. như bạn thấy đó tập tin catalog.xml ngày
càng phát triển kích thước dữ liệu sẽ phình to ra. Mặc dù vậy, cho dù có phình to ra đến
đâu nhưng nếu bạn tiếp tục tao ra thẻ và thêm dữ liệu vào theo đúng cách trên thì tất cả
các trình phân tích đều đọc được nội dung tài liệu của ta. Tài liệu XML thiết kế theo cách
trên được gọi là một tài liệu hợp khuôn dạng.
Tóm lại cấu trúc hình thành nên một tài liệu XML thường bạn tuân theo đó là: tạo
chỉ thị xử lý XML, xây dựng phần tử hoặc thẻ gốc, tạo các phần tử con lồng trong các
phần tử gốc.
Các phần tử bên trong thẻ gốc có thể chứa các thẻ con khác lông sâu nhau nhiều
cấp.
- 16 -
Ở mức cơ bản nhất, tài liệu XML được kết hợp bởi thành phần định dạng
(markup) và dữ liệu ký tự (charater data).
I. Định dạng và dữ liệu ký tự:
Định dạng tài liệu giúp ta tạo nên một cấu trúc. Định dạng bao gồm thẻ bắt đầu, thẻ kết
thúc, các phần tử thẻ rỗng các tham chiếu thực thể, tham chiếu ký tự lời chú thích, phân
đoạn CDATA khai báo kiểu tài liệu và chỉ thị xử lý. Tất cả các dữ liệu còn lại trong tài
liệu XML không phải là định dạng đều được xem là dữ liệu ký tự.
Dưới đây là diễn giải về các định dạng và kiểu dữ liệu ký tự dựa trên nội dung file
hello.xml đã được tạo ra ở trên.
Hello XML
Welcome to XML
Thẻ hay phần tử bắt đầu bắt đầu bằng ký tự bằng quy
tắc này ta có thể thấy trong tài liệu XML trên chúng ta có các phần tử gọi là định dạng
như , , .
Còn lại chuổi văn bản “Hello XML” hay “Welcome to XML” được xem là dữ liệu ký
tự.
Tuy nhiên phần định dạng không cần phải luôn bắt đầu bằng .
Trong trường hợp ta tham chiếu đến một thực thể thì phần định dạng có thể bắt đầu bằng
& và kết thúc bởi ; hoặc trong trường hợp bạn tham chiếu đến một thực thể tham số
- 17 -
(parameter entitis reference) phần định dạng có thể bắt đầu bằng % và kết thúc bởi ;. Một
vài tham chiếu thực thể có thể chuyển sang ký tự định dạng khi trình phân tích diễn dịch.
Ví dụ (< được dịch thành ). Chúng ta sẽ xem xét ví dụ sau
và kết quả như hình 2-1:
Hello <XML>
Welcome to XML
Hình 2-1 Sử dụng thẻ định dạng trong XML
Hình 2-1 thể hiện nội dung của tài liệu XML sử dụng các tham chiếu thực thể đặc biệt.
Các ký tự tham chiếu giúp ta hiển thị và đưa vào dữ liệu ký tự những dấu hiệu đã sử dụng
trong phần định dạng. Ở ví dụ trên nếu ta viết trực tiếp thẻ thì tài liệu của ta rõ
ràng là không hợp khuôn dạng vì không có thẻ đóng tương ứng.
Các ký tự như spacebar, backspace,Tab, ký tự xuống dòng, ký tự thụt dòng đều được xem
là khoảng trắng đối với các trình phân tích XML, ví dụ nội dung tài liệu sau:
- 18 -
Hello XML
Welcome to XML
Bộ phân tích không cần quan tâm đến khoảng trắng hay dấu canh lề định sẵn. Thực sự
nội dung tài liệu trên hoàn toàn tương đương với nội tài liệu dưới đây.
Hello XML
Welcome to XML
II. Phần khởi đầu (Prolog) của tài liệu XML
Phần prolog bắt đầu ngày từ những dòng đầu tiên của tài liệu XML. Chuẩn XML không
yêu cầu phải khai báo phần mở đầu XML. Tuy nhiên ,W3C khuyến khích bạn nên dùng ít
nhất cũng là dòng khai báo phiên bản sử dụng của XML. Nói chung phần khởi đầu của
XML thường chứa các khai báo XML, lời chú thích về tài liệu, chỉ thị xử lý khoảng trắng
và kiểu tư liệu DTD.
<!DOCTYPE Document [
- 19 -
]>
Như Ý
Lý
29/12/2008
Dell
1
15000000
- 20 -
III. Chú thích
Chú thích trong XML tương tự như chú thích trong HTML. Các chú thích để cho
ta hiểu rõ hơn một phần nào đó trong cấu trúc của tài liệu XML. Khi diễn dịch nội dung
tài liệu, các bộ phân tích thường bỏ qua những dòng chú thích. Bắt đầu chú thích bằng
chuỗi ký tự mở . ví dụ
<!DOCTYPE Document [
]>
Hello XML
Welcome to XML
- 21 -
Cần tuân theo một số quy tắc khi thêm dòng chú thích vào tài liệu XML. Chú thích không
được đặt trước các khai báo. Ví dụ sau là một chú thích không hợp lệ:
<!DOCTYPE Document [
]>
Hello XML
Welcome to XML
Không được đặt chú thích vào bên trong phần định dạng như ví dụ sau:
<!DOCTYPE Document [
- 22 -
]>
>
Hello XML
Welcome to XML
Chúng ta không thể dùng chuỗi -- bên trong chú thích. Bởi vì trình phân tích luôn xem
chuỗi -- là dấu hiệu nhận dạng kết thúc của chú thích. Ví dụ sau sử dụng chú thích không
hợp lệ:
<!DOCTYPE Document [
]>
Hello XML
- 23 -
Welcome to
XML
Ích lợi của chú thích còn được dùng để loại bỏ một số phần tử hoặc thẻ của XML không
dùng đến. Miễn là trong nội dung chú thích không được chứa các chú thích khác. Ví dụ
để loại bỏ phần tử khỏi tài liệu ta làm như sau và kết quả như hình 2-2
Hello XML
<!--
Welcome to XML
-->
Hình 2-2 Loại bỏ thẻ Message
IV. Chỉ thị xử lý
- 24 -
Các chỉ thị xử lý được dùng để chỉ dẫn cho bộ phân tích cách xử lý tài liệu XML
trong quá trình phân tích sẽ diễn ra sau này. Những chỉ thì này thường bắt đầu bằng <?
Và kết thúc bằng ?> tương tự như phần khai báo. Tuy nhiên ta không nên sử dụng trùng
lại từ khóa của khai báo những chỉ thị xử lý này rất đặc trưng và hoàn toàn phụ
thuộc vào bộ phân tích xử lý tài liệu XML ở ngữ cảnh xác định. Ví dụ chỉ thị yêu cầu bộ
phân tích kết hợp dữ liệu XML với XSLT.
Hello XML
Welcome to XML-->
V. Thẻ và các phần tử
1. Cấu thành của phần tử (element) và thẻ:
Ta tạo cấu trúc cho tài liệu XML dựa trên các thành phần định dạng (markup).
Những thành phần này bao gồm các phần tử (element). Mỗi phần tử thường bao
gồm một cặp thẻ, thẻ bắt đầu và thẻ kết thúc.Ngoại trừ các phần tử rỗng sẽ được
định nghĩa chỉ bằng một thẻ.
Thẻ bắt đầu còn được gọi là thẻ mở bắt đầu bằng ký tự .
Thẻ kết thúc được gọi là thẻ đóng bắt đầu bằng cặp ký tự </ và kết thúc bằng ký tự
>.
2. Tên thẻ
- 25 -
Đặc tả XML quy định rất rõ về cách đặt tên thẻ có thể bắt đầu bằng các ký tự (_)
hoặc dấu hai chấm (:) các ký tự kế tiếp có thể là ký tự, ký số, gạch chân , gạch nối,
dấu chấm ,dấu hai chấm nhưng không được là khoảng trắng.
Mặc dù đặc tả của XML cho phép nhưng nên tránh dùng dấu hai chấm trong tên
thẻ. Lý do chúng ta sẽ dùng dấu hai chấm để chỉ thị không gian tên (namespace)
của XML.
<CUSTOMER_0)
Lưu ý quan trọng là các bộ phân tích và diễn dịch XML thường phân biệt chữ hoa
và chữ thường cho nên thẻ được xem là khác biệt và độc lập với
thẻ . Tuy nhiên chúng ta không nên đặt tên thẻ như vậy. Thẻ mở và
thẻ đóng phải khớp với nhau như cặp thẻ đóng mở là
hợp lệ trong khi cặp thẻ được xem là bị lỗi do
không có thẻ đóng còn thì không có thẻ mở.
Các tên thẻ sau được xem là không hợp lệ:
3. Phần tử rỗng
- 26 -
Thường thì một phần tử bao gồm một thẻ mở và một thẻ đóng. Giữa thẻ mở
và thẻ đóng có thể chứa dữ liệu ký tự hoặc các cặp thẻ khác. Tuy nhiên, phần tử có
thể có duy nhất một thẻ. Đây là trường hợp thẻ rỗng không kèm theo dữ liệu và do
đó chỉ có duy nhất một thẻ. Thẻ thể hiện phần tử không phải thẻ mở cũng không
phải thẻ đóng. Chúng ta cũng từng quen với thẻ ,.. những thẻ này
được xem là phần tử rỗng bởi chúng không có thẻ đóng tương ứng. Trong XML
các thẻ chỉ đứng một mình tượng trưng cho phần tử rỗng và có dấu đóng thẻ là />
thay cho >. Ví dụ:
4. Phần tử gốc
Tất cả các tài liệu XML được coi là hợp khuôn dạng nếu chứa đựng duy
nhất một phần tử gốc. Phần tử gốc này chứa đựng tất cả các phần tử và cặp thẻ
khác trong tài liệu. phần tử gốc được xem là phần rất quan trọng trong cấu trúc
XML nhất là khi chúng ta nhìn nó ở khía cạnh lập trình. Khi ta bắt đầu phân tích
nội dung tài liệu XML ta phải khởi đầu từ một phần tử gốc, sau đó tiếp tục lần ra
các phần tử chứa dữ liệu khác. Trong file hello.xml phần tử gốc là cặp thẻ
phần tử gốc này do chúng ta tự đặt. Nó là một tên thẻ
bình thường.
5. Thuộc tính
Thuộc tính của các thẻ XML tương tự như các thẻ HTML. Thuộc tính được
kết hợp theo cặp name=value. Thuộc tính cho bạn xác định thêm thông tin và ý
- 27 -
nghĩa của thẻ. Thuộc tính được đặt trong thẻ mở và thẻ rỗng. Để gán trị cho thuộc
tính thường dùng dấu bằng (=). Ví dụ, dưới đây ta gán thuộc tính ProductName
cho phần tử sản phẩm trong product.xml để biết được tên sản phẩm
đó.
3
1
2
12 - 550 ml bottles
10.0000
13
70
25
false
Ta có thể thấy nội dung của tài liệu XML hiển thị trong trình duyệt IE cùng với thuộc
tính của thẻ như hình 2-3.
- 28 -
Hình 2-3 Nội dung tài liệu XML trong trình duyệt.
Rất nhiều tranh luận xoay quanh vấn đề nên chứa dữ liệu của thẻ trong thuộc tính
hay trong vùng dữ liệu giữa thẻ đóng và thẻ mở? Không có quy tắc nào chính xác
cả nhưng ta có thể theo một số hướng dẫn hữu ích sau.
- 29 -
Trước hết thẻ có nhiều thuộc tính sẽ làm cho thẻ và toàn bộ tài liệu trở nên khó
đọc.
Nhìn chung nếu thẻ chứa hơn 4 thuộc tính ta nên ngắt chúng ra thành các
phần tử cấu trúc bao gồm thẻ đóng và thẻ mở. Chúng sẽ dễ đọc và dễ chỉnh sửa
nội dung của tài liệu sau này hơn. Khi thiết lập thuộc tính cho thẻ, cần theo một số
quy tắt đặt tên và gán trị cho thuộc tính như sau.
5.1 Tên thuộc tính
Theo đặc tả XML 1.0 tên của thuộc tính cần tuân theo quy tắc đặt tên
thẻ. Ví dụ sau đây tên thuộc tính được xem như là hợp lệ.
Những thuộc tính sau là không hợp lệ:
5.2 Trị gán cho thuộc tính
Bởi vì phần định dạng luôn là văn bản text cho nên thuộc tính cũng
mang trị text. Ngay cả khi gán một trị số cho thuộc tính, nó cũng chỉ
biểu diễn ở dạng text mà thôi. Ví dụ ta xem số như là một chuỗi và bọc
chúng trong dấu nháy kép như sau:
Điều này cũng có nghĩa khi phân tích và trích xuất giá trị của thuộc tính
chúng ta cũng sẽ nhận về số kiểu chuỗi. nếu ta muốn dùng chuỗi số này
- 30 -
để tính toán, cần sử dụng các hàm chuyên dụng của ngôn ngữ lập trình
để chuyển kiểu chuỗi thành số.
Trong XML giá trị của thuộc tính thường được để trong cặp nháy kép
tuy nhiên nếu giá trị của thuộc tính có dấu nháy kép thì ta có thể sử
dụng dấu nháy đơn để thay thế.
Điều gì xảy ra khi giá trị của thuộc tính chứa dấu nháy đơn và nháy
kép? Ta có thể dùng thực thể định nghĩa của XML là ' (‘) và
"e; (“) cho dấu nháy đơn và kép tương ứng. Ví dụ:
Thuộc tính height thực tế là mạng trị 1’6’’.
5.3 Thuộc tính hữu dụng xml:lang
Nếu sử dụng thuộc tính xml:lang có thể tài liệu của chúng ta trở nên
đáng giá hơn. Thuộc tính này thường được các bộ máy tìm kiếm thông
tin trên mạng (search engine) sử dụng như là dấu hiệu nhận dạng về
ngôn ngữ của dữ liệu. giá trị gán cho thuộc tính này thường là mã quốc
gia chuẩn ISO 639 bao gồm hai ký tự tắt. Ví dụ để trình duyệt hiểu được
nội dung đoạn văn bản thuộc ngôn ngữ Anh ta có thể trình bày dữ liệu
bên trong thẻ với thuộc tính xml:lang như sau:
hello!
Ta cũng có thể dùng mã quốc gia và mã vùng theo chuẩn ISO cho phân
loại ngôn ngữ. Ví dụ có thể phân biệt ngôn ngữ tiếng Anh British và
American bằng thuộc tính thiết lập giá trị sau:
hello!
Hi!
- 31 -
VI. Xây dựng cấu trúc tài liệu hợp khuôn dạng:
Chúng ta đã xem qua cách khai báo phần tử, thẻ, thuộc tính, cách đặt tên
thẻ, tên thuộc tính… Dưới đây là phần tổng kết các quy tắc mà ta cần tuân theo để
xây dựng một tài liệu XML hợp khuôn dạng.
1. Các khai báo XML cần được đặt ở dòng đầu tiên của tài liệu.
2. Tài liệu XML chỉ có một phần tử gốc, các phần tử khác nếu có phải
là con của phần tử gốc.
3. Mọi phần tử XML khác rỗng phải bao gồm đầy đủ thẻ đóng và thẻ
mở.
4. Đóng phần tử rỗng với chuỗi đóng />.
5. Mọi phần tử trong tài liệu XML khác phần tử gốc đều phải nằm giữa
cặp thẻ gốc.
6. Các phần tử lồng nhau phải có thẻ đóng và thẻ mở hợp vị trí.
7. Sử dụng tên thuộc tính là duy nhất.
8. Chỉ nên sử dụng 5 tham chiếu thực thể được định nghĩa trước trong
XML.
& &
< <
> >
' ‘
" “
9. Bọc giá trị thuộc tính bằng cặp dấu nháy.
10. Chỉ nên sử dụng ký tự < và & đối với các thẻ mở và các thực thể.
VII Phân đoạn CDATA:
- 32 -
Như chúng ta thấy việc đặt nội dung dữ liệu trong tài liệu XML bao hàm cả
ký tự đặc biệt như > hay & là quá khó khăn. Chúng ta phải sử dụng các tham chiếu
thay thế. Nếu muốn lưu toàn bộ dữ liệu từ một tài liệu XML khác vào tài liệu
XML của mình thì sao? Nếu ta đặt nội dung dữ liệu XML ngoại vào tài liệu đích
của mình thì tài liệu đích sẽ bị xáo trộn bởi các thẻ nhập vào tài liệu ngoại để khắc
phục điều đó ta làm như thế nào? Chúng ta sử dụng phần tử CDATA để yêu cầu
trình phân tích xem toàn bộ nội dung của tài liệu ngoại như là dữ liệu chứ không
phải là cấu trúc bao gồm các thẻ.
Phân đoạn CDATA cũng là một phần tử nhưng bao gồm chỉ một thẻ. Thẻ
này bắt đầu bằng [!CDATA[ và kết thúc bằng ]]>. Giữa dấu hiệu bắt đầu
[!CDATA[ và kết thúc ]]> là nội dung văn bản bạn muốn trình phân tích không
đụng đến.
Ví dụ:
[<![CDATA[
Hello XML
Welcome to XML
]]>
Phân đoạn CDATA cực kỳ hữu dụng. Tất cả dữ liệu của ta sẽ được lưu trọn
vẹn mà không sợ xung đột với các thẻ hay ký tự đặc biệt của XML. Tuy nhiên, cần
phải tránh dùng ký tự nhận dạng nơi kết dữ liệu ]]> bên trong phân đoạn CDATA.
Ví dụ sau được xem là không hợp lệ:
- 33 -
[<![CDATA[
Hello XML]]>
Welcome to XML
]]>
Chúng ta xem xét một ví dụ về cách đưa javascript vào phân đoạn CDATA:
Hello XML
Welcome to XML
<![CDATA[
var a;
a=5;
if(a<0)
document.writeln("xin chào bạn")
else
document.writeln("số 5 lớn hơn 0")
- 34 -
]]>
Welcome java script
VIII . Không gian tên (namespace)
Xml cho phép tự do định nghĩa và đặt tên cho các thẻ. Nếu tài liệu của ta chỉ sử
dụng riêng cho một mục đích nào đó và không cần kết hợp vào tài liệu XML khác thì
điều này không thành vấn đề. Tuy nhiên một khi các ứng dụng phát triển, tập định nghĩa
các XML cần sống chung và kết hợp với nhau thì điều này là một vấn đề. Chẳng hạn nếu
tài liệu của ta tự định nghĩa thẻ mang tên chứa dữ liệu phục vụ cho riêng ứng
dụng của ta. Sau này chúng ta cần tích hợp tài liệu của mình với các ứng dụng khác như
VML hay MathML, chẳng may nếu các ứng dụng này cũng khai báo một phần tử mang
tên thì sao? Trình phân tích nên hiểu thẻ của mình hay của VML hay
MathML? Cần phải có sự phân biệt về phạm vi hay không gian tên (namespace) mà thẻ
có ý nghĩa. Ở đây ta vẫn có thể kết hợp hai thẻ vào một tài liệu XML duy nhất
nhưng phân biệt chúng bằng không gian tên. Chúng ta dùng một định danh tài nguyên
duy nhất (URI) để đặt cho không gian tên cần truy xuất. Tất cả các thẻ đi theo không gian
tên phải đặt sau tên miền và dấu hai chấm. Do URI chưa phổ dụng nên hiện nay ta vẫn
thường dùng địa chỉ URL làm định danh duy nhất cho một không gian tên nào đó.
1. Tạo không gian tên
Tài liệu dưới đây là một thư viện sách. Chúng ta bắt đầu bằng phần tử gốc với
tên thẻ là , bên trong thẻ gốc chứa các phần tử sách và tựa
sách như sau:
- 35 -
XML Tutorial
Để đưa định nghĩa không gian tên cho các thẻ, ta đưa thuộc tính xmlns:prefix
vào phần tử gốc. prefix là tên miền hay không gian tên mà ta muốn chỉ định.
Mỗi không gian tên cần mang một định danh URIs duy nhất. Ở đây chúng ta sử
dụng địa chỉ Web URLs thay cho URIs. Địa chỉ URLs được xem là duy nhất
đối với mọi tài nguyên trên Internet. Không gian tên NhuY được tạo ra cho thư
viện sau:
XML Tutorial
Sau khi tạo ra không gian tên phuongduy, áp dụng tên này cho tất cả các thẻ
nào trong tài liệu XML mà ta muốn chúng duy nhất và độc quyền thuộc về
phuongduy.
Ví dụ:
- 36 -
XML Tutorial
Tiếp theo nếu ta cần tham khảo đến các tựa sách của Amazon thì sao? Tài liệu
XML của Amazon chắc chắn sẽ có phần tử thẻ mang tên vậy để an
toàn chúng ta cần tạo ra không gian tên cho Amazon như sau:
<Library xmlns:phuongduy=""
xmlns:amazon="">
XML Tutorial
XML Tutorial
2. Không gian tên cục bộ (local namespace)
Chúng ta không chỉ có thể đặt thuộc tính xmlns ở phần tử gốc thuộc tính này
có thể đặt ở bất kỳ thẻ nào. Trong ví dụ dưới đây ta di chuyển việc định nghĩa
không gian tên amazon đến nơi mà nó bắt đầu sử dụng.
- 37 -
XML Tutorial
>
XML Tutorial
Chương III: ĐỊNH NGHĨA KIỂU TƯ LIỆU (DTD) &
KIỂM TRA TÍNH HỢP LỆ (VALID) CỦA XML
I.Định nghĩa kiểu tư liệu DTD là gì?
Ở phần trước chúng ta đã tìm hiểu về cú pháp và cách xây dựng một tài liệu XML
hợp khuôn dạng (well-formed). Tuy nhiên tài liệu XML còn được kiểm tra bởi một
quy định nữa đó là tính hợp lệ (valid) mà ở phần đầu ta đã đề cập đến.
Khi định nghĩa thẻ XML, ta tùy ý quyết định cách sử dụng chúng ví dụ như phần tử
chỉ chứa hai phần tử con là và .
Một tài liệu XML được xem là hợp lệ và có giá trị khi toàn bộ các phần tử trong
tài liệu được định nghĩa kiểu (type definition) mà nó sẽ chứa. Việc định nghĩa kiểu dữ
liệu cho các phần tử thẻ còn được gọi là kiểu định nghĩa tư liệu (DTD Document
Type Definition). Vi dụ:
<!DOCTYPE Document [
- 38 -
]>
Hello XML
Welcome to XML
Theo ví dụ trên, rõ ràng chưa cần xem qua nội dung tài liệu chúng ta cũng biết
được ý nghĩa và cấu trúc của toàn bộ tài liệu. Chẳng hạn Document được định
nghĩa ( bằng khai báo <!DOCTYPE) là phần tử thẻ gốc. Phần tử gốc chứa các
phần tử con như Greeting, Message hai phần tử còn này dùng chứa dữ liệu
(#PCDATA).
Ở ví dụ này chúng ta cần lưu ý đến phần tử thật sự về mặt
kỹ thuật mà nói, đây không hoàn toàn là một phần tử. Đây chỉ là phần chỉ thị bắt
đầu khai báo kiểu tư liệu DTD, cú pháp định nghĩa và khai báo kiểu tư liệu cho
các phần tử thẻ tổng quát như sau:
Trong đó DTD là các định nghĩa cho phần tử trong tài liệu. DTD có thể là
định nghĩa nội (internal) hoặc ngoại (external). Trong trường hợp này chúng ta sử
dụng định nghĩa kiểu dữ liệu nội.
<!DOCTYPE Document [
- 39 -
]>
Định nghĩa DTD cần theo cú pháp quy định của tổ chức XML W3C. Trong ví dụ
trên chúng ta định nghĩa thành phần DTD bằng chỉ thị khai báo . Với khai
báo này ta có thể cho biết một phần tử trong tài liệu sẽ mang dữ liệu text #PCDATA hoặc
sẽ chứa các phần tử con khác.
Phần tử Document là phần tử dùng chứa hai phần tử con Greeting và Message. Hai phần
tử này được định nghĩa chứa dữ liệu bằng văn bản và được khai báo:
Định nghĩa #PCDATA cho phép chứa các dữ liệu văn bản thuần túy không thuộc phần
định dạng.
Hơn nữa dựa vào khai báo đầu tiên của định nghĩa chúng ta có thể biết được thêm thông
tin rằng Document là phần tử gốc (root).
II. Khai báo và định nghĩa kiểu dữ liệu DTD
Ta dùng thẻ khai báo để bắt đầu kiểu định nghĩa tư liệu cho các
phần tử XML. Có nhiều mẫu khai báo mà chúng ta có thể sử dụng :
- 40 -
Phần khai báo định nghĩa kiểu tư liệu thường đặt ở phần khởi đầu của tài liệu XML. Ví
dụ chúng ta khai báo kiểu tư liệu trong hello.xml như sau
<!DOCTYPE Document [
]>
Tiếp đến ta định nghĩa kiểu tư liệu cho phần tử thẻ bên trong cặp dấu vuông [] ở đây các
phần tử được định nghĩa đều nằm trọn vẹn bên trong tài liệu, cho nên chúng được gọi là
là các phần tử được định nghĩa nội (internal). Lưu ý là chỉ thị standalone=”yes” cho biết
tài liệu XML của ta không phụ thuộc vào các tài liệu khác.
<!DOCTYPE Document [
]>
1.Khai báo
Khai báo được dùng để bắt đầu định nghĩa kiểu tư liệu DTD cho
một phần tử. Cú pháp khai báo:
- 41 -
Trong đó Name là tên của phần tử muốn định nghĩa; Content_Model có thể là
EMPTY hay ANY hoặc trộn lẫn cả hai nội dung.
Ví dụ sau cho ta thấy cách sử dụng định nghĩa DTD cho các phần tử thẻ. Các biểu
thức diễn đạt dưới đây còn gọi là tham chiếu thực thể theo tham số.
Ở ví dụ này chúng ta khai báo phần tử Document theo mô hình nội dung
(Content_Model) lưu trữ là ANY vậy ANY là gì?
2. Any
Khi khai báo một phần tử mang mô hình nội dung ANY có nghĩa là phần tử
khai báo có thể chứa bất kỳ nội dung nào bạn định nghĩa kể cả mọi phần tử khác.
Nếu một phần tử được khai báo là ANY thì trình phân tích sẽ không kiểm tra cú
pháp xác định tính hợp lệ của nội dung phần tử. Lý do là phần tử có thể chứa mọi
kiểu cho phép,không cần kiểm tra chi tiết nội dung bên trong của phần tử. Để cụ
thể hơn một phần tử có thể giới hạn nội dung mà nó thể hiện thay vì ANY. Chúng
ta có thể cụ thể hóa nội dung của phần tử thông qua khai báo danh sách các phần
tử con.
3. Danh sách các phần tử con
Chúng ta khai báo các phần tử con trong cặp ngoặc đơn của tư liệu DTD.
Ví dụ:
- 42 -
<!DOCTYPE Document [
]>
Dấu * cho biết Document có thể chứa số phần tử Student không giới hạn.
Tài liệu khi đó có thể thêm vào phần tử thẻ như sau:
<!DOCTYPE Document [
]>
Như ví dụ trên ta thấy tài liệu vẫn chưa hợp lệ do ta chưa khai báo phần tử Student.
Chúng ta cần khai báo phần tử Student sẽ chứa kiểu dữ liệu gì.
Ví dụ:
- 43 -
<!DOCTYPE Document [
]>
4. Làm việc với nhiều phần tử con
Khi muốn khai báo một phần tử con có khả năng chứa nhiều phần tử con khác,
thông thường ta phải lặp lại khai báo . Ví dụ trong tài liệu của ta
thẻ gốc chứa hai phần tử Student trong khi khai báo
chỉ định nghĩa có một trình phần tích sẽ báo lỗi.
Ví dụ:
<!DOCTYPE Document [
]>
Lý Như Ý
Hồ Thạnh Trung
- 44 -
Vậy để khắc phục vấn đề này chúng ta làm như thế nào ?
Chúng ta sử dụng các ký tự đại diện cho phép làm việc khai báo và sử dụng nhiều
phần tử con. Như chúng ta thấy ở ví dụ trên ta có sử dụng dấu * yêu cầu cho phép
Document chứa được mọi phần tử Student.
Dưới đây là một số nguyên tắc sử dụng ký tự đại diện có thể áp dụng khi khai báo
và định nghĩa DTD.
Giả sử a và b là hai phần tử con muốn khai báo và định nghĩa ta có cú pháp như
bảng 3-1 sau:
a* Không có hoặc có nhiều phần tử con giống nhau
a+ Có một hoặc nhiều phần tử con giống nhau
a? Phần tử a hoặc không có phần tử nào cả
a,b Phần tử a tiếp đến là phần tử b
a|b Phần tử a hoặc b nhưng không được cả hai
(expression) Tập các phần tử expression trong cặp ngoặc sẽ ảnh hưởng bởi ký
tự đại diện *,+ hoặc ?
Bảng 3-1 Những ký tự đại diện có thể áp dụng
III. Định nghĩa DTD ngoại:
Chúng ta có thể định nghĩa DTD cho phần tử thẻ dựa trên các tham chiếu đã được
định nghĩa sẳn từ các tài liệu XML trước đó.
- 45 -
Sử dụng định nghĩa DTD tham chiếu ngoại khiến cho các ứng dụng XML của bạn
có thể dễ dàng chia sẽ và dùng chung với các ứng dụng khác. Thực tế, đây là cách mà hầu
hết các ứng dụng XML đều hỗ trợ. Có hai cách chỉ định một phần tử DTD tham chiếu
ngoại: tham chiếu ngoại riêng (private DTD) và tham chiếu ngoại chung (Public DTD).
Những định nghĩa DTD tham chiếu ngoại riêng được sử dụng cho một nhóm
người và mang tính cá nhân chúng không được dùng cho mục đích phân phối chung.
Khai báo và định nghĩa phần tử DTD tham chiếu ngoại riêng bằng cách sử dụng khóa
SYSTEM trong chỉ thị khai báo như ví dụ sau:
Như Ý
Lý
29/12/2008
Dell
1
15000000
- 46 -
Ở ví dụ này ta sử dụng tham chiếu ngoại cho nên ta phải đổi lại chỉ thị
standalone=”no”. Bộ phân tích và kiểm tra sẽ hiểu rằng các phần tử mà ta định nghĩa
kiểu DTD sử dụng trong tài liệu này sẽ được khai báo từ một nơi nào đó bên ngoài tài
liệu của chính. Trong chỉ thị định nghĩa chúng ta cho biết các phần tử
DTD được định nghĩa chứa trong file order.dtd thuộc tính SYSTEM cho biết định nghĩa
tham chiếu được xem là riêng tư.
Nội dung của file order.dtd như sau:
IV. Tham chiếu DTD dùng chung:
Thay cho từ khóa SYSTEM bạn dùng từ khóa PUBLIC. Khi ta đặt từ khóa
PUBLIC vào chỉ thị khai báo, các thẻ DTD của ta có khả năng dùng làm
- 47 -
tham chiếu ngoại dùng chung và liên kết với nhiều tài liệu. Tuy nhiên để sử dụng được từ
khóa PUBLIC cần phải tạo ra một định danh chung hình thức (FPI Formal Public
Identifier) và tuân theo một số quy tắc áp dụng cho FPI sau:
Đối với DTD do ta định nghĩa thì trường đầu tiên sẽ là ký tự chấm {.} còn đối với
chuẩn hình thức trường này sẽ tự tham chiếu đến chuẩn của nó ví dụ
ISO/IEC:13449:2000.
Trường thứ hai phải nắm giữ tên nhóm hoặc của người sẽ chịu trách nhiệm bảo
trình và nâng cấp các định nghĩa DTD. Trong trường hợp này ta phải sử dụng tên mang
tính duy nhất (unique) và có thể dễ dàng định danh ra nhóm của bạn.
Trường thứ ba phải chỉ định kiểu của tài liệu được mô tả, thường thì trường này kèm
theo một số định danh duy nhất nào đó. Phần này bao gồm cả phiên bản mà ta cập nhật.
Trường thứ tư chỉ định ngôn ngữ mà định nghía DTD của ta sử dụng.
Các trường trong định danh FPI phải cách nhau bằng cặp sổ trái (//).
Ví dụ:
<!DOCTYPE Document PUBLIC ".//phuongduy//Order XML version 1.0//EN"
"order.dtd">
Như Ý
Ly
29/12/2008
- 48 -
Dell
1
15000000
V. Sử dụng tham chiếu nội và tham chiếu ngoại
Thực tế có thể sử dụng chung hai loại tham chiếu nội và ngoại trong cùng tài liệu
XML vào cùng một thời điểm.
Nếu một phần tử được định nghĩa ở hai nơi tức là trong tài liệu cục bộ và trong file
tham chiếu ngoại thì sao? Phần tử ở đâu sẽ được ưu tiên hơn? Về mặt lý thuyết nếu một
phần tử hay thuộc tính được định nghĩa ở hai nơi thì định nghĩa nội (cục bộ) sẽ được ưu
tiên hơn. Mặc dù vậy thực tế hiện nay hầu hết các trình kiểm tra đều thông báo lỗi và
dừng quá trình phân tích khi phát hiện có hai định nghĩa DTD nội và ngoại trùng nhau.
Chương IV : LƯỢC ĐỒ XML (Schema)
Chúng ta thấy việc sử dụng và khai báo DTD rất phức tạp do đó tổ chức W3C đã
đưa ra một giải pháp tổng quát hóa DTD hơn đó là khai báo và định nghĩa các phần tử
trong tài liệu XML theo lược đồ XML (XML Schema).
Thực sự thì lược đồ XML không đơn giản hơn DTD nhưng nó mạnh hơn và chính xác
hơn. Để kiểm tra tính hợp lệ của các định nghĩa DTD trong tài liệu ta dùng bộ kiểm tra
- 49 -
validator, để kiểm tra tính hợp lệ của các khai báo theo lược đồ XML ta dùng bộ kiểm tra
cú pháp lược đồ (schema checker).
Chúng ta bắt đầu tìm hiểu về schema XML thông qua ví dụ đơn giản sau đây:
Như Ý
Thạnh Trung
Lập trình XML
Lưu tài liệu này với tập tinh laptrinh.xml. Làm thế nào kết hợp lược đồ XML để trình
duyệt hiểu. để thực hiện yêu cầu này cần chỉ định một không gian tên mặc định cho tài
liệu bằng khai báo thuộc tính xmlns tại phần tử gốc cùng với thông tin về file chứa lược
đồ x-schema như sau :
Như Ý
Thạnh Trung
Lập trình XML
Nội dung file hello.xsd
<xs:schema name="hello"
- 50 -
targetNamespace=""
elementFormDefault="qualified"
xmlns=""
xmlns:mstns=""
xmlns:xs="">
I.Khai báo các phần tử và kiểu dữ liệu:
Điểm cơ bản nhất để hiểu lược đồ XML đó là khái niệm sử dụng kiểu giản đơn và
kiểu phức hợp trong khai báo kiểu cho các phần tử XML.
Để chỉ định kiểu cho một phần tử ta phải đảm bảo kiểu phải được định nghĩa trước
đó. Kiểu phức hợp là kiểu chứa các phần tử con trong nó hoặc chứa trong thuộc tính
trong khi kiểu giản đơn thì không.
Kiểu giản đơn là kiểu nội tại đã được định nghĩa sẵn và ta có thể dùng nó tự do
trong lược đồ XML. Dưới đây là bảng liệt kể các kiểu giản đơn.
Binary Kiểu dữ liệu nhị phân
boolean Kiểu lý luận
byte Kiểu byte
century Kiểu thế kỷ (ví dụ 21)
date Kiểu ngày
- 51 -
decimal Kiểu thập phân
double Kiểu số thực 64 bits
ENTITY Kiểu thực thể
ENTITIES Kiểu đa thực thể
ID Kiểu định danh
int,integer Kiểu số nguyên
IDREF Kiểu tham chiếu định danh
NOTATION Kiểu ghi chú
NMTOKEN Kiểu token đơn
NMTOKENS Kiểu đa token
month Kiểu tháng
String Kiểu chuỗi
Bảng 4-1 Bảng liệt kê các kiểu dữ liệu đơn giản
Thực ra thì còn rất nhiều kiểu nữa chúng ta có thể tham khảo tại trang web
Tạo một kiểu phức hợp mới trong lược đồ bằng cách dùng phần tử khai báo
. Một định nghĩa về kiểu phức hợp bản thân nó thường chứa các khai
báo phần tử con, tham chiếu đến các phần tử khác và khai báo thuộc tính.
Khai báo phần tử bằng chỉ thị khai báo và khai báo thuộc tính bằng chỉ thị
. Cũng tương tự như DTD khai báo phần tử sẽ chỉ định cú pháp của phần
tử trong lược đồ ta có thể chỉ định kiểu cho phần tử thậm chí còn có thể chỉ định kiểu cho
thuộc tính.
- 52 -
Chỉ định số lần xuất hiện của các phần tử:
MinOccurs Chỉ định phần tử đó xuất hiện hoặc không xuất hiện ít nhất
MaxOccurs Chỉ định phần tử đó xuất hiện tối đa là bao nhiêu lần
Bảng 4-2 Chỉ số xuất hiện của các phần tử (element)
Nếu như không chỉ định MinOccurs và MaxOccurs thì mặc định MinOccurs =1 còn
MaxOccrus không giới hạn. Điều này có nghĩa là phải có ít nhất một phần tử xuất hiện.
II.Chỉ định ràng buộc và trị mặc định cho thuộc tính
Thuộc tính không có kiểu phức hợp chúng ta chỉ có thể khai báo thuộc tính giản
đơn nhưng thay vào đó ta có thể chỉ định các ràng buộc cho thuộc tính.
Các ràng buộc cho thuộc tính thể hiện ở bảng sau:
required Thuộc tính cần phải hiện hữu trong thẻ và phải được gán trị
optional Thuộc tính có thể có hoặc không và giá trị gán cho thuộc tính là không
bắt buộc
fixed Giá trị thuộc tính phải được gán cố định và không được thay đổi như đã
gán trong lược đồ.
default Nếu thuộc tính không gán trị thì giá trị định nghĩa trong lược đồ là giá
- 53 -
trị mặc định của thuộc tính
prohibited Không cho phép thuộc tính xuất hiện
Bảng 4-3 Các ràng buộc giá trị cho thuộc tính.
Chương V: SỬ DỤNG XSL TRANSFORM TÀI LIỆU XML
Như chúng ta đã tìm hiểu, XML là ngôn ngữ định dạng thiên về mô tả cấu trúc dữ liệu và
định nghĩa ngôn ngữ. Bản thân dữ liệu XML tự nó không thể hiện định dạng cho tài liệu
như HTML. Chúng ta phải có cách nào đó chuyển dữ liệu XML thành tài liệu xem được
bởi người dùng. Để làm được điều này ngoài cách sử dụng CSS,DOM,DSO,SAX chúng
ta còn sử dụng ngôn ngữ chuyển dịch tổng quát hơn đó là XSLT (Extendsion Style
Language).
XSLT là ngôn ngữ định kiểu mở rộng. Tương tự CSS, XSLT thực hiện nhiệm vụ biến đổi
dữ liệu của XML để hiển thị cho phía người dùng cuối một tài liệu đã định dạng tương tự
HTML.
Nhiệm vụ của XSLT là trích rút dữ liệu XML đưa vào khuôn dạng HTML.
Một tài liệu của XSLT phải được viết theo đúng cú pháp và hợp khuôn dạng với quy tắc
XML.
Chúng ta xem xét ví dụ sau để xem XSLT rút trích dữ liệu XML như thế nào và kết quả
được hiển thị như hình 6-1.
Hide your heart
- 54 -
Bonnie Tyler
UK
CBS Records
9.90
1988
Lưu file này với tập tin catalog.xml và đây là tập tin catalog.xslt.
<xsl:stylesheet version="1.0"
xmlns:xsl="">
My CD Collection
Title
Artist
- 55 -
Price
- 56 -
hình 5-1 Sử dụng XSLT để rút trích tài liệu XML
- 57 -
I. Tạo tài liệu XSLT
1. Tài liệu XSLT yêu cầu tiếp nhận dữ liệu XML theo cấu trúc cây, thực hiện
biến đổi và cho ra một tài liệu định dạng cũng theo cấu trúc hình cây khác. Ở gốc
độ tài liệu XSLT, dữ liệu đầu vào là một tập hợp các nút (node) có 7 loại nút mà
bộ xử lý XSL có thể nhận dạng và chuyển dịch là:
Gốc tài liệu (root document) Nơi khởi đầu của tài liệu cần chuyển dịch.
Thuộc tính (Atribute) Nắm giữ thuộc tính của phần tử thẻ, giá trị
thuộc tính đã loại bỏ dấu bao chuỗi.
Chú thích (Comment) Nắm giữ dữ liệu của chuỗi văn bản chú
thích
Phần tử (Element) Bao gồm thẻ tên của phần tử và tập các
phần tử con giữa thẻ đóng và thẻ mở nếu có
Không gian tên (Namespace) Nằm giữa chuỗi định danh URI của không
gian tên
Chỉ thị xử lý (Processing instruction) Nắm giữ nội dung chuỗi chỉ thị xử lý đã
loại bỏ hai ký tự định dạng
Văn bản (text) Dữ liệu thuần text nằm giữa thẻ đóng và
thẻ mở
II. Các phần tử (Element) của XSLT:
1. Element
XSL định nghĩa một số lệnh chế biến (processing commands) để trích dữ liệu
ra từ một tài liệu XML và hòa nó vào một hồ sơ kết quả. Cái lệnh căn bản và hữu
dụng nhất trong số này là lệnh value-of. Lệnh value-of chọn trị số (value) của một
- 58 -
Element hay Attribute nào đó trong XML và hòa nó với hồ sơ output.
Lệnh value-of có dạng một XML Element trong XSL. Nó dùng một Attribute tên
select có value là một XPath Location Path để trích ra một Node. Kết quả là value
của (value-of) Node ấy. bây giờ ta có thể trình bày dữ liệu của XML với lệnh
value-of như sau:
<xsl:stylesheet version=”1.0”
xmlns:xsl=””>
My CD Collection
Title
Artist
- 59 -
hình 5-2 Rút trích dữ liệu XML sử dụng element
2. Element
- 60 -
Trong một tài liệu XML, có thể có nhiều Elements mang cùng một tên để nói
đến một danh sách những thứ tương tự. Thí dụ trong tài liệu đặt hàng có hai
Element Item để diễn tả hai món hàng được đặt.
Hầu hết ngôn ngữ lập trình cho ta phương tiện để áp dụng cùng một cách chế
biến cho mọi món trong nhóm. Như trong Visual Basic ta có FOR loop hay DO
loop để iterate qua từng món trong bộ. Trong XSL cũng thế, bạn có thể dùng lệnh
for-each để đi lần lượt qua từng Element trong nhóm, bằng cách dùng Attribute
select để chỉ định những nodes mà bạn muốn làm việc.
Thí dụ:
<xsl:stylesheet version="1.0"
xmlns:xsl="">
My CD Collection
Title
Artist
- 61 -
- 62 -
hình 5-3 Rút trích dữ liệu XML sử dụng element
3. Các câu lệnh điều kiện
- 63 -
Element
Cú pháp sử dụng:
...
...some output if the expression is true...
...
Thí dụ:
<xsl:stylesheet version="1.0"
xmlns:xsl="">
My CD Collection
Title
Artist
- 64 -
- 65 -
Hình 5-4 Rút trích dữ liệu XML sử dụng điều kiện if.
Chương VI: Chương Trình Ứng Dụng
I. Phân tích thiết kế
- 66 -
1. Thiết kế cơ sở dữ liệu:
1.1 Mô hình thiết kế:
a. ERD Phisical:
Hình 6-1 Mô hình ERD Phisycal
b.ERD Logical
- 67 -
Hình 6-2 Mô hình ERD Logical
c. Mô hình Diargam
- 68 -
Hình 6.3 Mô hình Diagram
1. 2 Mô tả các bảng:
a. Account table:
STT Thuộc tính Loại
Kiểu
dữ
liệu
MGT Ràng buộc Ý nghĩa
1
Col_account
_id
Khóa chính long Tự tăng
Id tài
khoản
2 Col_fullname nvarch Not null Họ và tên
- 69 -
ar người
dùng
3
Col_usernam
e
nvarch
ar
Not null & không
trùng
Tên đăng
nhập
4 Col_pass
nvarch
ar
Not null
Mật khẩu
người
dùng
5 Col_email
nvarch
ar
Not null phải có dạng
abc@phuongduy.com
Địa chỉ
email
6 Col_address
nvarch
ar
Not null
Địa chỉ
người
dùng
7 Col_phone
nvarch
ar
Not null
Số điện
thoại
người
dùng
8
Col_date_of_
birth
nvarch
ar
Ngày sinh
b. Category table:
STT Thuộc tính Loại
Kiểu dữ
liệu
Miền giá
trị
Ràng
buộc
Ý nghĩa
- 70 -
1 Col_category_id
Khóa
chính
long Tự tăng
Mã danh
mục
2 Col_lang nvarchar
(vie or
eng)
Ngôn
ngữ
3 Col_name nvarchar Not null
Tên danh
mục
4 Col_visible Bit Not null
Kích hoạt
danh mục
đó
5 Col_index long >0 Not null
Vị trí
danh mục
6 Col_parent long >0
Thuộc
danh mục
nào
C. Permission table:
STT Thuộc tính Loại
Kiểu dữ
liệu
Miền giá
trị
Ràng
buộc
Ý nghĩa
- 71 -
1 Col_permmision_id
Khóa
chính
long Tự tăng ID
2 Col_page_id
Khóa
ngoại
long Id trang
3 Col_edit int [0 1]
Quyền
được sửa
4 Col_add int [0 1]
Quyền
được
thêm
5 Col_del int [0 1]
Quyền
được xóa
6 Col_full int [0 1]
Toàn
quyền
7 Col_user_id
Khóa
ngoại
Id quản
trị
d. Product table:
STT Thuộc tính Loại
Kiểu dữ
liệu
Miền giá
trị
Ràng
buộc
Ý nghĩa
1 Col_product_id
Khóa
chính
long Tự tăng
Mã sản
phẩm
- 72 -
2 Col_uid nvarchar
Không
trùng
Sử dụng
để update
lại giá
3 Col_name nvarchar Not null
Tên sản
phẩm
4 Col_unit nvarchar Not null
Đơn vị
sản phẩm
5 Col_unit_currency nvarchar Not null
Đơn vị
tiền tệ
6 Col_category_id
Khóa
ngoại
long
Id danh
mục
7 Col_lang nvarchar Not null
Ngôn
ngữ
8 Col_description ntext Not null
Mô tả sản
phẩm
9 Col_detail ntext
Chi tiết
sản phẩm
10 Col_hot long
Sản
phẩm
được
mua
nhiều
- 73 -
nhất
11 Col_visible bit
Sản
phẩm
kích hoạt
chưa
12 Col_index long >0 Not null
Vị trí sản
phẩm
13 Col_Picture nvarchar Not null
Hình sản
phẩm
14 Col_price double Not null Giá
e. Price Product table:
STT Thuộc tính Loại
Kiểu dữ
liệu
Miền giá
trị
Ràng
buộc
Ý nghĩa
1 Col_id
Khóa
chính
long
Id của
bảng
2 Col_product_id
Khóa
ngoaij
nvarchar
Lấy uid
của sản
phẩm
Uid sản
phẩm
3 Col_price double >0 Not null
Giá sản
phẩm
- 74 -
4 Col_date datetime Not null
Ngày cập
nhật lại
giá
f. Product news table:
STT Thuộc tính Loại
Kiểu dữ
liệu
Miền
giá trị
Ràng
buộc
Ý nghĩa
1 Col_product_news_id
Khóa
chính
long Tự tăng Mã tin tức
2 Col_content ntext
Không
trùng
Chi tiết tin
3 Col_short_content ntext Not null
Sơ lược tin
tức
4 Col_category_id
Khóa
ngoại
long
Id danh
mục
5 Col_lang nvarchar Not null Ngôn ngữ
6 Col_hot long
Tin được
đọc nhiều
nhất
7 Col_visible bit
Tin kích
hoạt chưa
- 75 -
8 Col_index long >0 Not null Vị trí tin
9 Col_Picture nvarchar Not null
Hình tin
tức
g. Shopping cart table:
STT Thuộc tính Loại
Kiểu dữ
liệu
Miền
giá trị
Ràng
buộc
Ý nghĩa
1 Col_shopping_cart_id
Khóa
chính
long Tự tăng
Id giỏ
hàng
2 Col_uid nvarchar
Không
trùng &
tự sinh
Dùng để
sử dụng
cho giỏ
hàng
3 Col_account_id
Khóa
ngoại
long
Giỏ hàng
này của
ai
4 Col_total double >0 Not null
Tổng giá
trị của
giỏ hảng
đóa
5 Col_lang nvarchar Not null Ngôn
- 76 -
ngữ
6 Col_pay_form nvarchar Not null
Hình
thức
thanh
toán
7 Col_date datetime Not null
Ngày đặt
hàng
8 Col_close bit Not null
Thanh
toán
chưa
h. Shopping Cart Item table:
STT Thuộc tính Loại
Kiểu dữ
liệu
Miền
giá trị
Ràng
buộc
Ý nghĩa
1 Col_shopping_cart_id
Khóa
chính
nvarchar
Lấy giá
trị uid
của giỏ
hàng
Uid giỏ
hàng
2 Col_product_id
Khoá
chính
long
Id sản
phẩm
3 Col_quantity Int >0 Số lượng
sản
- 77 -
phẩm
4 Col_price double >0
Giá sản
phẩm
i. User table
STT Thuộc tính Loại
Kiểu dữ
liệu
Miền
giá trị
Ràng buộc Ý nghĩa
1 Col_user_id
Khóa
chính
long Tự tăng Id
2 Col_fullname nvarchar Not null
Họ và
tên
3 Col_username nvarchar Not null
Tên
đăng
nhập
4 Col_pass nvarchar Not null
Mật
khẩu
5 Col_email nvarchar
Not null kiểm tra
email hợp lệ
Địa chỉ
email
6 Col_address nvarchar Not null
Địa chỉ
người
quản trị
- 78 -
7 Col_phone nvarchar Not null
Số điện
thoại
người
quản trị
8 Col_date_of_birth nvarchar
Ngày
sinh
9 Col_sex int
Giới
tính
2. Mô hình UML:
2.1 Usecase Diagram:
a. usecase hệ thống:
- 79 -
Hình 6-4 Usecase hệ thống
b.Admin Usecase:
- 80 -
Hình 6-5 Usecase diagram admin
c.Usecase User:
- 81 -
Hình 6-6 Usecase diagram user
d.Shoppingcart usecase:
- 82 -
Hình 6-7 ShoppingCart Usecase
2.2 Sequences Diagram:
a. Sequence diagram đăng nhập:
- 83 -
Hình 6-8 Sequence Diagram đăng nhập.
b. Sequences Diagram Đăng ký:
- 84 -
Hình 6-9 Sequence diagram đăng ký
c. Shopping Cart Sequence diagram:
Khách hàng chọn sản phẩm sau đó nếu khách hàng muốn mua tiếp thì click vào
nút tiếp tục mua hàng nếu khách hàng chọn thanh toán thì hệ thông kiểm tra khách hàng
có đăng nhập chưa nếu khách hàng đã đăng nhập rùi thì hệ thống sẽ cập nhật giỏ hàng
của khách hàng và ngược lại thì hệ thống yêu cầu khách hàng phải đăng nhập nếu chưa là
thành viên thì có thể click vào nút đăng ký.
- 85 -
Hình 6-10 Shopping Cart Sequence diagram
2.3 Class diagram:
- 86 -
a. System Class diagram :
Hình 6-11 System class diagram
- 87 -
b.Class diagram Shopping cart:
Hình 6-12 Class diagram shoppingcart
c. Class diagram Login:
- 88 -
Hình 6-13 Class Diagram Login
II. Giao diện website:
1.Trang quản lý người dùng:
Cho phép người quản trị thêm mới, cập nhật và xóa user.
Chức năng thêm user chỉ thành công khi nhập đầy đủ thông tin cũng như vượt qua
các ràng buộc ví dụ như email phải có dạng abc@yahoo.com
- 89 -
hình 6-14 Quản lý người dùng
2. Trang đăng nhập:
Người quản trị hay user được phép thêm thông tin cũng như cập nhật sản phẩm, tin tức
thì bắt buộc người đó phải đăng nhập.
- 90 -
hình 6-15 Đăng nhập
3.Trang quản lý sản phẩm:
Hình 6-16 Quản lý sản phẩm
- 91 -
Cho phép người quản trị cập nhật cũng như thêm mới một sản phẩm.
4. Trang quản lý tin tức:
Hình 6-17 Quản lý tin tức
Cho phép người quản trị thêm mới cũng như cập nhật lại tin tức.
5.Trang quản lý danh mục:
- 92 -
Hình 6-18 Quản lý danh mục
Cho phép người quản trị thêm mới cũng như cập nhât lại danh mục sản phẩm.
6. Quản lý giỏ hàng khách hàng:
Hình 6-19 Quản lý giỏ hàng khách hàng
7.Cập nhật giá sản phẩm:
- 93 -
Hình 6-20 Cập nhật giá sản phẩm
Người quản trị chọn sản phẩm sau đó update lại giá cho sản phẩm đó.
8.Trang chủ:
- 94 -
Hình 6-21 Trang chủ
Giới thiệu sản phẩm các mặt hàng đang có trên thị trường cũng như cho phép
người dùng sử dụng những chức như xem chi tiêt mặt hàng đó hoặc là đặt hàng….
9.Trang tin tức
- 95 -
Hình 6-22 Trang tin tức
Cho phép người dùng đọc tin tức về nhưng sản phẩm trên thị trường.
10.Trang đăng ký thành viên
- 96 -
Hình 6-23 Đăng ký thành viên
Người dùng được phép đăng ký làm thành viên để đặt hàng và mua hàng trực
tuyến.
11.Chi tiết sản phẩm:
- 97 -
Hình 6-24 Chi tiết sản phẩm
12.Chi tiết tin tức:
hình 6-25 Chi tiết tin tức
- 98 -
Chương VII. Tổng Kết
II. Kết Luận:
Sau thời gian tìm hiểu và viết chương trình ứng dụng đề tài đã đạt được những
điều sau:
Xây dựng được một dịch vụ bán hàng tự động.
Có kiến thức cơ bản về nền tảng XML và XSLT cũng như công nghệ Web 2.0.
Có kiến thức cơ bản về thương mại điện tử.
III. Hướng phát triển:
Thêm tính năng thanh toán tự động thông qua thẻ tín dụng hoặc ATM.
Gửi mail đến người dùng trên internet (hiện tại chỉ gửi được mail cục bộ (POP3)
do chưa có mail server).
Hoàn thiện thêm các chức năng cũng như giao diện dễ cho người sử dụng.
IV. Tài liệu tham khảo
1. XML nền tảng và xây dựng – Tác giả Nguyễn Phương Lan – Nhà Xuất bản
giáo dục 2001.
2.
3.
4.
5.
ajax/Controls/Examples/Default/DefaultCS.aspx.
Các file đính kèm theo tài liệu này:
- Tìm hiểu về xml và xslt web 20 ứng dụng trong thương mại điện tử.pdf