Đồ án Xây dựng website quảng cáo thương mại bằng ASP.NET

pdf 50 trang huongle 3370
Bạn đang xem 20 trang mẫu của tài liệu "Đồ án Xây dựng website quảng cáo thương mại bằng ASP.NET", để tải tài liệu gốc về máy bạn click vào nút DOWNLOAD ở trên

Tài liệu đính kèm:

  • pdfdo_an_xay_dung_website_quang_cao_thuong_mai_bang_asp_net.pdf

Nội dung text: Đồ án Xây dựng website quảng cáo thương mại bằng ASP.NET

  1. 1 LỜI CẢM ƠN Lời đầu tiên em xin đƣợc bày tỏ sự trân trọng và lòng biết ơn chân thành đối với thầy giáo, Thạc sỹ. Vũ Mạnh Khánh giảng viên khoa Công nghệ thông tin - Trƣờng Đại học Dân Lập Hải Phòng. Trong suốt thời gian học và làm đồ án tốt nghiệp, thầy đã dành rất nhiều thời gian quý báu để tận tình chỉ bảo, hƣớng dẫn, định hƣớng cho em thực hiện đồ án. Em xin chân thành cảm ơn tất cả các thầy cô giáo trong Bộ môn Công nghệ thông tin - Trƣờng Đại học Dân Lập Hải Phòng, chân thành cảm ơn các thầy giáo, cô giáo tham gia giảng dạy và truyền đạt những kiến thức quý báu trong suốt thời gian em học tập tại trƣờng, đã đọc và phản biện đồ án của em giúp em hiểu rõ hơn các vấn đề mình nghiên cứu, để em có thể hoàn thành đồ án tốt nghiệp này. Em xin cảm ơn GS.TS.NGƢT Trần Hữu Nghị Hiệu trƣởng Trƣờng Đại học Dân lập Hải Phòng, Ban giám hiệu nhà trƣờng, Bộ môn tin học, các Phòng ban nhà trƣờng đã tạo điều kiện tốt nhất cho em cũng nhƣ các bạn khác trong suốt thời gian học tập và làm tốt nghiệp. Tuy có nhiều cố gắng trong quá trình học tập, trong thời gian thực tập cũng nhƣ trong quá trình làm đồ án nhƣng không thể tránh khỏi những thiếu sót, em rất mong đƣợc sự góp ý quý báu của tất cả các thầy giáo, cô giáo cũng nhƣ tất cả các bạn để kết quả của em đƣợc hoàn thiện hơn. Em xin chân thành cảm ơn! Hải Phòng, 04 tháng 07 năm 2011. Sinh viên Phạm Văn Vinh
  2. 2 MỤC LỤC DANH MỤC HÌNH VẼ VÀ BẢNG BIỂU 4 MỞ ĐẦU 6 CHƢƠNG I: TỔNG QUAN ASP.NET VÀ VISUAL STUDIO 2008 7 1.1 Giới thiệu về ASP.NET 7 1.1.1 NET FRAMEWORK 7 1.1.2 ASP.NET là gì 7 1.1.3 Khác biệt giữa ASP.NET và ASP 8 1.1.4 Quá trình xử lý tập tin Aspx 11 1.1.5 Các đối tƣợng của ASP.NET 12 1.1.6 Phát triển một website ASP.NET 15 1.2 Microsoft Visual Studio 2008 Professional Edition 16 CHƢƠNG II: MÔ TẢ VÀ PHÂN TÍCH BÀI TOÁN 19 2.1 Khảo sát bài toán 19 2.1.1 Mô tả bài toán 19 2.1.2 Biểu đồ phân rã chức năng 20 2.1.3 Các mẫu biểu 22 2.2 Các mô hình 23 2.2.1 Ma trận thực thể chức năng 23 2.2.2 Biểu đồ ngữ cảnh 24 2.2.3 Xây dựng biểu đồ luồng dữ liệu mức 0 25 2.2.4 Biều đồ luồng dữ liệu mức 1: 26 Hình 2.8: Biểu đồ luồng dữ liệu cho tiến trình 1.0 26 2.2 Mô hình ER và mô hình quan hệ 29 2.3.1 Đƣa ra các thực thể 29
  3. 3 2.3.2 Xác định mối quan hệ giữa các thực thể 32 2.3.3 Mô hình ER 34 2.3.4 Thiết kế cơ sở dữ liệu, mô hình quan hệ 35 CHƢƠNG III: CHƢƠNG TRÌNH 37 3.1 Giới thiệu chƣơng trình 37 3.2 Hƣớng dẫn cài đặt 37 3.2.1 Cài đặt SQL 2005 Express Edition 37 3.2.2 Cài đặt IIS 39 3.2.3 Cài đặt thƣ mục ảo, tạo kết nối và Attach Cơ sở dữ liệu 40 3.3 Hƣớng dẫn sử dụng 41 3.3.1 Hƣớng dẫn chức năng đăng ký 41 3.3.2 Hƣớng dẫn chức năng đăng tin 43 3.3.3 Hƣớng dẫn chức năng gia hạn 45 3.3.4 Hƣớng dẫn một số chức năng trong Administrator Control 47 KẾT LUẬN 49 TÀI LIỆU THAM KHẢO 50
  4. 4 DANH MỤC HÌNH VẼ VÀ BẢNG BIỂU Hình 1.1: Kiến trúc .NET Framework 7 Hình 1.2: Quá trình xử lý tập tin aspx 11 Hình 2.1: Biểu đồ phân rã chức năng 20 Hình 2.2: Bảng hồ sơ khách hàng 22 Hình 2.3: Bảng tin 22 Hình 2.4: Bảng giá 22 Hình 2.5: Bảng ma trận thực thể chức năng 23 Hình 2.6: Biểu đồ ngữ cảnh 24 Hình 2.7: Biểu đồ luồng dữ liệu mức 0 25 Hình 2.8: Biểu đồ luồng dữ liệu cho tiến trình 1.0 26 Hình 2.9: Biểu đồ luồng dữ liệu cho tiến trình 2.0 27 Hình 2.10: Biểu đồ luồng dữ liệu cho tiến trình 3.0 28 Hình 2.11: Thực thể Khách hàng 29 Hình 2.12: Thực thể tin quảng cáo 30 Hình 2.13: Thực thể bảng giá 30 Hình 2.14: Thực thể Nơi đăng 31 Hình 2.15: thực thể Danh mục 31 Hình 2.16: Mối quan hệ giữa thực thể “Khách hàng” và “Tin quảng cáo” 32 Hình 2.17: Mối quan hệ giữa “Bảng giá” và “Tin quảng cáo” 32 Hình 2.18: Mối quan hệ giữa “Tin quảng cáo” và “Nơi đăng” 33 Hình 2.19: Mối quan hệ giữa “Tin quảng cáo” và “Danh mục” 33 Hình 2.20: Mô hình ER 34 Hình 2.21: Mô hình quan hệ 36 Hình 3.1: Chế độ Mixed mode SQL Server 39
  5. 5 Hình 3.2: Giao diện trang chủ 42 Hình 3.3: Form đăng ký 42 Hình 3.4: Thông báo đăng ký thành công 43 Hình 3.5: Form đăng ký 44 Hình 3.6: Email thông báo khách hàng đăng tin 45 Hình 3.7: Bảng điều khiển khách hàng 46 Hình 3.8: Email thông báo gia hạn 47 Hình 3.9: Duyệt tin 47 Hình 3.10: Quản lý thành viên 48
  6. 6 MỞ ĐẦU Buổi sáng, mở cửa thấy một tờ giới thiệu chuyên lắp đặt ăng ten, bƣớc ra đƣờng thấy các bức tƣờng đƣợc trang điểm bằng những dòng chữ khoan cắt bê tông và nhận rút hầm cầu. buổi trƣa mở máy tính, nhận đƣợc email sửa chửa thiết bị điện gia dụng tại nhà, buổi tối lên tivi, màng hình đầy những dầu gội, kem đánh răng và bông băng Nhìn từ đầu phố đến cuối phố, trên cửa tất cả các căn nhà điều đƣợc che kín bằng những hình ảnh quảng cáo đủ kiểu, màu sắc, hình dáng, kích cỡ Một thế giới đầy quảng cáo. Đó là thể hiện của nền kinh tế tiêu dùng phát triển. Một cửa hàng nho nhỏ muốn quảng cáo sản phẩm, một ngƣời muốn bán một món hàng hay đang cần mua một món hàng họ khó có thể làm một thông tin quảng cáo để đƣa lên truyền hình hay lên báo hay việc làm tờ rơi vừa mất công sức, hiệu quả không cao. Nhƣng thời đại hiện nay với sự phát triển cực kỳ mạnh mẽ của mạng Internet, quảng cáo hiệu quả và tiết kiệm chi phí nhất là quảng cáo trên website quảng cáo thƣơng mại. Vì thế nên em chọn đề tài “Xây dựng website quảng cáo thương mại bằng ASP.NET”. Website này xây dựng với mục đích trợ giúp việc đăng quảng cáo cho những doanh nghiệp, tổ chức, cá nhân và mang về lợi nhuận. Đồ án gồm ba chƣơng: - Chƣơng I: Tổng quan về ASP.NET Microsoft Visual Studio 2008 - Chƣơng II: Mô tả và phân tích bài toán - Chƣơng III: Chƣơng trình
  7. 7 CHƢƠNG I: TỔNG QUAN ASP.NET VÀ VISUAL STUDIO 2008 1.1 Giới thiệu về ASP.NET 1.1.1 NET FRAMEWORK .NET Framework là một tập những giao diện lập trình và là tâm điểm của nền tảng .NET. Nó cung cấp cơ sở hạ tầng để xây dựng và chạy các dịch vụ Web. Hình 1.1: Kiến trúc .NET Framework 1.1.2 ASP.NET là gì Trƣớc hết, họ tên của ASP.NET là Active Server Pages .NET (.NET ở đây là .NET framework). ASP.NET là một công nghệ có tính cách mạng dùng để phát triển các ứng dụng về mạng hiện nay cũng nhƣ trong tƣơng lai (ASP.NET is a
  8. 8 revolutionary technology for developing web applications). Lƣu ý ở chỗ ASP.NET là một phƣơng pháp tổ chức hay khung tổ chức (framework) để thiết lập các ứng dụng hết sức mạnh mẽ cho mạng dựa trên CLR (Common Language Runtime) chứ không phải là một ngôn ngữ lập trình. Ngôn ngữ lập trình đƣợc dùng để diễn đạt ASP.NET là VB.NET (Visual Basic .NET) và VB.NET chỉ là một trong 25 ngôn ngữ .NET hiện nay đƣợc dùng để phát triển các trang ASP.NET mà thôi. Tuy mang họ tên gần giống nhƣ ASP cổ điển nhƣng ASP.NET không phải là ASP. Sau đây là phần sơ lƣợc vài khác biệt giữa ASP.NET và ASP để có khái niệm tổng quát về ASP.NET 1.1.3 Khác biệt giữa ASP.NET và ASP SỰ THAY ÐỔI CƠ BẢN ASP đã và đang thi hành sứ mạng đƣợc giao cho nó để phát triển mạng một cách tốt đẹp nhƣ vậy thì tại sao phải cần phải đổi mới hoàn toàn? Lý do đơn giản là ASP không còn đáp ứng đủ nhu cầu hiện nay trong lĩnh vực phát triển mạng của công nghệ Tin Học. ASP đƣợc thiết kế riêng biệt và nằm ở tầng phía trên hệ điều hành Windows và Internet Information Service, do đó các công dụng của nó hết sức rời rạc và giới hạn. Trong khi đó, ASP.NET là một cơ cấu trong các cơ cấu của hệ điều hành Windows dƣới dạng nền hay khung .NET (.NET framework), nhƣ vậy ASP.NET không những có thể dùng các object của các ứng dụng cũ mà còn có thể xử dụng tất cả mọi tài nguyên mà Windows có. Ta có thể tóm tắt sự thay đổi nhƣ sau: - Tập tin của ASP.NET (ASP.NET file) có extension là .ASPX, còn tập tin của ASP là .ASP. - Tập tin của ASP.NET (ASP.NET file) đƣợc phân tích ngữ pháp (parsed) bởi XSPISAPI.DLL, còn tập tin của ASP đƣợc phân tích bởi ASP.DLL. - ASP.NET là kiểu mẫu lập trình phát động bằng sự kiện (event driven), còn các trang ASP đƣợc thi hành theo thứ tự tuần tự từ trên xuống dƣới. - ASP.NET xử dụng trình biên dịch (compiled code) nên rất nhanh, còn ASP dùng trình thông dịch (interpreted code) do đó hiệu suất và tốc độ cũng thua kém hẳn.
  9. 9 ASP.NET hỗ trợ gần 25 ngôn ngữ lập trình mới với .NET và chạy trong môi trƣờng biên dịch (compiled environment), còn ASP chỉ chấp nhận VBScript và JavaScript nên ASP chỉ là một scripted language(ngôn ngữ kịch bản) trong môi trƣờng thông dịch(in the interpreter environment). Không những vậy, ASP.NET còn kết hợp nhuần nhuyễn với XML (Extensible Markup Language) để chuyển vận các thông tin (information) qua mạng. ASP.NET hỗ trợ tất cả các trình duyệt và quan trọng hơn nữa là hỗ trợ các thiết bị di động (mobile devices). Chính các thiết bị di động, mà mỗi ngày càng phổ biến, đã khiến việc dùng ASP trong việc phát triển mạng nhằm vƣơn tới thị trƣờng mới đó trở nên vô cùng khó khăn. KIỂU MẪU RESQUEST/RESPONSE Kiểu mẫu này chính là toàn bộ phƣơng pháp làm việc theo kiểu Client /Server hiện dùng với ASP. Client/Server - Một trƣờng hợp đơn giản nhất là sự trao đổi thông tin giữa 2 máy vi tính để hoàn thành 1 công việc nào đó, trong đó máy server cung cấp dịch vụ theo yêu cầu của 1 máy khách(Client PC). Thông thƣờng, Server là máy vi tính lƣu trữ thông tin về mạng trong đó có hình ảnh, video, những trang HTML hay ASP và Client là máy vi tính đƣợc dùng dể viếng thăm mạng. Một cách tổng quát phƣơng pháp này gồm có 4 bƣớc nhƣ sau: 1. Client (thông qua trình duyệt, Internet Browser) xác định vị trí của Web Server qua 1 nối URL (Universal Resource Locator) 2. Client sẽ yêu cầu đƣợc tham khảo 1 trang trong mạng đó và thƣờng là trang chủ (home page) nhƣ index.htm hay default.htm 3. Server đáp ứng bằng cách hoàn trả hồ sơ mà Client đã yêu cầu trƣớc đây 4. Client nhận đƣợc hồ sơ gởi về và hiển thị (display) trong browser của mình Lƣu ý, một khi Client đã nhận đƣợc hồ sơ rồi là quá trình trao đổi qua lại đó kết thúc ngay tức khắc. KIỂU MẪU EVENT-DRIVEN
  10. 10 Kiểu mẫu event-driven này dùng với ASP.NET cũng tƣơng tự nhƣ là kiểu mẫu event-driven ta vẫn thƣờng dùng trong khi lập trình các ứng dụng với Visual Basic 6. Trong kiểu mẫu này, Server sẽ không chờ Client yêu cầu tham khảo 1 trang nào đó trong mạng mà Server đã bố trí và kế hoạch sẵn trƣớc tất cả mọi tình huống để có thể hành động kịp thời mỗi khi Client quyết định làm 1 điều gì đó. Đó là “response to your action”, còn trong kiểu mẫu trƣớc là “response to your request”, nhƣ vậy ASP.NET có thể phát hiện ra các hành động của Client để phản ứng cho thích hợp. ASP.NET có thể làm đƣợc điều đó là dựa vào tiến trình xử lý linh động ở Client (gọi là clever client-side processing) để thực hiện kiểu mẫu event-driven này của mình. Tiến trình xử lý ở Client xảy ra khi ta bố trí nguồn mã thích hợp mà Client có thể hiểu đƣợc trong các trang ta gởi về cho Client. Lƣu ý là mặc dù các trang mạng (web page) ta đều chứa ở Server nhƣng nguồn mã lại có thể đƣợc thực hiện và xử lý, hoặc ở Server hoặc ở Client (Server-Side processing, Client-Side processing) tuỳ theo cách ta bố trí.
  11. 11 1.1.4 Quá trình xử lý tập tin Aspx Hình 1.2: Quá trình xử lý tập tin aspx
  12. 12 1.1.5 Các đối tƣợng của ASP.NET 1.1.5.1 Đối tƣợng Request, Response Request và Response là 2 đối tƣợng đƣợc dùng nhiều nhất trong lập trình ASP, và cho đến ASP.NET vẫn đƣợc dùng rất nhiều, dùng trao đổi dữ liệu giữa trình duyệt và server. Request cho phép lấy về các thông tin từ client. Khi browser gửi một yêu cầu trang web lên server ta gọi là 1 request Chúng ta thƣờng sử dụng các lệnh request sau: Request.QueryString Cho phép server lấy về các giá trị đƣợc gửi từ ngƣời dùng qua URL hoặc form (method GET). Ví dụ ở trang home.aspx chúng ta đặt một dòng liên kết sang trang gioithieu.aspx với thẻ sau: Biến "tacgia" có giá trị là "Tran Van A" đƣợc ngƣời dùng gửi tới server kèm theo URL. (ngƣời dùng có thể gõ thẳng địa chỉ: " Van A" trên thanh Address của trình duyệt) Server muốn nhận lại giá trị này thì dùng request.QueryString ở trang gioithieu.asp
  13. 13 Tƣơng tự nhƣ vậy nếu ngƣời dùng gửi giá trị Tran Van A thông qua một biến trong form và chọn method GET Request.Form Cho phép server lấy về các giá trị đƣợc gửi từ ngƣời dùng qua form (method POST). Chẳng hạn file form.aspx: File xulyform.aspx làm nhiệm vụ xử lý thông tin từ Form này sẽ dùng câu lệnh request.form để nhận lại thông tin ngƣời dùng đã gõ vào: response.write "Tên người dùng là: "&x %> Response Đối tƣợng Response dùng để gửi các đáp ứng của server cho client. Chúng ta thƣờng dùng một số lệnh Response sau: Response.Write Đƣa thông tin ra màn hình trang web. Ví dụ để đƣa câu chào Hello ra màn hình ta dùng lệnh sau:
  14. 14 Hiển thị thời gian trên server ra màn hình: hoặc now là hàm lấy ngày giờ hệ thống trên server Response.Redirect Chuyển xử lý sang một trang Asp.Net khác. Ví dụ trang xulyform.aspx sau khi kiểm tra form đăng nhập thấy ngƣời dùng không có quyền vào website thì nó sẽ chuyển cho file Error.aspx(file này hiển thị một thông báo lỗi user không có quyền truy cập) Response.End Ngừng xử lý các Script. Dùng lệnh này khi muốn dừng xử lý ở một vị trí nào đó và bỏ qua các mã lệnh ASP.NET ở phía sau. Đây là cách rất hay dùng trong một số tình huống, chẳng hạn nhƣ debug lỗi 1.1.5.2 Đối tƣợng session, Application Session là một phiên làm việc giữa từng ngƣời dùng và web server, nó bắt đầu khi ngƣời đó lần đầu tiên truy cập tới 1 trang web trong website và kết thúc khi ngƣời đó rời khỏi website hoặc không tƣơng tác với website trong một khoảng thời gian nhất định (time out). Nhƣ vậy tại một thời điểm một website có bao nhiêu ngƣời truy cập thì có bấy nhiêu phiên ứng với mỗi ngƣời, các phiên này độc lập nhau. Để lƣu những thông tin tác dụng trong 1 phiên, ngƣời ta dùng đối tƣợng Session, ví dụ khi một user bắt đầu session với việc login vào hệ thống, và user đã login đó cần đƣợc hệ thống ghi nhớ trong toàn phiên làm việc (nhằm tránh việc ngƣời dùng phải đăng nhập lại mỗi khi đƣa ra một request).Giá trị của biến kiểu session có phạm vi trong tất cả các trang ASP.NET của ứng dụng, nhƣng không có tác dụng đối với phiên làm việc khác. Application đại diện cho toàn bộ ứng dụng, bao gồm tất cả các trang web trong website. Để lƣu trữ những thông tin có tác dụng trong toàn ứng dụng, tức là
  15. 15 có giá trị trong tất cả các trang asp.net và tất cả các phiên, ngƣời ta dùng đối tƣợng Application Điểm khác của biến application so với biến session là session chỉ có tác dụng đối với mỗi phiên, còn biến application có tác dụng với mọi phiên. 1.1.5.3 Đối tƣợng Server Đối tƣợng Server đƣợc sử dụng để cung cấp thông tin của Server cho ứng dụng. Thuộc tính MachineName Thuộc tính này đƣợc dùng để lấy tên của Web Server. Phƣơng thức Mappath Phƣơng thức Mappath đƣợc dùng để lấy đƣờng dẫn vật lý hoặc đƣờng dẫn ảo đến một thƣ mục trên Server. Phƣơng thức Transfer( ) Ngừng thi hành trang hiện hành, gởi yêu cầu mới đến trang đƣợc gọi thực hiện. 1.1.5.4 Đối tƣợng Cookies Có thể xem một Cookie nhƣ một tập tin (với kích thƣớc khá nhỏ) đƣợc Web Server lƣu tại máy của ngƣời dùng. Mỗi lần có yêu cầu đến Web Server, những thông tin của Cookies cũng sẽ đƣợc gởi theo về Server. 1.1.6 Phát triển một website ASP.NET Để phát triển một website bằng ASP.NET trƣớc hết ta phải cần có: - Internet Information services (IIS) IIS đƣợc đính kèm với các phiên bản của Windows. Microsoft Internet Information Services (các dịch vụ cung cấp thông tin Internet) là các dịch vụ dành cho máy chủ chạy trên nền Hệ điều hành Window nhằm cung cấp và phân tán các thông tin lên mạng, nó bao gồm nhiều dịch vụ khác nhau nhƣ Web Server, FTP Server,
  16. 16 Nó có thể đƣợc sử dụng để xuất bản(publish) nội dung của các trang Web lên Internet/Intranet bằng việc sử dụng “Phƣơng thức chuyển giao siêu văn bản“ - Hypertext Transport Protocol (HTTP). Nhƣ vậy, sau khi thiết kế xong các trang Web của mình, nếu muốn đƣa chúng lên mạng để mọi ngƣời có thể truy cập và xem chúng thì phải nhờ đến một Web Server, ở đây là IIS. - Microsoft Visual Studio .NET Sẽ đƣợc giới thiệu ở phần 1.2 - .NET Framework Xem phần 1.1.1 1.2 Microsoft Visual Studio 2008 Professional Edition Visual Studio 2008 Professional Edition là bộ công cụ dễ dùng giúp tăng tốc quá trình biến của ý tƣởng ban đầu của nhà phát triển thành hiện thực. Visual Studio 2008 Professional Edition đƣợc thiết kế để hỗ trợ các dự án phát triển nhắm đến nền tảng Web (bao gồm ASP.NET AJAX), Windows Vista, Windows Server 2008, hệ thống 2007 Microsoft Office, SQL Server 2008, cùng các thiết bị nền Windows Mobile. Số lƣợng nền tảng hệ thống mà các nhà phát triển phải nhắm đến để đáp ứng nhu cầu thƣơng trƣờng đang ngày càng gia tăng rất nhanh. Visual Studio 2008 Professional Edition cung cấp bộ công cụ tích hợp để đáp ứng mọi nhu cầu này thông qua việc cung cấp một tập hợp khổng lồ các chức năng có thể trong phiên bản Visual Studio 2008 Standard Edition. Các nhà phát triển hiện nay phải đối mặt với thách thức là sự đa dạng của các nền tảng hệ thống cùng các ứng dụng tự tạo đem lại giá trị trong kinh doanh. Các bộ thiết kế và các tính năng ngôn ngữ tích hợp trong Visual Studio cho phép các nhà phát triển vừa xây dựng các ứng dụng liên kết cần thiết trong kinh doanh hiện nay vừa tận dụng môi trƣờng.NET Framework 3.5 để giảm thiểu thời gian phát triển.
  17. 17 1. Đem đến các ứng dụng hiệu quả cao 2. Liên kết các dữ liệu bạn cần, bất kể vị trí, cũng nhƣ xây dựng các ứng dụng kiểm soát dữ liệu bằng truy vấn Language Integrated Query (LINQ). 3. Xây dựng các ứng dụng client hiệu quả 4. Phát triển các giải pháp tinh vi tăng cƣờng trải nghiệm ngƣời dùng cùng các khả năng của hệ thống 2007 Microsoft Office và Windows Vista®. 5. Xây dựng các ứng dụng web mạnh mẽ 6. Xây dựng các ứng dụng tƣơng tác phong phú bằng các giao diện web tƣơng tác ASP.NET AJAX. 7. Xây dựng các ứng dụng tận dụng triệt để các công nghệ web mới nhất cùng cải tiến hỗ trợ cho AJAX và các điều khiển Web cũng nhƣ thƣ viện 8. Microsoft AJAX Library 9. Tạo các ứng dụng web dễ dàng hơn với giao diện đƣợc thiết kế lại và khả năng hỗ trợ nhiều chuẩn. 10. Tận dụng dữ liệu từ bất kì nguồn dữ liệu nào dễ dàng hơn với LINQ, một bộ các thành phần bổ sung ngôn ngữ cho Visual Basic và Visual C# Quản lý và xây dựng các ứng dụng hƣớng đến nhiều phiên bản của bộ .NET Framework. Trong lần sử dụng đầu tiên bạn có thể sử dụng một công cụ để làm việc trên các ứng dụng chạy trên nền .NET Framework phiên bản 2.0, 3.0, và 3.5 Đảm bảo độ chính xác của ứng dụng dễ dàng hơn với bộ kiểm tra đơn vị tích hợp trong Visual Studio 2008 Professional Edition Khám phá toàn bộ sức mạnh của bộ .NET Framework 3.5 với các công cụ tích hợp giúp đơn giản hóa việc xây dựng những trải nghiệm ngƣời dùng và các hệ thống liên kết thú vị Xây dựng những trải nghiệm ngƣời dùng hấp dẫn với các bộ thiết kế tích hợp cho Windows Presentation Foundation. Các trải nghiệm đƣợc xây dựng với WPF có thể hoạt động liên kết mạnh mẽ với Windows Forms Tạo các ứng dụng liên kết sử dụng các bộ thiết kế hình ảnh mới cho Windows Communications Foundation và Windows Workflow Foundation
  18. 18 Sử dụng môi trƣờng phát triển chuyên nghiệp của Visual Studio để xây dựng các giải pháp dựa trên Microsoft Office đáng tin cậy, mở rộng đƣợc, cũng nhƣ dễ bảo trì (chỉ có trong phiên bản Visual Studio 2008 Professional Edition) Tăng cƣờng khả năng làm việc liên kết giữa các nhà phát triển và các nhà thiết kế để tạo ra những trải nghiệm ngƣời dùng phức tạp hơn.
  19. 19 CHƢƠNG II: MÔ TẢ VÀ PHÂN TÍCH BÀI TOÁN 2.1 Khảo sát bài toán 2.1.1 Mô tả bài toán Khi khách hàng đến tham quan website và muốn đăng tin quảng cáo. Nếu là khách hàng mới (Chƣa có tài khoản) thì phải đăng ký rồi đăng nhập. Ngƣợc lại thì đăng nhập. Đăng ký thông tin, khách hàng cần khai báo thông tin chi tiết ( Tên đăng nhập, mật khẩu, họ tên, email ). Khi đăng ký thành công hệ thống sẽ lƣu thông tin của khách hàng vào hồ sơ khách hàng và gửi một email thông báo đến hộp thƣ mà khách hàng khai báo. Khách hàng có thể đăng nhập bằng thông tin đã khai báo( Tên đăng nhập, mật khẩu). Khi khách hàng đã đăng nhập thì có thể đăng thông tin quảng cáo.Trƣớc khi đăng tin, khách hàng có thể xem bảng giá. Khách hàng cần điền chi tiết những thông tin về tin đăng quảng cáo (Tiêu đề, nội dung, danh mục, nơi đăng, thời hạn ). Khi đăng tin thành công, thông tin quảng cáo sẽ đƣợc lƣu vào bảng tin và đƣợc chờ xét duyệt, thanh toán. Hàng ngày, quản trị viên trang web quảng cáo phải đăng nhập vào admin control để duyệt các bài mà khách hàng đã đăng. Các bài đƣợc duyệt sẽ đƣợc hiển thị lên trang web với thời hạn mà khách hàng đã khai báo. Khi thông tin hết hạn, hệ thống sẽ gửi một email thông báo hết hạn đến cho khách hàng. Khách hàng có thể gia hạn thông tin. Khách hàng có thể quản lý thông tin cá nhân, sửa thông tin cá nhân. Quản trị viên có toàn quyền thêm, sửa xóa thông tin khách hàng, thông tin quảng cáo, các danh mục, tỉnh thành
  20. 20 2.1.2 Biểu đồ phân rã chức năng Hình 2.1: Biểu đồ phân rã chức năng Mô tả chức năng lá: “1.1” Đăng ký thông tin cá nhân khách hàng: Khách hàng phải khai báo đầy đủ những thông tin mà hệ thống yêu cầu nhƣ : tên đăng nhập, mật khẩu, Email, họ tên, địa chỉ “1.2” Kiểm tra thông tin khách hàng: Hệ thống kiểm tra tên đăng nhập của khách hàng không trùng lặp với khách hàng khác, mỗi khách hàng chỉ có một tên đăng nhập. Kiểm tra định dạng Email và kiểm tra mỗi Email chỉ đƣợc dùng một lần “1.3” Thông tin phản hồi qua Email: Hệ thống gửi Email thống báo khách hàng đã đăng ký thành công. “1.4” Lƣu vào bảng hồ sơ khách hàng: Thông tin khách hàng đăng ký sẽ đƣợc lƣu lại “2.1” Nhập thông tin quảng cáo: Khách hàng đăng tin phải điền đầy đủ những thông tin cần thiết cho thông tin nhƣ tiêu đề, nội dung, danh mục, nơi đăng
  21. 21 “2.2” Kiểm tra thông tin: Kiểm tra một số yêu cầu bắt buộc không đƣợc để trống nhƣ tiêu đề, nội dung “2.3” Lƣu thông tin vào bảng tin: thông tin sẽ đƣợc lƣu vào bảng tin “2.4” Xét duyệt và hiển thị thông tin: quản trị viên, duyệt bài, bài nào hợp lệ và đã thanh toán thì cho phép hiển thị “3.1” Kiểm tra thời hạn thông tin: Mỗi thông tin có một hạn đăng nhất định, phải kiểm tra xem thông tin đã hết hạn hay chƣa “3.2” Loại bỏ những thông tin hết hạn: Những thông tin đã hết hạn sẽ bị loại bỏ không cho hiển thị trên website “3.3” Gia hạn thông tin: Khách hàng có thể gia hạn thông tin hết hạn hoặc chƣa hết hạn “3.4” Thông tin phản hồi qua Email: Khi một thông tin hết hạn, hệ thống sẽ gửi một email đến cho khách hàng “4.1” Sửa thông tin khách hàng: Khách hàng có thể sửa chữa thông tin cá nhân sau khi đã đăng nhập “4.2” Đổi mật khẩu: Khách hàng có thể đổi mật khẩu sau khi đăng nhập “4.3” Lấy lại mật khẩu khi quên: Khi khách hàng quên mật khẩu khách hàng có thể khai báo Email mình đã dùng để đăng ký, hệ thống sẽ tự động làm lại mật khẩu và gửi vào email cho khách hàng
  22. 22 2.1.3 Các mẫu biểu Tên đăng Mật Quyền Họ và Số điện Email Địa chỉ nhập khẩu tên thoại Hình 2.2: Bảng hồ sơ khách hàng Mã Tiêu Ngƣời Mã Danh Mã Nơi Nội Ngày Ngày Giá Trạng tin đề đăng danh mục nơi đăng dung đăng hết thái mục đăng hạn Hình 2.3: Bảng tin Mã giá Tên giá Số ngày hiển thị Giá Hình 2.4: Bảng giá
  23. 23 2.2 Các mô hình 2.2.1 Ma trận thực thể chức năng 2.2.1.1 Các hồ sơ dữ liệu D1: Hồ sơ khách hàng: Lƣu trữ những thông tin cá nhân của khách hàng đã đăng ký D2: Bảng tin: Lƣu trữ những thông tin quảng cáo của khách hàng đã đăng D3: Bảng giá: Lƣu trữ giá cả tính theo thời gian đăng tin 2.2.1.2 Bảng ma trận thực thể chức năng D1. Hồ Sơ khách hàng D2. Bảng tin D3. Bảng giá Các chức năng D1 D2 D3 Đăng ký khách hàng C Đăng tin quảng cáo R C R Quản lý thông tin quảng cáo R U R Quản lý thông tin cá nhân U Hình 2.5: Bảng ma trận thực thể chức năng
  24. 24 2.2.2 Biểu đồ ngữ cảnh Hình 2.6: Biểu đồ ngữ cảnh
  25. 25 2.2.3 Xây dựng biểu đồ luồng dữ liệu mức 0 Hình 2.7: Biểu đồ luồng dữ liệu mức 0
  26. 26 2.2.4 Biều đồ luồng dữ liệu mức 1: Hình 2.8: Biểu đồ luồng dữ liệu cho tiến trình 1.0
  27. 27 Hình 2.9: Biểu đồ luồng dữ liệu cho tiến trình 2.0
  28. 28 Hình 2.10: Biểu đồ luồng dữ liệu cho tiến trình 3.0
  29. 29 2.2 Mô hình ER và mô hình quan hệ 2.3.1 Đƣa ra các thực thể Từ những bảng 2.2, 2.3, 2.4 sau khi liệt kê chính xác và chọn lọc, ta rút ra đƣợc những thực thể với những thuộc tính: Hình 2.11: Thực thể Khách hàng
  30. 30 Hình 2.12: Thực thể tin quảng cáo Hình 2.13: Thực thể bảng giá
  31. 31 Hình 2.14: Thực thể Nơi đăng Hình 2.15: thực thể Danh mục
  32. 32 2.3.2 Xác định mối quan hệ giữa các thực thể Hình 2.16: Mối quan hệ giữa thực thể “Khách hàng” và “Tin quảng cáo” Hình 2.17: Mối quan hệ giữa “Bảng giá” và “Tin quảng cáo”
  33. 33 Hình 2.18: Mối quan hệ giữa “Tin quảng cáo” và “Nơi đăng” Hình 2.19: Mối quan hệ giữa “Tin quảng cáo” và “Danh mục”
  34. 34 2.3.3 Mô hình ER Sau khi rút gọn ta đƣợc mô hình ER nhƣ hình 2.20: Hình 2.20: Mô hình ER
  35. 35 2.3.4 Thiết kế cơ sở dữ liệu, mô hình quan hệ Từ mô hình ER ta có các quan hệ sau: KHÁCH HÀNG (Tên đăng nhập, Mật khẩu, Quyền, Email, địa chỉ, số điện thoại) BẢNG GIÁ ( Mã giá, Tên giá, Số ngày hiển thị, giá) TIN QUẢNG CÁO ( Mã tin, Tên đăng nhập, Mã giá, Mã danh mục, Mã nơi đăng, Ngày đăng, Ngày hết hạn, Tiêu đề, Nội dung, Trạng thái) DANH MỤC (Mã danh mục, Danh mục) NƠI ĐĂNG (Mã nơi đăng, Nơi đăng)
  36. 36 Hình 2.21: Mô hình quan hệ
  37. 37 CHƢƠNG III: CHƢƠNG TRÌNH 3.1 Giới thiệu chƣơng trình Chƣơng trình là một website đƣợc phát triển bằng các công cụ: - Visual Studio 2008 Professional Edition bao gồm cả .NET Framework - SQL Server 2005 Express Edition - IIS (Internet Information Service) Các Module chính của chƣơng trình: - Module “đăng ký khách hàng”: Lƣu thông tin cá nhân khách hàng để quản lý những thông tin khách hàng và thông tin quảng cáo của khách hàng - Module “đăng tin”: Lƣu thông tin quảng cáo mà khách hàng đã đăng - Module “bảng điều khiển khách hàng”: Lƣu những thông tin cá nhân mà khách hàng thay đổi, sửa chữa. Gia hạn thông tin. - Module “Administrator Control”: Module để ngƣời quản trị viên có thể kiểm soát thông tin, duyệt tin, quản lý tin, quản lý khách hàng thành viên, quản lý danh mục 3.2 Hƣớng dẫn cài đặt Để cài đặt Website ASP.NET ta cần phải cài đặt thành công những chƣơng trình sau: - SQL Server 2005 Express Edition - IIS (Internet Information Service) 3.2.1 Cài đặt SQL 2005 Express Edition Yêu cầu về phần cứng và hệ điều hành sử dụng Hệ điều hành tối thiểu: Windows 2000 Service Pack 4; Windows Server 2003 Service Pack 1; Windows XP Service Pack 2 Phần cứng: - Máy tính chip Pentium III 600 MHz trở lên (Cấu hình đề nghị: Chip 1 GHz hoặc cao hơn.) - Tối thiểu 192 MB RAM (Cấu hình đề nghị: 512 MB RAM.) - Ổ cứng còn trống tối thiểu 525 MB
  38. 38 Bộ cài đặt: - 1. Để cài đặt SQL Server 2005 Express, máy bạn phải có bộ Windows Installer 3.1 trở lên, download về tại địa chỉ: - 2. Microsoft .Net Framework 2.0 trở lên o Hệ điều hành 32bit: o Hệ điều hành 64bit: - 3. Phải có file cài đặt SQL Server 2005 Express, có thể download miễn phí từ Website của Microsoft tại địa chỉ: 4448-8848-dcc397514b41&displaylang=en - 4. SQL Server Management Studio Express: 4BD1-4E3D-94B8-5A0F62BF7796&displaylang=en Sau khi download về, lƣu vào một thƣ mục nào đó để bắt đầu tiến hành cài đặt lần lƣợt: - WindowsInstaller-KB893803-v2-x86.exe: Windows Installer 3.1 - dotnetfx.exe: Microsoft .Net Framework 2.0 - SQLEXPR.EXE: SQL Server 2005 Express - SQLServer2005_SSMSEE.msi: Công cụ quản lý SQL Server Management Studio Express Chú ý, khi cài đặt SQL Server nên để chế độ Mixed mode và đặt mật khẩu cho tài khoản sa
  39. 39 Hình 3.1: Chế độ Mixed mode SQL Server 3.2.2 Cài đặt IIS - Cài IIS 5.1 đối với Windows XP: Bƣớc 1: Vào menu Start -> Control Panel Bƣớc 2: Vào mục Add, Remove Program Bƣớc 3: Trong cửa sổ mở ra, tiếp tục chọn vào Add, Remove Windows Components Bƣớc 4: Trong cửa sổ tiếp theo, đánh dấu vào mục Internet Information Services (IIS) - đây chính là thành phần mà ta cần cài. Trong quá trình cài, Windows có thể yêu cầu cho đĩa Windows vào ổ CD để nó chép các file cần thiết. Lúc này ta có thể có hai cách: Cho đĩa vào ổ CD và OK. Nếu trên máy đã có sẵn thƣ mục chứa bộ cài đặt Windows, nhấn Browse và tìm đến thƣ mục I386 có trong bộ cài đặt đó. -> OK Khi máy báo cài xong, nhấn Finish.
  40. 40 - Cài IIS 7 đối với Windows 7: Bƣớc 1: Vào Control Panel -> Programs and Features Bƣớc 2: Chọn Turn windows features Bƣớc 3: Một của sổ hiện ra: o Chọn dấu tick vào Internet Infomation Services o Chọn dấu tick vào World Wide Web Services o Chọn dấu tick vào ASP, ASP.Net Click OK 3.2.3 Cài đặt thƣ mục ảo, tạo kết nối và Attach Cơ sở dữ liệu 3.2.3.1 Attach cơ sở dữ liệu (thêm cơ sở dữ liệu đã tồn tại vào SQL Server) Ta có thể dùng SQL Server Management Studio Express để Attach cơ sở dữ liệu. Trƣớc hết, bạn kết nối vào Server, điền tên Server, chọn SQL Server Authentication và tên đăng nhập với mật khẩu. Tiếp theo bạn vào mục Databases, Click chuột phải chọn Attach, một cửa sổ hiện lên, tiếp tục click vào nút Add Rồi chọn file db_quangcao.mdf trong thƣ mục “App_Data” trong thƣ mục của chƣơng trình. Sau đó OK là hoàn tất. 3.2.3.2 Sửa chuỗi kết nối Chƣơng trình đƣợc phát triển ở một nơi khác, một máy chủ chứa cơ sở dữ liệu có thể khác với lúc cài đặt nên bạn phải sửa chuỗi kết nối cơ sở dữ liệu. Tại thƣ mục của chƣơng trình bạn tìm file Web.config. Nếu bạn có Visual Studio thì mở nó, nếu không bạn có thể mở nó bằng notepad hay wordpad. Sau đó bạn tìm đến dòng: Tại phần “Data Source=REKKA” ta thay bằng tên Server SQL 2005 mà ta đã attach cơ sở dữ liệu. “User ID=sa;Password=123456” ta thay bằng tên đăng nhập và mật khẩu mà ta đã dùng để đăng nhập vào SQL Server và attach cơ sở dữ liệu.
  41. 41 3.2.3.3 Tạo thƣ mục ảo + Bạn mở IIS + Di chuyển chuột tới SERVER\Web site\ Default Web Site, nhấn chuột phải vào Default Web Site, chọn New\Virtual Directory + Màn hình sẽ hiển thị ra Virtual Directory Creation Wizard + Nhấn chuột vào nút Next + Gõ chữ “ Web” (hay đặt tên gì cũng đƣợc) vào vùng Alias và chọn Next + Nhấn chuột vào nút Browse, chọn thƣ mục chƣơng trình, và nhấn Next. + Chọn Read và Run script (such as ASP) rồi tiếp tục chọn Next. + Chọn Finish để kết thúc. Bây giờ, ta có thể chạy chƣơng trình bằng các vào trình duyệt gõ để chạy chƣơng trình. “Hostname” là tên Host (máy) mà ta tạo thƣ mục ảo trong IIS. “Alias” là tên tùy chọn trong mục Alias khi tạo thƣ mục ảo 3.3 Hƣớng dẫn sử dụng 3.3.1 Hƣớng dẫn chức năng đăng ký Khi một khách hàng mới đến thăm website, khách hàng muốn đăng tin mà chƣa có tài khoản. Khách hàng phải đăng ký một tài khoản để có quyền đăng thông tin quảng cáo. Ở trang chủ( hình 3.2), khách hàng có thể kích chuột vào menu đăng ký để chuyển đến trang đăng ký
  42. 42 Hình 3.2: Giao diện trang chủ Hình 3.3: Form đăng ký Hình 3.3 là Form đăng ký, khách hàng nhập đầy đủ thông tin vào các trƣờng. Những trƣờng bắt buộc là Tên đăng nhập, mật khẩu, Email. Email là quan trọng, yêu cầu khách hàng nhập chính xác, vì Email là nơi để hệ thống website và khách hàng trao đổi thông tin. Khi khách hàng điền đẩy đủ và chính xác các thông tin thì kích chuột vào nút đăng ký. Khi nhận đƣợc thông báo nhƣ hình 3.4 là đăng ký thành công. Một Email đã đƣợc gửi đến cho khách hàng
  43. 43 Hình 3.4: Thông báo đăng ký thành công 3.3.2 Hƣớng dẫn chức năng đăng tin Để có quyền đăng đƣợc thông tin, trƣớc hết khách hàng phải đăng nhập. Sau khi đăng nhập. Khách hàng kích chuột vào menu đăng tin trên thanh menu để chuyển đến trang đăng tin.
  44. 44 Hình 3.5: Form đăng ký Khách hàng điền đầy đủ những thông tin, Tiêu đề, Danh mục,Hạn đăng Khách hàng có thể xem bảng giá bằng cách kich vào link “Xem bảng giá các gói
  45. 45 cƣớc”. Khách hàng có thể soạn thảo nội dung tin quảng cáo của mình bằng một editor giao diện bắt mắt dễ dùng nhƣ trong hình 3.5 .Khi đăng tin thành công, khách hàng cũng sẽ nhận đƣợc một thông báo thanh toán vào Email nhƣ hình 3.6 Hình 3.6: Email thông báo khách hàng đăng tin 3.3.3 Hƣớng dẫn chức năng gia hạn Khi thông tin hết hạn, một Email sẽ đƣợc gửi đến cho khách hàng, thông báo thông tin quảng cáo của bạn đã hết hạn để hiển thị lên website. Khách hàng sẽ đăng nhập, rồi vào chức năng “Bảng điều khiển” để gia hạn thông tin
  46. 46 Hình 3.7: Bảng điều khiển khách hàng Sau khi kích vào link gia hạn cho thông tin khách hàng chọn, sẽ chuyển đến trang gia hạn. Khách hàng chọn số ngày gia hạn. Sau khi gia hạn thành công, sẽ có một email thông báo gia hạn và thanh toán đƣợc gửi đến cho khách hàng.
  47. 47 Hình 3.8: Email thông báo gia hạn 3.3.4 Hƣớng dẫn một số chức năng trong Administrator Control Chức năng này là dành cho các quản trị viên. 3.3.4.1 Chức năng “quản lý tin” và duyệt tin Hình 3.9: Duyệt tin Những thông tin khách hàng đã đăng hoặc đã gia hạn nhƣng chƣa thanh toán sẽ đƣợc hiển thị. Khi đã nhận đƣợc thanh toán, quản trị viên có thể kích link nút mở, để đồng ý hiển thị thông tin lên web. Kích vào link gia hạn để đồng ý gia hạn.
  48. 48 3.3.4.2 Chức năng “Quản lý thành viên” Hình 3.10: Quản lý thành viên Quản trị viên có thể sửa thông tin thành viên, có thể khóa hay mở. Khi một thành viên bị khóa, thành viên đó sẽ không đăng nhập đƣợc.
  49. 49 KẾT LUẬN Đồ án đã thực hiện các nhiệm vụ sau: - Mô tả nghiệp vụ của bài toán và tiến hành mô hình hóa nghiệp vụ bài toán chuẩn bị cho bƣớc sau. - Phân tích bài toán theo hƣớng cấu trúc bao gồm phân tích dữ liệu và phân tích xử lý. - Thiết kế hệ thống Website bao gồm thiết kế kiến trúc, thiết kế dữ liệu, thiết kế giao diện và các mô đun xử lý. - Cài đặt hệ thống và thử nghiêm với một số dữ liệu. Trong thời gian nghiên cứu, xây dựng Website, em đã hết sức cố gắng làm việc với sự giúp đỡ tận tình của thầy giáo hƣớng dẫn. Chƣơng trình đã đạt đƣợc một số kết quả nhất định. Tuy nhiên trình độ và kinh nghiệm còn hạn chế; chƣơng trình vẫn còn nhiều thiếu sót. Rất mong các thầy cô giáo và các bạn tận tình giúp đỡ để chƣơng trình ngày càng đƣợc hoàn thiện hơn. Nếu đƣợc phát triển tiếp đề tài này, em sẽ tiếp tục cố gắng hoàn thiện các chức năng của Website để có thể đáp ứng đƣợc với nhu cầu của các doanh nghiệp.
  50. 50 TÀI LIỆU THAM KHẢO Tài liệu tiếng Việt [1]. Nguyễn Văn Vỵ, Phân tích và thiết kế hệ thống thông tin quản lý, NXB Khoa học Tự nhiên và Công nghệ, Hà nội, 2007 [2]. Tài liệu hướng dẫn giảng dậy – Lập trình ứng dụng web với ASP.NET, Trung tâm tin học – Đại học Khoa Học Tự Nhiên thành phố Hồ Chí Minh, tháng 6 năm 2005 [3]. Website Tài liệu tiếng anh [1]. Microsoft®, MSDN Library, us/library/ms123401.aspx