- Một khía cạnh khác giúp để lại kinh nghiệm mua hàng thú vị cho khách hàng trực tuyến chính là giao diện: được hiểu là từ ngữ và hình ảnh mà người mua hàng sẽ tiếp xúc, thay vì người bán hàng thực sự. Trang chủ là trang thể hiện bộ mặt chính của ứng dụng, do vậy các chức năng phải được bố trí hợp lý, tiện lợi cho người dùng khi lựa chọn các chức năng đó
- Từ trang chủ người xem có thể liên kết đến các trang nội dung phải nhanh chóng dễ dàng và tiện lợi.
62 trang |
Chia sẻ: aloso | Lượt xem: 1615 | Lượt tải: 0
Bạn đang xem trước 20 trang tài liệu Đề tài Xây dựng website bán điện thoại di động – Minhphu mobile, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
ùng, thiết bị y tế chuyên dụng) và thương mại dịch vụ (như dịch vụ cung cấp thông tin, dịch vụ pháp lý, tài chính); các hoạt động truyền thống (như chăm sóc sức khoẻ, giáo dục) và các hoạt động mới (như siêu thị ảo)
2.1.2. Mục đích khi áp dụng thương mại điện tử
Mục đích khi doanh nghiệp áp dụng thương mại điện tử vào sản xuất và kinh doanh chính là mục đích căn bản của bài toán chúng ta đang xử lý.
Mục đích của một doanh nghiệp khi áp dụng thương mại điện tử là giảm thiểu chi phí trong doanh nghiệp. Các biện pháp nhằm để giảm thiểu chi phí trước tiên là bao gồm việc tối ưu hóa các quy trình kinh doanh đang tồn tại và thành lập các quy trình mới dựa trên nền tảng của các công nghệ Internet.
Thông qua việc tích hợp này của các tính năng doanh nghiệp dọc theo chuỗi giá trị, việc tiến hành kinh doanh có hiệu quả cao hơn. Các lợi thế cho doanh nghiệp có thể là:
Tiết kiệm chi phí đầu tư: Phí đầu tư tích hợp cổng tiết kiệm hơn so với việc thuê cửa hàng giới thiệu sản phẩm, văn phòng đại diện
Linh hoạt trong kinh doanh: Công nghệ cổng thanh toán cung cấp khả năng giải quyết các tình huống kinh doanh phức tạp, quản lý hiệu quả sản phẩm và thông tin khách hàng
Giúp cho các Doanh nghiệp nắm được thông tin phong phú về thị trường và đối tác
Giúp giảm chi phí sản xuất. Giúp giảm chi phí bán hàng và quảng cáo tiếp thị sản phẩm
Khả năng giao tiếp mới với khách hàng
Khách hàng hài lòng hơn
Nâng cao hình ảnh của doanh nghiệp
Khai thác các kênh bán hàng mới
Có thêm khách hàng mới
Tăng doanh thu, hiệu quả
2.1.3. Khái niệm về Website thương mại điện tử
Cửa hàng trực tuyến đưa hàng vào trong Internet để giới thiệu và bán. Đây là một chương trình phần mềm có tính năng giỏ hàng. Người mua chọn lựa các sản phẩm và đặt chúng vào giỏ hàng. Đằng sau một cửa hàng trực tuyến như thế là một việc kinh doanh thật sự, tiến hành các đơn đặt hàng.
Có nhiều chương trình phần mềm cho kênh bán hàng này. Một cửa hàng trực tuyến hiện đại không chỉ tạo khả năng cho người dùng xem món hàng hai chiều và đọc một ít thông số kỹ thuật của món hàng đó. Trong lãnh vực hàng tiêu dùng cao cấp người ta cũng đã tạo ảnh ba chiều của sản phẩm để cảm giác của khách hàng càng gần hiện thực càng tốt. Ngoài ra còn có các chương trình cấu hình mà qua đó màu sắc, trang bị và thiết kế của sản phẩm có thể thay đổi để phù hợp với tưởng tượng cá nhân của từng khách hàng. Bằng cách này người sản xuất hay người chào bán còn có thêm thông tin rất có giá trị về ý thích của khách hàng. Các hình thức được biết nhiều của thương mại điện tử là mua bán sách và nhạc cũng như mua bán đấu giá trong Internet.
Thông qua việc Internet bùng nổ vào cuối thập niên 1990, cửa hàng trực tuyến ngày càng có tầm quan trọng nhiều hơn. Những người bán hàng trong Internet có lợi thế là họ không cần đến một diện tích bán hàng thật sự mà thông qua các trang Web sử dụng một không gian bán hàng ảo. Các cửa hàng trực tuyến cũng thường hay không cần đến nhà kho hay chỉ cần đến rất ít, vì thường có thể cung cấp cho khách hàng trực tiếp từ người sản xuất hay có thể đặt hàng theo nhu cầu. Lợi thế do tiết kiệm được những phí tổn cố định này có thể được tiếp tục chuyển tiếp cho khách hàng. Ngay cả những người bán sách trong Internet tại Đức, bắt buộc phải bán sách theo giá cố định, cũng vẫn có lợi thế là - thông qua việc không thu tiền cước phí gửi - tiết kiệm được cho khách hàng một chuyến đi đến nhà bán sách mà vẫn có cùng một giá.
Các ngành hưởng lợi của xu hướng này, bên cạnh các cửa hàng trực tuyến, đặc biệt là các doanh nghiệp tiếp vận và các dịch vụ phân phối, trong khi các doanh nghiệp bán hàng nhỏ lẻ thường là những người thua cuộc trong biến đổi này. Ngành công nghệ thông tin cũng hưởng lợi gián tiếp từ tăng trưởng của thương mại Internet thông qua các đơn đặt hàng nhiều hơn cho việc cung ứng kỹ thuật cũng như bảo trì các cửa hàng trực tuyến.
2.2. Cơ sở lý thuyết để giải quyết bài toán
Ngày nay trên toàn thế giới có rất nhiều các công cụ lập trình giúp các lập trình viên xây dựng ứng dụng nhanh chóng và tiện lợi. Tuy nhiên xu thế hiện đang phân chia làm loại công cụ chính đó là:
Nhóm công cụ phát triển trên môi trường .NET của Microsoft như: Visual Studio 6.0, Visual Studio.NET, hệ quản trị CSDL SQL server, Microsoft Access
Nhóm công cụ mã nguồn mở phát triển trên môi trường Java như: Java, Jdeveloper , Jbuilder, JSP, Struts, Oracle…
Mỗi nhóm công cụ đểu có những ưu điểm và nhược điểm khác nhau, tùy theo mức độ, phạm vi và thói quen của người lập trình mà lựa chọn công cụ phù hợp để xây dựng ứng dụng.
Trong đề tài này tôi sử dụng công cụ lập trình Web ASP và hệ quản trị cơ sở dữ liệu Access để xây dựng trang web bán hàng di động.
2.2.1. Công cụ để tiến hành giải quyết bài toán
2.2.1.1. Công cụ quản lý cơ sở dữ liệu Access
a. Một số khái niệm
Một trong những tài sản lớn nhất mà ASP có được là khả năng thâm nhập vào các cơ sở dữ liệu. ASP thường làm việc với hai người bạn đồng nghiệp là Access và hệ cơ sở dữ liệu SQL.Component rất hữu ích giúp chúng ta có thể kết nối vào một cơ sở dữ liệu bằng cách sử dụng ActiveX Data Object để viết nội dung lên màn hình trình duyệt và tạo lập hoặc cập nhật các file cơ sở dữ liệu. Cơ sở dữ liệu là một phần không thể thiếu của một bài toán quản lý áp dụng công nghệ thông tin. Cơ sở dữ liệu được định nghĩa là kho thông tin về một chủ đề, được tổ chức hợp lý để dễ dàng quản lý và truy tìm. Bất kỳ kho thông tin nào đáp ứng được yêu cầu này đều có thể coi là một cơ sở dữ liệu.
b. Quản trị cơ sở dữ liệu
Chương trình quản trị cơ sở dữ liệu là một chương trình ứng dụng trên máy tính có các công cụ để truy tìm, sửa chữa, xoá và chèn thêm dữ liệu. Các chương trình này cũng có thể dùng để tạo lập một cơ sở dữ liệu và tạo ra các báo cáo, thống kê. Các chương trình quản trị cơ sở dữ liệu liên quan khá thông dụng hiện nay tại Việt Nam là Foxpro, Access cho ứng dụng nhỏ, DBL, MSSQL và Oracle cho ứng dụng vừa và lớn.
Cơ sở dữ liệu (database): kho thông tin về một chủ đề, được tổ chức hợp lý để dễ dàng quản lý và truy tìm. Bất kỳ kho thông tin nào đáp ứng được yêu cầu này đều có thể coi là một cơ sở dữ liệu (CSDL). Như trên đây, bạn có hai cơ sở dữ liệu: CSDL người quen ghi trong sổ và CSDL trên máy tính. Thông thường, những thông tin trong CSDL được chia thành nhiều mẫu tin có cấu trúc tương đối giống nhau
Bảng (table): Là một thành phần cơ bản trong chương trình quản trị cơ sở dữ liệu quan hệ. Bảng được hình thành khi sắp xếp các thông tin có liên quan với nhau theo hàng và cột. Các hàng tương ứng với các bản ghi (record) dữ liệu và các cột tương ứng với trường dữ liệu. Các bạn hãy xem bảng Người quen. Các hàng là người, mỗi hàng tương ứng với một người. Các cột là trường (hay lĩnh vực) của thông tin. Ta có các cột Họ tên, Ngày sinh, Điện thoại, Địa chỉ, Tên cơ quan.
Bản ghi (record): trong chương trình quản trị cơ sở dữ liệu, đây là một đơn vị hoàn chỉnh nhỏ nhất của dữ liệu, được lưu trữ trong những trường hợp dữ liệu đã được đặt tên. Trong một cơ sở dữ liệu dạng bảng, bản ghi dữ liệu đồng nghĩa với hàng (row). Bản ghi chứa tất cả các thông tin có liên quan với mẫu tin mà cơ sở dữ liệu đang theo dõi. Ví dụ, trong cơ sở dữ liệu về Người quen, bản ghi sẽ liệt kê tên người quen, số điện thoại, ngày sinh, địa chỉ và tên cơ quan. Hầu hết các chương trình đều hiển thị các bản ghi dữ liệu theo hai cách: theo các mẫu nhập dữ liệu và theo các bảng dữ liệu. Các bản ghi dữ liệu được hiển thị dưới dạng các hàng ngang và mỗi trường dữ liệu là một cột.
Trường dữ liệu (field): trong chương trình quản trị cơ sở dữ liệu, đây là không gian dành cho một mẫu thông tin trong bản ghi dữ liệu. Trong chương trình quản trị CSDL dạng bảng với dữ liệu được tổ chức theo hàng và cột, thì trường dữ liệu tương ứng với các cột. Như ở bảng Cơ quan, ta có các trường Tên cơ quan, Địa chỉ, Thành phố, Số điện thoại, Lĩnh vực hoạt động.
Quản lý cơ sở dữ liệu quan hệ: là một cách quản lý cơ sở dữ liệu, trong đó dữ liệu được lưu trữ trong các bảng dữ liệu hai chiều gồm các cột và các hàng, có thể liên quan với nhau nếu các bảng đó có một cột hoặc một trường chung nhau.Chương trình quản trị cơ sở dữ liệu: một chương trình ứng dụng trên máy tính cung cấp các công cụ để truy tìm, sửa chữa, xóa và chèn thêm dữ liệu. Các chương trình này cũng có thể dùng để thành lập một cơ sở dữ liệu và tạo ra các báo cáo, thống kê. Các chương trình quản trị cơ sở dữ liệu liên quan khá thông dụng hiện nay tại Việt Nam là Foxpro, Access cho ứng dụng nhỏ, DB 2, MS SQL và Oracle cho ứng dụng vừa và lớn.
Quản trị cơ sở dữ liệu Microsoft Access quan hệ là một cách quản lý cơ sở dữ liệu trong đó dữ liệu được lưu trữ trong các bảng dữ liệu hai chiều gồm các cột và các hàng, có thể liên quan với nhau nếu các bảng đó có một cột hoặc một trường chung nhau.
Hệ quản trị cơ sở dữ liệu Microsoft Access là một quá trình xử lý xoay quanh các vấn đề sau đây:
Lưu trữ dữ liệu
Truy nhập dữ liệu
Bảo đảm tính toàn vẹn của dữ liệu
Ba vấn đề chính ở trên có mối quan hệ mật thiết, phụ thuộc lẫn nhau và chúng được liệt kê theo thứ tự thực hiện mỗi ứng dụng.
Mô hình cơ sở dữ liệu quan hệ (Relationship Database Management System - RDMS) được xây dựng làm đơn giản hoá quá trình lưu và đọc dữ liệu RDMS cung cấp khả năng giao tiếp tốt với dữ liệu và giúp người lập trình tự do trong lĩnh vực quản lý truy cập cơ sở dữ liệu.
Sau đây là các bước xây dựng một cơ sở dữ liệu theo mô hình cơ sở dữ liệu quan hệ:
Tổ chức dữ liệu theo nhóm logic (table)
Xác định các mối quan hệ giữa các table
Tạo tập tin cơ sở dữ liệu và định nghĩa cấu trúc của các table trong cơ sở dữ liệu.
Lưu dữ liệu
Hai bước đầu là hai bước thiết kế cơ sở dữ liệu và đây là hai bước cực kỳ quan trọng. Nếu được thiết kế tốt, các khía cạnh khác sẽ được giải quyết dễ dàng hơn; ngược lại việc khai thác cơ sở dữ liệu sẽ không hiệu quả và chương trình sẽ có những lỗi rất khó phát hiện.
Các bước chính khi tiến hành thiết kế một cơ sở dữ liệu:
Xác định dữ liệu cần trong ứng dụng
Xác định nguồn gốc dữ liệu
Tổ chức dữ liệu thành các nhóm logic
Tiêu chuẩn hoá dữ liệu và các mối quan hệ giữa chúng
Xác định cách sử dụng các bảng
2.2.1.2. Công cụ lập trình Website
a. Ngôn ngữ HTML
Sơ lược về HTML
HTML là ngôn ngữ định dạng, hay đánh dấu. HTML là viết tắt của HyperText Markup Language (ngôn ngữ đánh dấu siêu văn bản). Một Một tập tin .html (file) được đánh dấu bằng các thẻ (tag). Các thẻ HTML sẽ quy định cách hiển thị trên trình duyệt. HTML cho phép người ta đọc được chúng trên máy của mình qua mạng bằng trình duyệt Web.Thẻ là một đoạn mà được giới hạn bởi dấu ngoặc nhọn ''. HTML thực hiện định dạng tập tin HTML trên màn hình. HTML không đưa ra bất cứ mô tả nào về font, hình ảnh đồ hoạ và chỗ để đặt chúng. HTML chỉ gán thẻ cho nội dung tập tin với những thuộc tính nào đó mà sau đó chúng được xác định bởi trình duyệt để xem tập tin này. File định dạng HTML phải được ghi lại với phần mở rộng là .html hoặc .htm
HTML gán thẻ cho kiểu chữ, chèn file ảnh đồ hoạ, âm thanh, video vào văn bản, tạo ra mối liên kết bằng hình thức gọi là siêu văn bản. Siêu văn bản là đặc tính quan trọng nhất của ngôn ngữ HTML, điều này có nghĩa là một đoạn văn bản hay đồ hoạ bất kỳ nào cũng có thể liên kết với một tài liêụ HTML khác.
Ngôn ngữ HTML chính thức là một bộ đặc biệt bao gồm các thẻ, mà tất cả các trình duyệt đều có thể hiểu được. Một số trình duyệt còn có thể biên dịch được những thẻ bổ sung ngoài phần tiêu chuẩn. Theo thời gian, bộ chuẩn được cập nhật những thẻ mới. Để soạn thảo một file HTML chúng ta có thể dùng bất kỳ một trình soạn thảo đơn giản nào (notepad, pspad, word,...).
Các thẻ cơ bản của HTML
Có hai loại thẻ cơ bản: thẻ mang thông tin (container tag) và thẻ rỗng (empty tag).
Thẻ rỗng là một thẻ không tác động lên cái gì cả. Chúng thường một mình thùc hiện một nhiệm vụ rất đặc biệt, không ảnh hưởng đoạn chữ nào. Ví dụ, tạo một đường kẻ ngang.
Đối với thẻ mang thông tin, khi có một thẻ mở thì phải có một thẻ đóng tương ứng, thẻ đóng giống như thẻ mở nhưng trước nó có gạch chéo (/). Ví dụ, thẻ mở cho kiểu chữ in nghiêng là , và thẻ đóng tương ứng là .
Cấu trúc cơ bản của một trang HTML
…………..
b. Ngôn ngữ ASP (Active Server Page)
Khái niệm ASP (Active Server Page)
Microsoft Active Server Pages (ASP) không hẳn là một ngôn ngữ lập trình , Microsoft gọi ASP là môi trường kịch bản trên máy chủ (Server-Side Scripting Enviroment), môi trường này cho phép tạo và chạy các các ứng dụng Web server động , tương tác và có hiệu quả cao. Các đoạn chương trình nhỏ được gọi là Script sẽ được nhúng vào các trang của ASP phục vụ cho việc đóng mở và thao tác với dữ liệu cũng như điều khiển, có tính bảo mật cao và làm tăng khả năng giao tiếp của chương trình ứng dụng. Ðể làm việc trong môi trường này , các ASP coder thường sử dụng VBScript hoặc JavaScript, cả hai loại này đều tự động hỗ trợ ASP
Các đoạn ASP script có thể xuất hiện ở mọi nơi trong trang HTML, ASP & HTML có sự gắn bó chặt chẽ với nhau. Với ASP ta có thể chen các script thực thi được vào trực tiếp các file HTML . Khi đó việc tạo ra trang HTML và xử lý script trở nên đồng thời, điều này cho phép tạo ra các tương tác của Web site một cách linh hoạt uyển chuyển , có thể chen các thành phần HTML động vào trang Web tùy vào từng trường hợp cụ thể. ASP cung cấp một môi trường cho các công cụ đặc tả và phân tích các script trong một file .ASP để các công cụ này xử lý. ASP còn cho phép viết hoàn chỉnh các thủ tục để phát triển Web bằng nhiều ngôn ngữ Script mà trình duyệt có thể hiểu được tất cả. Trên thực tế, vài ngôn ngữ Script được sử dụng trong một file và nó được thực hiện bằng cách định nghĩa ngôn ngữ Script trong một trang của HTML tại nơi bắt đầu thủ tục Script.
ASP xây dựng các file ở khắp nơi với phần đuôi mở rộng là *.asp. File .asp là một file text và có thể bao gồm các sự kết hợp sau:
Text
Các trang của HTML
Các câu lệnh của Script
Mô tả của ASP
Cách hoạt động của mô hình ASP được mô tả tóm tắt qua 3 bước sau:
Một ASP bắt đầu chạy khi trình duyệt yêu cầu một file. asp cho Web Server.
File. asp đó được nạp vào bộ nhớ và thực hiện (tại máy chủ). Các đoạn chương trình Script trong file. asp đó có thể là mở dữ liệu, thao tác với dữ liệu để lấy những thông tin mà người dùng cần đến. Trong giai đoạn này, file. asp đó cũng xác định xem là đoạn script nào chạy trên máy người sử dụng.
Sau khi thực hiện xong thì kết quả thực hiện của file. asp đó sẽ được trả về cho Web Server Browser của người sử dụng dưới dạng trang Web tĩnh.
Cú pháp của ASP: ASP không phải là ngôn ngữ Scripting mà thực ra nó cung cấp một môi trường để xử lý các Script có trong trang HTML. Sau đây là một số quy tắc và cú pháp của ASP.
Phân định ranh giới (Delimiter): Các trang của HTML được phân định với text dựa vào các phân định ranh giới. Một phân định ranh giới là một ký tự hay các thứ tự đánh dấu điểm bắt đầu và kết thúc của một đơn vị. Trong trường hợp của HTML, các ký hiệu ranh giới (). Tương tự, các lệnh của Script ASP và các biểu thức đầu ra được phân biệt giữa text và các trang HTML bằng các phân định ranh giới ASP sử dụng phân định ranh giới là để chứa các lệnh Script. VD: tức là gán giá trị football cho biến sport. ASP sử dụng phân định ranh giới là để chứa các biểu thức đầu ra. Như VD trên, biểu thức đầu ra sẽ gửi giá trị football (giá trị hiện thời của biến) cho trình duyệt.
Các tính chất và ưu điểm của ASP
Các ASP script thông thường chạy trên các server cài IIS ( Microsoft Internet Information Server). Nhưng ASPvẫn có thể làm việc với đa số các Web server trên NT (Netscape, Oreilly ) sử dụng ChiliSoft ASP, có thể trên một số hệ điều hành khác nh Linux, SunSolaris.
Quy trình thực hiện một của ASP như sau : khi một user thông qua trình duyệt web gửi yêu cầu tới một file .asp ở server thì script chứa trong file đó sẽ được chạy trên server và trả kết quả về cho browser đó. Khi Web server nhận được yêu cầu tới một file .asp thì nó sẽ đọc từ đầu tới cuối file .asp đó, thực hiện các lệnh script trong đó và trả kết quả về cho Web brower là một trang HTML.
Thực ra thì quá trình tạo trang HTML và thực thi script là hai quá trình riêng biệt, script sẽ được ASP engine dịch và thực thi trước khi chuyển kết quả cho Web server, tới giai đoạn này các mã HTML và kết quả sẽ kết hợp để tạo nên một trang Web. Việc nhúng HTML và script chỉ để làm đẩy nhanh tốc độ phát triển ứng dụng mà thôi. Do môi trường hoạt động là mạng nên một script ASP khi được viết ra có thể sử dụng được ở mọi nơi, không cần trình biên dịch hay kết nối.
Các ASP script được viết dựa trên các ngôn ngữ hướng đối tượng nên rất tiện lợi, sẵn có các object đi kèm như: Request, Response, Application, Server, Session. Tận dụng được các ActiveX components như : Database access , Content linking, Collaboration Data Object, Browser capabilities,File Access, ... Hơn nữa nó cũng có thể tận dụng được components từ các nhà phân phối khác, cung cấp dưới dạng các file .dll
Những tính chất trên đem đến cho ta những lợi ích xác thực, cho phép tạo ra các ứng dụng Web thương mại có tương tác chứ không chỉ đơn thuần là phổ biến các nội dung tĩnh. Ví dụ như để lưu giữ lại thông tin về các khách hàng đã ghé thăm qua web site của mình, các web builder có thế dùng asp để tạo ra các file cơ sở dữ liệu khách hàng lưu trên máy chủ, khi cần có thể tiện tra cứu.
• Các Objects & Components cơ bản
Object là những đoạn chương trình có khả năng thực hiện những công việc cơ bản nào đó. Mỗi object là một kết hợp giữa lập trình và dữ liệu mà có thể xử lý như một đơn vị thống nhất. Các ASP object cho phép chúng ta giao tiếp tương tác với cả máy chủ lẫn trình duyệt, thông thường chúng ta dùng vài object trong các scripts. Các object này đã sẵn có nên ta chỉ cần nhớ cách sử dụng chúng.
Request Object:
Request object cho phép lấy thông tin thông qua một HTTP request. Chúng ta có thể dùng Request object để đọc URL, truy cập thông tin từ một form, đọc cookies và các HTTP header.
Response Object:
Ressponse object là chìa khóa để gửi thông tin tới user, là đại diện cho phần thông tin do server trả về cho Web browser. Chúng ta có thể viết lên màn hình, tái định hướng các trang, tạo các cookies sử dụng Response object.
Application Object:
Sử dụng Application object chúng ta có thể điều khiển các đặc tính liên quan đến đến việc khởi động và dừng ứng dụng, cũng như việc lưu trữ các thông tin có thể được truy nhập bỏi các ứng dụng nói chung.
Server Object:
Server object cho phép thực thi một chuỗi các tác vụ chẳng hạn như ánh xạ một đường dẫn ảo tới một đường dẫn vật lý và tạo một instance của một componnet.
Session Object:
Sử dụng object này chúng ta có thể lưu thông tin liên quan tới từng user đã truy nhập vào site của bạn.
Khác với các object, các ASP components là các điều khiển ActiveX ghép nối với ASP để đơn giản hoá các thủ tục thông thường. Chúng ta sẽ lướt qua số components thường được sử dụng.
Browser Capabilities:
Component này cho phép xác định trình duyệt của user là gì và những tính năng nào được hỗ trợ bởi trình duyệt đó.
Collaboration Data Objects (CDO):
CDO được liên kết chặt chẽ vói IIS SMTP server, CDO hỗ trợ chúng ta gửi và nhận email. Ví dụ với CDO chúng ta có thể xử lý một form mà không cần nhận biết đó là Perl script hay CGI. CHƯƠNG III: PHÂN TÍCH VÀ THIẾT KẾ HỆ THỐNG
A: Phân tích sơ đồ phân cấp chức năng của hệ thống
3.1.1 Yêu cầu cần thiết của bài toán
Trang Web thương mại điện tử bán điện thoại di động – MINH PHÚ mobile phải đáp ứng những yêu cầu cần thiết sau:
Đối với các khách hàng khi truy cập vào trang Web:
- Trang web phải có mục riêng để giới thiệu về công ty, địa chỉ liên hệ…để
Khi họ truy cập vào trang Web họ có thể xem thông tin về công ty như: Quá trình hình thành, hoạt động kinh doanh, đối tác của công ty cũng như năng lực làm việc của công ty qua những hợp đồng đã ký kết. Thông tin về sản phẩm - dịch vụ, thông tin chi tiết từng sản phẩm cũng như tham khảo giá cả của các mặt hàng
- Trang web có phần tin tức về thị trường, thông tin khuyễn mãi… giúp khách hàng có đầy đủ thông tin, có thêm kiến thức nhằm giúp người mua chọn được sản phẩm ưng ý nhất.
- Yêu cầu được xem các thông tin về các sản phẩm, thông tin chi tiết về sản phẩm như tính năng, mẫu mã, kích thước của sản phẩm điện thoại …
- Chức năng tìm kiếm: Chức năng này giúp khách hàng nhanh chóng tìm được sản phẩm và các tin tức đã đăng.
- Chức năng đặt hàng qua trang Web: Điều quan trọng nhất là khách hàng còn đặt hàng hoá mà họ muốn. Đó là những thông tin cần thiết cho việc mua bán qua Website. Đây là phần quan trọng nhất của website thương mại điên tử, do vậy cần phải thiết kế sao cho khách hàng có thể chọn hàng và đặt được hàng theo yêu cầu của mình một cách dễ dàng thuận tiện và nhanh chóng. Phần này phải kết hợp với phần giới thiệu sản phẩm một cách linh hoạt giúp khách hàng có đầy đủ thông tin về sản phẩm trước khi chọn
- Ngoài ra họ có thể hỏi ý kiến của công ty về kỹ thuật mà họ muốn biết, đó là các vấn đề liên quan sử dụng, bảo quản, sửa chữa, chế độ bảo hành.
Đối với người quản trị, ban lãnh đạo công ty:
- Từ những đơn đặt hàng của công ty họ có thể theo dõi tình hình đặt mua sản phẩm của khách hàng, họ có thể kiểm tra các đối tượng khách hàng để từ đó có những hướng đi tốt cho công ty. Ngoài ra họ có thể cung cấp các thông tin về kỹ thuật khi khách hàng yêu cầu…
- Yêu cầu của website là người quản trị dễ dàng thêm, sửa, xoá thông tin, danh mục gồm: danh mục thông tin về sản phẩm và dịch vụ, danh mục tin tức và câu hỏi hỗ trợ, danh mục người quản trị, danh mục để quản lý các thông tin của thành viên….
- Chức năng xử lý đơn đặt hàng: Hiện thi được danh sách khách hàng đã đặt hàng, xoá đơn đặt hàng sai quy cách của khách hàng. Hiện thị đầy đủ thông tin giỏ hàng mà khách đã đăng ký mua.
Đối với bộ phận kinh doanh:
- Cần phải cập nhật và thay đổi các thông tin về sản phẩm - dịch vụ, thông tin thị trường, bảo hành…, Ngoài ra cần phải tập hợp các đơn đặt hàng của khách để xử lý.
3.1.2. Sơ đồ phân cấp chức năng
Sơ đồ phân cấp chức năng cho ta cái nhìn tổng quát về các chức năng chính của hệ thống, nó giúp xác định phạm vi của hệ thống cần phân tích và tăng cường cách tiếp cận logic tới phân tích hệ thống
Hệ thống bao gồm các chức năng chính:
- Quản lý bán hàng: giới thiệu các tính năng giá cả của sản phẩm
Với việc phân tích yêu cầu của bài toán theo các mục trên ta cần phải thiết kế Website gồm các chức năng chính sau: (Hình 3.1) Quản lý Website phu mobile
Quản lý bán hàng
Xem thông tin và chọn hàng
Tìm kiếm sản phẩm
Quản lý
thông tin
Giới thiệu công ty, liên hệ
Quản lý tin tức, giải trí,
Hỗ trợ giải đáp
khuyễn mãi, bảo hành
Đặt hàng
Quản lý đơn đặt hàng
Quản lý thành viên quản trị, members
Quản trị hệ thống
Cập nhật danh mục sản phẩm dich vụ
Quản lý liên kết quảng cáo
Quản lý đơn đặt hàng từ các khách hàng gửi đến
Hình 3.1: Sơ đồ chức năng của hệ thống website
Trong 1 số chức năng ta lại có thể có biểu đồ phân cấp thành những chức năng nhỏ hơn. Ví dụ như Biểu đồ phân cấp chức năng Tìm kiếm
Tìm Kiếm Sản Phẩm
Nhận thông tin cần tìm kiếm
Kiểm tra thông tin nhận được
Cung cấp thông tin tìm được
3.2. Thiết kế cơ sở dữ liệu
3.2.1. Sơ đồ luồng thông tin
Sơ đồ luồng thông tin được dùng để mô tả hệ thống thông tin theo cách thức động. Tức là mô tả sự di chuyển của dữ liệu, việc xử lý, việc lưu trữ trong thế giới vật lý bằng sơ đồ
Các ký pháp của sơ đồ luồng thông tin như sau:
- Xử lý
Thủ công Giao tác người - máy Tin học hoá hoàn toàn
- Kho lưu trữ dữ liệu
Thủ công Tin học hoá
- Dòng thông tin
Tài liệu
- Điều khiển
Từ những ký pháp trên, sau đây sẽ là sơ đồ luồng thông tin thể hiện hoạt động đặt hàng trên mạng (Hình 3.2):
Thời điểm
Khách hàng truy cập vào website
Hệ thống website
Phòng bán hàng
Bắt đầu vào trang web
Đặt hàng
Sau khi đặt mua hàng
Đơn đặt hàng
Giới thiệu hàng
Tổng hợp đơn đặt hàng
In đơn đặt hàng
Hoá đơn
Kiểm tra đơn đặt hàng
Đặt hàng
Giỏ hàng
Mua hàng
Sản phẩm
Tổng hợp đơn đặt hàng
Thông tin hàng
Cập nhật thông tin hàng
Hình 3.2: sơ đồ luồng thông tin thể hiện hoạt động đặt hàng trên mạng
3.2.2. Sơ đồ luồng dữ liệu
Sơ đồ luồng dữ liệu dùng để mô tả cũng chính hệ thống thông tin như sơ đồ luồng thông tin nhưng trên góc độ trừu tượng. Trên sơ đồ chỉ ra bao gồm Các luồng dữ liệu, các xử lý, các lưu trữ dữ liệu, nguồn và đích nhưng không hề quan tâm tới nơi, địa điểm và đối tượng chịu trách nhiệm xử lý. Sơ đồ luồng dữ liệu chỉ mô tả đơn thuần hệ thống thông tin làm gì và để làm gì.
Vai trò của luồng thông tin
Mô hình luồng dữ liệu cho ta một cái nhìn tổng thể về hệ thống có quan điểm cân xứng cho cả dữ liệu và quá trình. Nó chỉ ra các thông tin chuyển tiếp từ một quá trình hoặc chức năng nào trong hệ thống sang quá trình hoặc chức năng khác. Điều quan trọng nhất là nó chỉ ra cần có những thông tin vào trước khi cho nó thực hiện một chức năng hay quá trình.
Giải thích các ký hiệu
- Ký hiệu : Biểu thị luồng thông tin. Tên là một danh từ.
- Ký hiệu : Biểu thị chức năng xử lý thông tin.
Trong sơ đồ này được chỉ ra một chức năng hoặc một quá trình chức năng quan trọng trong mô hình luồng dữ liệu là biến đổi thông tin, nghĩa là thay đổi thông tin từ đầu vào theo một cách tạo nào đó như tổ chức lại thông tin mới. Tên chức năng trong biểu đồ luồng dữ liệu phải trùng tên với tên của chức năng trong biểu đồ phân cấp chức năng. Tên là động từ + bổ ngữ.
- Ký hiệu : Biểu thị cho các tác nhân ngoài.
Tác nhân ngoài là các tổ chức hoặc cá nhân nằm ngoài hệ thống nhưng có trao đổi trực tiếp với hệ thống, sự có mặt của các nhân tố này trên sơ đồ chỉ ra giới hạn của hệ thống, định rõ mối quan hệ của hệ thống với thế giới bên ngoài. Tên gọi là một danh từ
- Ký hiệu : Biểu thị kho dữ liệu.
Biểu diễn cho thông tin cần cất giữ sau đó để một hay nhiều chức năng sử dụng chúng trong một khoảng thời gian khai thác để lấy thông tin ra xử lý hoặc cập nhật chúng. Chúng có thể là một tệp dữ liệu được lưu trữ trong văn phòng hoặc được lưu trữ trong máy vi tính. Luồng dữ liệu ra vào kho có thể ghi hoặc không ghi. Không có những thông tin nối giữa hai kho. Tên kho là một danh từ + tính từ (có thể).
- Ký hiệu : Biểu thị tác nhân trong.
Tác nhân trong là một chức năng xử lý nào đó hoặc một hệ thống con của hệ thống đang xét có trao đổi thông tin và các chức năng trong mô hình được mô tả ở trang khác của quá trình. Mọi mô hình luồng dữ liệu đều có thể bao gồm nhiều trang thông tin được truyền giữa các trang khác nhau được chỉ ra nhờ ký hiệu này. Tên gồm động từ + bổ ngữ.
Các mức của DFD
- Sơ đồ ngữ cảnh (Context Diagram) thể hiện rất khái quát nội dung chính của hệ thống thông tin. Sơ đồ này không đi vào chi tiết, mà mô tả sao cho chỉ cần một lần nhìn là nhận ra nội dung chính của hệ thống. Để sao cho sơ đồ ngữ cảnh sáng sủa, dễ nhìn có thể bỏ phần các kho dữ liệu; bỏ qua các xử lý cập nhật. Sơ đồ khung cảnh còn được gọi là sơ đồ mức 0 (Hình 3.2)
Khách hàng
Đặt hàng
Thông tin
Công ty Minh Phu
Thông tin
Báo cáo
Hệ thống website TMĐT Minh Phu mobile
Hình 3.3: Sơ đồ mức 0
- Phân rã sơ đồ: Để mô tả hệ thống chi tiết hơn người ta dùng kỹ thuật phân rã (Explosion) sơ đồ. Bắt đầu từ sơ đồ khung cảnh, người ta phân rã ra thành sơ đồ mức 0, tiếp sau mức 0 là mức 1...
Thông tin của khách hàng
Đặt hàng
Thông tin sản phẩm, dich vụ
Công ty Minh Phu
Cập nhật thông tin sản phẩm, dich vụ
Báo cáo
Quản lý thông tin
Khách hàng
Liên hệ, hỏi đáp
Thông tin thị trường, tin phản hồi
Cập nhật thông tin
Kho dữ liệu
Quản quản trị hệ thống
Câp nhật
Quản lý bán hàng
Hình 3.4: Sơ đồ mức 1
3.2.3. Xác định danh sách các loại thực thể
3.2.3.1. Khái niệm về thực thể
Thực thể là khái niệm để biểu diễn các đối tượng trong ƯDTH. Thực thể không chỉ bao gồm những sự vật tồn tại một cách khách quan trong thực tế, mà thật ra thực thể còn được dùng cho cả những trường hợp trừu tượng ( Thời khoá biểu, công nợ, tồn kho…). Mỗi thực thể sẽ có những thuộc tính đặc trưng cho thực thể đó. Thuộc tính của một thực thể bao gồm có tên (name), kiểu dữ liệu (type) và bản số (cardinality).
3.2.3.2. Phương pháp xác định loại thực thể
Việc xác định các loại thực thể có thể được tiếp cận theo hai cách sau:
Tiếp cận theo kết xuất: dựa vào dữ liệu liên quan đến các báo cáo, hoá đơn, phiếu…Từ đó có thể xác định được các thuộc tính
Tiếp cận theo quy trình quản lý: dựa vào những mô tả về quy trình quản lý trong Hồ sơ khảo sát để xác định các thực thể.
3.2.3.3. Danh sách các loại thực thể trong ứng dụng
Dựa vào các kết xuất và sơ đồ nghiệp vụ trong phân khảo sát chúng ta có thể đưa ra được các thực thể cơ bản sau:
Thực thể Sản phẩm (SANPHAM)
SANPHAM
MASP
Mabac
Maloai
kieudang
Kichthuoc
baohanh
Tensp
Giasp
Gioithieu
Hinh
LUOTXEM
Ngayramat
tonkho
spnoibat
trongluong
phanloai
Hình 3.5: thực thể sản phẩm
Thực thể tin tức giải trí (tintuc)
Tintuc
matt
ndm
Tentt
Noidung
Ngaydt
Tacgia
chuthichnhanh
Nguoigui
Hinh
luotxem
Hình 3.6: thực thể tin tức giải trí
Thực thể danh mục nhóm (loaisp)
loaisp
Maloai
Tenloaisp
manhom
sott
logo
Hình 3.7: thực thể danh mục nhóm
Thực thể thông báo dịch vụ (thongbao)
thongbao
mathongbao
thongbao
Hình 3.8: thực thể thông báo dịch vụ
Thực thể Người sử dụng và quản trị (Members)
Members
Ten_dang_nhap
Mathanhvien
gioitinh
dienthoai
Dia_chi
email
Ho_ten
ngaythamgia
Mat_khau
Hình 3.9: thực thể người sử dụng và quản trị
Thực thể Hoá đơn đặt hàng (DONDH)
DONDH
ID
Hoten
Email
Diachi
dienthoai
NGAYDATHANG
Hình 3.10: thực thể hoá đơn đặt hàng
Thực thể Hoá quảng cáo (quangcao)
quangcao
Malogo
Hinh
link
Thực thể Hoá quảng cáo
3.2.4. Mối quan hệ giữa các thực thể
DONDH
Sanpham
Loaisp
Users
Đặt hàng
Thuộc
Hình 3.11: Sơ đồ mối quan hệ giứa các loại thực thể
Ta nhân thấy giữa các loại thực thể Hoa_don và Products xuất hiện mối quan hệ nhiều - nhiều, do vậy ta có thể tách thành các loại thực thể sau: (Hình 3.10)
DONDH
Dat_hang
sanpham
Đặt hàng
Bao gồm
Hình 3.12: Phân tích quan hệ nhiều-nhiều
3.2.5. Mô tả dữ liệu
3.2.5.1. Các loại thực thể
Loại thực thể
Diễn giải
DONDH
Hoá đơn đặt hàng
CHITIETDONHANG
Nội dung phiếu đặt hàng
sanpham
Sản phẩm
LOAISP
Danh mục nhóm
TINTUC
Tin tức, giải trí
Các thực thể phụ và thực thể hệ thống
quangcao
Danh mục các quảng cáo của trang
Thongke
Đếm số lần truy cập trang
TINTUC
Tin vắn quảng cáo, giải trí
Thongbao
Các thông báo của trang
Members
Người quản trị hệ thống và khách
3.2.5.2. Mô tả các loại thực thể
Thực thể DONDH
Thuộc tính
Diễn giải
Kiểu
Kích thước
P P: Primary key (khóa chính)
M: Mandatory (không được rỗng)
M
SODDH
Số hoá đơn
AutoNumber
8
x
x
MATHANHVIEN
Number
x
Hoten
Họ tên người đặt hàng
Text
50
x
Gioitinh
Giới tính
Text
10
x
Diachi
Địa chỉ
Text
50
x
PHONE
Điện thoại
Text
12
x
Email
Email
Text
50
x
FAX
Text
20
THANHTOAN
Thanh toán
Text
50
x
DIACHINHAN
Địa chỉ nhận hàng
Text
50
x
TGIANNHAN
Thời gian nhận
Text
x
GHICHU
Memo
NGAYDATHANG
Ngày đặt
Date/time
x
TRANGTHAI
Xác nhận đơn hàng
Yes/No
x
Thực thể CHITIETDONHANG
Thuộc tính
Diễn giải
Kiểu
Kích thước
P
M
ID
Mã phiếu đặt
AutoNumber
8
x
x
SODDH
Mã hàng đã đặt
Number
8
x
MASP
Mã các sản phẩm
Number
8
x
SLDAT
Số lượng đặt
Number
4
x
Thực thể sanpham (Sản phẩm)
Thuộc tính
Diễn giải
Kiểu
Kích thước
P
M
MASP
Mã sản phẩm
Number
8
x
x
TENSP
Tên sản phẩm
Text
250
x
GIOITHIEU
Giới thiệu
Memo
x
TINHNANGKHAC
Chi tiết về sản phẩm
Memo
x
GIASP
Giá cũ trước khuyến mãi
Number
x
MALOAI
Giá bán của sản phẩm
Number
x
Baohanh
Thời gian bảo hành
Text
20
x
KHUYENMAI
Khuyến mại sản phẩm
Text
10
Phukien
Phụ kiện kèm theo
Text
255
x
Ghichu
Ghi chú
Memo
Kichthuoc
Kích thước
Text
50
x
Trongluong
Trọng lượng
Text
50
SPNOIBAT
Sản phẩm nổi bật
Yes/No
x
TONKHO
Trạng thái
Number
2
x
NGAYRAMAT
Ngày ra mắt
Date/Time
x
SOLUONGNHAP
Ngôn ngữ
Number
8
x
LUOTXEM
Số lần xem sản phẩm
Number
8
x
Thực thể Tin tức (tintuc)
Thuộc tính
Diễn giải
Kiểu
Kích thước
P
M
MATT
Mã tin tức
Number
8
x
x
MALT
Mã loại tin
Text
250
x
TENTT
Tên bài tin tức
Memo
x
NOIDUNG
Nội dung tin bài
Memo
x
NDM
Tin chú ý
Yes/No
x
HINH
Hình ảnh tin đăng
Text
20
x
NGAYDT
Ngày gửi
Date/Time
x
NGUOIGUI
Người gửi
Text
50
x
TACGIA
Tác giả
Text
50
LUOTXEM
Lượt xem tin bài
Number
4
Thực thể quảng cáo
Thuộc tính
Diễn giải
Kiểu
Kích thước
P
M
MALOGO
Mã logo
Number
8
x
x
HINH
Hình logo
Text
255
x
LINK
Link quảng cáo
Text
255
x
Thực thể LOAISP
Thuộc tính
Diễn giải
Kiểu
Kích thước
P
M
MALOAI
Mã loại
Number
8
x
x
TENLOAISP
Tên loại sản phẩm
Text
100
x
MANHOM
Mã nhóm
Number
4
x
LOGO
Logo của loại sản phẩm
Text
100
x
STT
Số thứ tự
Number
2
x
Thực thể Members
Thuộc tính
Diễn giải
Kiểu
Kích thước
P
M
MATHANHVIEN
Mã người quản trị
Number
8
x
x
TEN_DANG_NHAP
Tên đăng nhập
Text
50
x
MAT_KHAU
Mật khẩu
Text
20
x
HO_TEN
Tên thật
Text
50
x
DIEN_THOAI
Điện thoại
Text
20
x
GIOITINH
Giới tính
Text
10
x
Email
Email đăng ký
Text
50
x
NGAYTHAMGIA
Date/Time
x
DIA_CHI
Địa chỉ
Text
50
NDM
Thuộc nhóm quyền hạn
Text
10
x
Thực thể nhóm sản phẩm (NHOMSP)
Thuộc tính
Diễn giải
Kiểu
Kích thước
P
M
MANHOM
Mã nhóm
Number
2
x
x
TENNHOM
Tên Nhóm
Text
255
x
STT
Số thứ tự
Number
2
x
Thực thể quangcao
Thuộc tính
Diễn giải
Kiểu
Kích thước
P
M
MALOGO
Mã Logo
Number
8
x
x
HINH
Text
50
x
LINK
Đường dẫn đến ảnh
Text
255
x
Thực thể thông báo (thongbao)
Thuộc tính
Diễn giải
Kiểu
Kích thước
P
M
MATHONGBAO
Mã thông báo
Number
4
x
x
THONGBAO
Nội dung thông báo
Memo
x
Thực thể loại tin tức (loaitintuc)
Thuộc tính
Diễn giải
Kiểu
Kích thước
P
M
MALT
Mã loại tin tức
Number
8
x
x
TENLT
Tên loại tin tức
Text
50
x
Thực thể liện hệ (LIENHE)
Thuộc tính
Diễn giải
Kiểu
Kích thước
P
M
MAEMAIL
Mã e mail
AutoNumber
8
x
x
HOTEN
Họ tên khách
Text
50
x
DIACHI
Địa chỉ
Text
50
x
EMAIL
Text
50
x
DIENTHOAI
Điện thoại
Text
50
NOIDUNG
Ý kiến của khách
Memo
x
3.2.6. Mô hình thực thể liên kết
Từ những phân tích trên ta xây dựng được mô hình thực thể liên kết dữ liệu của bài toán “Xây dựng website bán điện thoại di động – MINH PHÚ mobile”
Hình 3.6: Mô hình thực thể liên kết
CHƯƠNG IV: PHÂN TÍCH VÀ THIẾT KẾ CÁC THUẬT TOÁN
4.1. Phân tích thành các phần xử lý
4.1.1. Cơ sở phân tích và xác định các thành phần xử lý
4.1.1.1. Xác định danh sách các xử lý
Để xác định danh sách các xử lý của ứng dụng tin học, chúng ta có thể dựa trên hai cách tiếp cận theo kết xuất và theo quy trình nghiệp vụ.
Tiếp cận theo kết xuất
Trong cách tiếp cận này chúng ta xem xét từng kết xuất và tìm hiểu những xử lý nào cần được thực hiện để tạo ra những kết xuất của ứng dụng tin học.
Tiếp cận theo kết xuất có ưu điểm là trực quan, dễ thực hiện nhưng có khuyết điểm là kém linh hoạt, khó mở rộng.
Tiếp cận theo quy trình nghiệp vụ
Khi tiếp cận theo quy trình nghiệp vụ, chúng ta vận dụng phương pháp phân tích top – down. Xuất phát từ một công tác nghiệp vụ trong thực tế, chứng ta phân rã thành những xử lý con theo nhiều cấp bậc để tạo thành một cây xử lý.
4.1.1.2. Mô tả các xử lý trong chương trình
Mỗi xử lý trong danh sach cần phải được mô tả một cách rõ ràng. Nội dung mô tả một xử lý bao gồm: tên, chức năng, dữ liệu đầu vào, dữ liệu đầu ra.
4.1.2. Danh sách các xử lý của ứng dụng
Dựa và các sơ đồ phần rã chức năng, sô đồ nghiệp vụ, các kết xuất trong quá trình khảo sát, ta có thể đưa ra các chức năng xử lý của hệ thống như sau
Tên xử lý
Diễn giải
XL1
Đăng nhập hệ thống
XL2
Tạo Acount hệ thống
XL3
Cập nhật danh mục hàng hoá
XL4
Cập nhật danh mục tin tức, giải trí
XL5
Cập nhật danh mục download
XL6
Cập nhật danh mục menu (danh mục nhóm)
XL7
Cập nhật liên kết quảng cáo
XL8
Cập nhật banner trang chủ
XL9
Cập nhật tin nhanh quảng cáo
XL10
Xử lý đặt hàng
XL11
Thống kê danh sách đặt hàng
XL12
Thuật toán tìm kiếm
4.2. Các thuật toán chính của đề tài
4.2.1. Thuật toán đăng nhập vào hệ thống (login)
Dữ liệu đầu vào
Sơ đồ xử lý
TEN_DANG_NHAP,
MAT_KHAU
Kiểm tra hợp lệ
Đăng nhập
Thông báo lỗi
Lưu phiên làm việc
Members table
Sai
Đúng
Sử dụng hệ thống
Yêu cầu xử lý chức năng
Dữ liệu không được để trống.
Tên không xuất hiện các ký tự lạ.
Mật khẩu phải có ít nhất 4 ký tự và không có ký tự đặc biệt, tên không có dấu cách.
Nếu sai xuất thông báo lỗi yêu cầu đăng nhập lại.
Nếu đăng nhập thành công thì lưu lại thông tin đăng nhập cho phiên làm việc hiện tại.
4.2.2. Tạo Acount trong hệ thống
Dữ liệu đầu vào
Sơ đồ xử lý
TEN_DANG_NHAP,
MAT_KHAU,
HO_TEN,
MATHANHVIEN,
NGAYTHAMGIA,
EMAIL
Kiểm tra quyền
Đăng nhập
Thông báo lỗi
Nhập thông tin account
Members table
Sai
Đúng
Kiểm tra hợp lệ
Thông báo lỗi
Sai
Đúng
Yêu cầu xử lý chức năng:
Người sử dụng phải có quyền quản trị
Dữ liệu không được để trống.
Tên đăng nhập không xuất hiện các ký tự lạ, không có dấu cách.
Mật khẩu phải có ít nhất 4 ký tự và không có ký tự đặc biệt.
Nếu sai xuất thông báo lỗi yêu cầu đăng nhập lại.
Nếu thành công thì lưu lại thông tin vào bảng tài khoản
Khi sửa lại thông tin không được phép sửa tên tài khoản
4.2.3. Cập nhật danh mục hàng hoá
Dữ liệu đầu vào
Sơ đồ xử lý
TEN_DANG_NHAP,
MAT_KHAU,
Thông tin sản phẩm
Kiểm tra quyền
Đăng nhập
Thông báo lỗi
Nhập thông tin hàng hoá
Member
table
Sai
Đúng
Kiểm tra hợp lệ
Thông báo lỗi
Sai
Đúng
sanpham
table
Yêu cầu xử lý chức năng:
Người sử dụng phải có quyền quản trị
Dữ liệu không được để trống.
Tên đăng nhập không xuất hiện các ký tự lạ, không có dấu cách.
Nếu sai xuất thông báo lỗi yêu cầu đăng nhập lại.
Nếu thành công thì nhập thông tin sản phẩm
Kiểm tra tính hợp lệ nếu được thì lưu vào bảng sanpham
4.2.4. Cập nhật danh mục tin tức sản phẩm
Dữ liệu đầu vào
Sơ đồ xử lý
TEN_DANG_NHAP,
MAT_KHAU,
Nội dung tin tức hoặc tin giải trí hoặc giới thiệu công ty …
Kiểm tra quyền
Đăng nhập
Thông báo lỗi
Nhập nội dung thông tin
Member
table
Sai
Đúng
Kiểm tra hợp lệ
Thông báo lỗi
Sai
Đúng
tintuc
table
Yêu cầu xử lý chức năng:
Người sử dụng phải có quyền quản trị
Dữ liệu không được để trống.
Tên đăng nhập không xuất hiện các ký tự lạ, không có dấu cách.
Nếu đăng nhập sai xuất thông báo lỗi yêu cầu đăng nhập lại.
Nếu thành công thì nhập nôi dung thông tin cần đăng
4.2.5. Thuật toán tìm kiếm dữ liệu trong hệ thống
Dữ liệu đầu vào
Sơ đồ xử lý
Nội dung tin cần tìm,
loại tin cần tìm
Khách hàng
Nhập nội dung tin cần tìm và loại tin cần tìm
Tìm kiếm
Hiển thị kết quả
sanpham
table
Loại SP
Sai
Tìm Thấy
Không thấy
Báo không thấy
Yêu cầu xử lý chức năng:
Để mặc định mục cần tìm là tìm sản phẩm
Nếu không tìm thấy thì hiện thông báo không tìm thấy
Nếu tìm thành công thì hiển thị danh sách mục tìm thấy
4.2.6. Thuật toán đặt hàng
Dữ liệu đầu vào
Sơ đồ xử lý
Thông tin khách đặt hàng,
Mã hàng,
số lượng
Khách hàng
Chọn hàng
Đúng
sanpham
table
chọn tiếp
Sai
Hiển thị giỏ hàng
Nhập thông tin người đặt
DONDH ,Hoa_don
table
Yêu cầu xử lý chức năng:
Dữ liệu không được để trống.
Khách có thể chọn hàng ngay hoặc xem thông tin cụ thể của hàng trước khi chọn hàng
Khi khách hàng chon hàng hiện chi tiết thông tin giỏ hàng
Khách có thể quay lại chọn hàng tiếp những mặt hàng khác
Khi khách đặt mua phải yêu cầu nhập thông tin của khách
Sau khi đặt hàng xong phải hiện thông báo cho khách biết
CHƯƠNG V: THIẾT KẾ CHƯƠNG TRÌNH
5.1. Thiết kế các giao diện chính cho chương trình
5.1.1. Một số yêu cầu khi thiết kế giao diện ứng dụng
5.1.1.1. Các tính chất của hình giao diện
Tính đồng nhất
Tính thân thuộc, bắt mắt
Tính phong phú đa dạng của nội dung trình bày
Tính phong phú của thao tác xử lý
Tính cá nhân hóa
5.1.1.2. Các kỹ thuật
Cập nhật nội dung
Bổ sung thao tác
Tăng tốc độ nhập liệu
Xử lý các lỗi trong quá trình hoạt động
Thân thuộc hóa giao diện
Cá nhân hóa giao diện
5.1.2. Thiết kế các màn hình giao diện
5.1.2.1. Thiết kế trang chủ
Một khía cạnh khác giúp để lại kinh nghiệm mua hàng thú vị cho khách hàng trực tuyến chính là giao diện: được hiểu là từ ngữ và hình ảnh mà người mua hàng sẽ tiếp xúc, thay vì người bán hàng thực sự. Trang chủ là trang thể hiện bộ mặt chính của ứng dụng, do vậy các chức năng phải được bố trí hợp lý, tiện lợi cho người dùng khi lựa chọn các chức năng đó
Từ trang chủ người xem có thể liên kết đến các trang nội dung phải nhanh chóng dễ dàng và tiện lợi.
Hình 5.1: Màn hình trang chủ
5.1.2.2 Màn hình đăng nhập
Căn cứ theo các yêu cầu trong phần xử lý ta có thể xây dựng mục login vào tài khỏan của khách hàng và admin cùng nhau, và hệ thống sẽ tự check xem tài khỏan đó login với quyền hạn là khách hàng member hay là admin quản lý trang giao diện đăng nhập như sau:
Hình 5.2: Màn hình đăng nhập
5.1.2.3. Màn hình sản phẩm điện thoai
Hình 5.3: Màn hình sản phẩm điện thoại
5.1.2.4. Màn hình khi tài khoản login với quyền admin
Hình 5.4: Màn hình khi tài khoản login với quyền admin
5.1.2.5. Màn hình cập nhật sản phẩm mới
Hình 5.5: Màn hình cập nhật sản phẩm mới
5.1.2.6. Màn hình quản lý đơn đặt hàng
Hình 5.6: Màn hình quản lý đơn đặt hàng
5.1.2.7. Màn hình tin bài đã đăng
Hình 5.7: Màn hình tin bài đã đăng
5.1.2.8. Màn hình cập nhật, đăng tin tức
Hình 5.8 : Màn hình cập nhật, đăng tin tức
5.1.2.9. Màn hình xem danh sách khách hàng là thành viên đăng ký:
Hình 5.9: Màn hình danh sách khách hàng là thành viên
5.2. Một số đoạn mã chính của chương trình:
5.2.1. Kết nối cơ sở dữ liệu:
<%
filenameDB="..\Images\minhphumobile\minhphu.mdb"
%>
sub ketnoi(filename,cn)
set cn=server.CreateObject("adodb.connection")
cn.ConnectionString="Provider=Microsoft.Jet.OLEDB.4.0;Data Source = " & server.MapPath(filename)
cn.CursorLocation=3 'adUseClient
cn.Open
end sub
5.2.2. Mở cơ sở dữ liệu và hiển thị dữ liệu
<%
‘ Mở cơ sở dữ liệu
call ketnoi(filenameDB,cn) 'open ket noi
sql="SELECT * FROM LOAISP"
call MoRec(sql,cn,rs_LDT)
while not rs_LDT.EOF
sql="select top 1 * from SANPHAM where MALOAI=" & rs_LDT("MALOAI") & " order by NGAYRAMAT desc"
sql_UC="select top 1 * from SANPHAM where MALOAI=" & rs_LDT("MALOAI") & " order by TONKHO asc"
call MoRec(sql,cn,rs_DT)
call MoRec(sql_UC,cn,rs_DTUC)
if not rs_DT.BOF then
%>
‘ Phân trang và phân loại hiển thị nội dung
"" THEN Response.Write ("" & rs_LDT("LOGO") & "") ELSE Response.Write ("../images/Noimages.gif") %>" align="center" vspace="2" hspace="8">Hàng mới
nhập
Hàng bán chạy
. Giá bán : . Ngày ra mắt : ';return true" onmouseout="window.status='Chao mung ban den voi MINH PHÚ Mobile !';return true" href="dienthoaichitiet.asp?IDdienthoaichitiet=">
"" THEN Response.Write ("" & rs_DT("HINH") & "") ELSE Response.Write ("../images/Noimages.gif") %>" align="left" vspace="2" hspace="6" class="Images">
Giá: "0" THEN Response.Write ("" & rs_DT("GIASP") & " VND") ELSE Response.Write ("Chưa báo giá") %>
B.Hành: "" THEN Response.Write ("" & rs_DT("BAOHANH") & "") ELSE Response.Write ("Không") %>
Hiện tại:
. Giá bán : . Ngày ra mắt : ';return true" onmouseout="window.status='Chao mung ban den voi MINH PHÚ Mobile !';return true" href="dienthoaichitiet.asp?IDdienthoaichitiet=">
. Giá bán : . Ngày ra mắt : ';return true" onmouseout="window.status='Chao mung ban den voi MINH PHÚ Mobile !';return true" href="dienthoaichitiet.asp?IDdienthoaichitiet=">
"" THEN Response.Write ("" & rs_DTUC("HINH") & "") ELSE Response.Write ("../images/Noimages.gif") %>" align="left" vspace="2" hspace="6" class="Images">
Giá: "0" THEN Response.Write ("" & rs_DTUC("GIASP") & " VND") ELSE Response.Write ("Chưa báo giá") %>
B.Hành: "" THEN Response.Write ("" & rs_DTUC("BAOHANH") & "") ELSE Response.Write ("Không") %>
Hiện tại:
. Giá bán : . Ngày ra mắt : ';return true" onmouseout="window.status='Chao mung ban den voi MINH PHÚ Mobile !';return true" href="dienthoaichitiet.asp?IDdienthoaichitiet=">
<% end if
end if
end if
rs_LDT.movenext
wend
rs_LDT.close
set rs_LDT=nothing
rs_DT.close
set rs_DT=nothing
rs_DTUC.close
set rs_DTUC=nothing
%>
‘ quản lý chỉnh sửa sản phẩm
<%
call ketnoi(filenameDB,cn)
MASP=Request.QueryString("NDM")
NGUOIGUI=Session("HO_TEN")
MALOAI=Request.Form("cmbChungloai")
MABAC=Request.Form("cmbMABAC")
TENSP=Trim(Request.Form("txtTENSP"))
GIOITHIEU=Request.Form("txtGIOITHIEU")
HINH=Trim(Request.Form("txtHINH"))
NGAYRAMAT=Trim(Request.Form("txtNGAYRAMAT"))
GIASP=Trim(Request.Form("txtGIASP"))
KICHTHUOC=Trim(Request.Form("txtKICHTHUOC"))
TRONGLUONG=Trim(Request.Form("txtTRONGLUONG"))
KIEUDANG=Trim(Request.Form("txtKIEUDANG"))
BAOHANH=Trim(Request.Form("txtBAOHANH"))
DONGGOI=Trim(Request.Form("txtDONGGOI"))
MANG=Trim(Request.Form("txtMANG"))
MANHINHTRONG=Trim(Request.Form("txtMANHINHTRONG"))
MANHINHNGOAI=Trim(Request.Form("txtMANHINHNGOAI"))
GOINHANNHO=Trim(Request.Form("txtGOINHANNHO"))
TGIANGOI=Trim(Request.Form("txtTGIANGOI"))
TGIANCHO=Trim(Request.Form("txtTGIANCHO"))
TINNHAN=Trim(Request.Form("txtTINNHAN"))
DONGBOPC=Trim(Request.Form("txtDONGBOPC"))
BONHONGOAI=Trim(Request.Form("txtBONHONGOAI"))
BONHOTRONG=Trim(Request.Form("txtBONHOTRONG"))
PIN=Trim(Request.Form("txtPIN"))
KIEUCHUONG=Trim(Request.Form("txtKIEUCHUONG"))
GAME=Trim(Request.Form("txtGAME"))
TINHNANGKHAC=Request.Form("txtTINHNANGKHAC")
SOLUONGNHAP=Trim(Request.Form("txtSOLUONGNHAP"))
KHUYENMAI=Trim(Request.Form("txtKHUYENMAI"))
GPRS=Request.Form("txtGPRS")
if GPRS="" THEN GPRS=FALSE
WAP=Request.Form("txtWAP")
if WAP="" THEN WAP=FALSE
HONGNGOAI=Request.Form("txtHONGNGOAI")
if HONGNGOAI="" THEN HONGNGOAI=FALSE
FM=Request.Form("txtFM")
if FM="" THEN FM=FALSE
QUAYSOGIONGNOI=Request.Form("txtQUAYSOGIONGNOI")
if QUAYSOGIONGNOI="" THEN QUAYSOGIONGNOI=FALSE
GHIAM=Request.Form("txtGHIAM")
if GHIAM="" THEN GHIAM=FALSE
CAMERA=Request.Form("txtCAMERA")
if CAMERA="" THEN CAMERA=FALSE
NGHENHAC=Request.Form("txtNGHENHAC")
if NGHENHAC="" THEN NGHENHAC=FALSE
JAVA=Request.Form("txtJAVA")
if JAVA="" THEN JAVA=FALSE
PHANLOAI=Request.Form("txtPHANLOAI")
if PHANLOAI="" THEN PHANLOAI=FALSE
SPNOIBAT=Request.Form("txtSPNOIBAT")
if SPNOIBAT="" THEN SPNOIBAT=FALSE
sql="update SANPHAM set MABAC = " & MABAC & ","
sql=sql & " MALOAI ='" & MALOAI & "',"
sql=sql & " TENSP ='" & TENSP & "',"
sql=sql & " GIOITHIEU ='" & GIOITHIEU & "',"
sql=sql & " HINH ='" & HINH & "',"
sql=sql & " NGAYRAMAT ='" & NGAYRAMAT & "',"
sql=sql & " GIASP ='" & GIASP & "',"
sql=sql & " KICHTHUOC ='" & KICHTHUOC & "',"
sql=sql & " TRONGLUONG ='" & TRONGLUONG & "',"
sql=sql & " KIEUDANG ='" & KIEUDANG & "',"
sql=sql & " BAOHANH ='" & BAOHANH & "',"
sql=sql & " DONGGOI ='" & DONGGOI & "',"
sql=sql & " MANG ='" & MANG & "',"
sql=sql & " MANHINHTRONG ='" & MANHINHTRONG & "',"
sql=sql & " MANHINHNGOAI ='" & MANHINHNGOAI & "',"
sql=sql & " GOINHANNHO ='" & GOINHANNHO & "',"
sql=sql & " TGIANGOI ='" & TGIANGOI & "',"
sql=sql & " TGIANCHO ='" & TGIANCHO & "',"
sql=sql & " TINNHAN ='" & TINNHAN & "',"
sql=sql & " DONGBOPC ='" & DONGBOPC & "',"
sql=sql & " GPRS =" & GPRS & ","
sql=sql & " HONGNGOAI =" & HONGNGOAI & ","
sql=sql & " WAP =" & WAP & ","
sql=sql & " FM =" & FM & ","
sql=sql & " QUAYSOGIONGNOI =" & QUAYSOGIONGNOI & ","
sql=sql & " GHIAM =" & GHIAM & ","
sql=sql & " CAMERA =" & CAMERA & ","
sql=sql & " NGHENHAC =" & NGHENHAC & ","
sql=sql & " JAVA =" & JAVA & ","
sql=sql & " BONHONGOAI ='" & BONHONGOAI & "',"
sql=sql & " BONHOTRONG ='" & BONHOTRONG & "',"
sql=sql & " PIN ='" & PIN & "',"
sql=sql & " KIEUCHUONG ='" & KIEUCHUONG & "',"
sql=sql & " GAME ='" & GAME & "',"
sql=sql & " TINHNANGKHAC ='" & TINHNANGKHAC & "',"
sql=sql & " SOLUONGNHAP ='" & SOLUONGNHAP & "',"
sql=sql & " SPNOIBAT =" & SPNOIBAT & ","
sql=sql & " KHUYENMAI ='" & KHUYENMAI & "',"
sql=sql & " PHANLOAI =" & PHANLOAI & ","
sql=sql & " NGUOIGUI ='" & NGUOIGUI & "'"
sql=sql & " where MASP =" & MASP
cn.execute(sql)
cn.close
set cn=nothing
Response.Redirect("../MINHPHU/Hi.asp?NDM=15")
%>
‘ quản lý chỉnh sửa Tin tức
<%if Session("user")= 0 then
Response.Redirect("../MINHPHU/Trangchu.asp")
End if
%>
<%
call ketnoi(filenameDB,cn) 'open ket noi
dim MALT,TENTT,NOIDUNG,NGAYDT,TACGIA,HINH
MALT=Request.Form("cmbMALT")
TENTT=Request.Form("txtTENTT")
NOIDUNG=Request.Form("txtNOIDUNG")
NGAYDT=Request.Form("txtNGAYDT")
TACGIA=Request.Form("txtTACGIA")
HINH=Request.Form("txtHINH")
NGUOIGUI=Session("HO_TEN")
CHUTHICHANH=Request.Form("txtChuThich")
NDM=Request.Form("CmbQuyen")
sql="insert into TINTUC(MALT,TENTT,NGUOIGUI,NOIDUNG,NGAYDT,CHUTHICHANH,NDM,TACGIA,HINH) values("
sql=sql & MALT & ","
sql=sql & "'" & TENTT & "',"
sql=sql & "'" & NGUOIGUI & "',"
sql=sql & "'" & NOIDUNG & "',"
sql=sql & "'" & NGAYDT & "',"
sql=sql & "'" & CHUTHICHANH & "',"
sql=sql & "'" & NDM & "',"
sql=sql & "'" & TACGIA & "',"
sql=sql & "'" & HINH & "')"
' Response.Write(sql)
cn.execute(sql)
cn.close
set cn=nothing
if Session("user")= 8 then
Response.Redirect("../Administrator/TinTucXem.asp?ID=" & MALT)
End if
if Session("user")= 3 then
Response.Redirect("../MINHPHU/Hi.asp?NDM=12")
else
Response.Redirect("../MINHPHU/Trangchu.asp")
End if
%>
‘ quản lý kiểm tra thành viên khi đăng nhập
<%
call ketnoi(filenameDB,cn)
dim tendangnhap,matkhau
tendangnhap=Replace(Request.Form("txttendangnhap"),"'","''")
matkhau=sha256(sha256(Replace(Request.Form("txtmatkhau"),"'","''")))
sql="select * from MEMBERS where Ten_dang_nhap ='" & tendangnhap & "' and Mat_khau='" & matkhau & "'"
call MoRec(sql,cn,rs)
if not rs.BOF then
Session("HO_TEN")=rs("HO_TEN")
Session("MATHANHVIEN")=rs("MATHANHVIEN")
Session("User")=rs("NDM")
session.Timeout = 200
call ketthuc(rs,cn)
Response.Redirect("../MINHPHU/trangchu.asp")
else
Session("User")=0
Response.Redirect("../MINHPHU/Hi.asp?NDM=1")
end if
%>
Các file đính kèm theo tài liệu này:
- 26935.doc