Tốt nghiệp đại học- Nghiên cứu công nghệ JSP & Java, xây dựng Website bán hàng cho công ty cổ phần chế biến gỗ Việt Đức Kha

Trước hết là trang index.jsp, đây là trang chủ của một ứng dụng. Trong trang này ta đọc từ bảng dữ liệu message các chủ đề hiện có. Hiển thị các chủ đề và phân trang chúng(5 mẫu tin đọc được trên một trang). Người dùng có thể kích chuột vào các liên kết Previous hoặc Next để đi đến các trang dữ liệu khác.

pdf58 trang | Chia sẻ: lylyngoc | Lượt xem: 2345 | Lượt tải: 1download
Bạn đang xem trước 20 trang tài liệu Tốt nghiệp đại học- Nghiên cứu công nghệ JSP & Java, xây dựng Website bán hàng cho công ty cổ phần chế biến gỗ Việt Đức Kha, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
ày sẽ được trình biên dịch trang bỏ qua không quan tâm đến. Ví dụ: <%-- out.println (“ Đoạn này trình biên dịch sẽ bỏ qua”) --%> Dấu chú thích này rất có hiệu quả. Nó giúp ta tạm thời cô lập hoặc che bỏ tác dụng của một đoạn mã Java nào đó đang bị lỗi trong trang JSP. Ta chỉ tạm thời làm mất tác dụng của chúng chứ không cần xố bỏ. 1.4. Khai báo phương thức và biến hằng Một cú pháp nữa mà JSP cung cấp đó là . Cú pháp này cho phép ta định nghĩa một hoặc nhiều phương thức và biến. Phương thức và biến sau đó có thể được triệu gọi bất kỳ nơi đâu trong trang JSP. 2. Các đối tượng của JSP: Trong JSP chúng ta có thể truy cập một số đối tượng của JSP mà không cần phải khai báo. Trình dịch JSP sẽ nhận dạng những đối tượng này và dịch sang trang Servlet. 2.1. Đối tượng Request: Đối tượng Request đại diện cho đối tượng javax.servlet.http.HttpServletRequest. Giao diện HttpServlet được định nghĩa như một đối tượng truy cập đến thông tin header của giao thức HTTP được gởi về trình khách. Đối tượng request thường được truyền như đối số cho phương thức service(), ví dụ: Error! Một trong những ứng dụng thông thường nhất của đối tượng request là nắm giữ các tham số. Chúng ta có thể thấy điều này bằng cách gọi phương thức getParameter() của request. Phương thức này thừa kế từ lớp cha là javax.ServletRequest. Phương thức này nhận tên tham số và trả về giá trị chuỗi tương ứng với tên của tham số đó. Phương public void jspService (HttpServletRequest request, HttpServiceResponse response) throws IOException, Servlet ( ) Đồ án tốt nghiệp đại học GVHD: Nguyễn Đức Thuần SVTH: Nguyễn Văn Ty Trang 18 thức getParameter() sẽ trả về giá trị của tham số mà nó giữ, nếu tham số này là null, nó sẽ trả về giá trị null. Ngồi ra, vì đối tượng request đại diện cho đối tượng javax.servlet.http.HttpServletRequest nên có thể sử dụng các phương thức của javax.servlet.http.HttpServletRequest trên request như getSession(), getCookies(), getRemoteUser()… 2.2. Đối tượng Response: Một đối tượng khác của JSP là đối tượng response. Đối tượng response cho phép phản hồi thông tin xử lý từ trình chủ trở về trình duyệt. Hầu hết ứng dụng thông thường của đối tượng response là dùng để xuất HTML ra trình duyệt. Đối tượng response thường gọi phương thức getWriter() để thực hiện kết xuất. Các phương thức mà đối tượng respons thường sử dụng được liệt kê như sau: - response.sendRedirect(java.lang.String location): gởi đối tượng response một lần nữa đến một trang JSP được chỉ định trong đối số của phương thức. - response.setContenType(java.lang.String type): Định dạng nội dung xuất là kiểu type - đối số của phương thức. 2.3. Đối tượng Session: Đối tượng session tham chiếu đến đối tượng javax.servlet.http.HttpSession. Đối tượng session dùng để lưu các đối tượng khác từ những yêu cầu của client. Chúng đưa ra hầu hết trạng thái đầy đủ của HTTP. Đối tượng session được khởi tạo bằng cách gọi phương thức pageContext.getSession() để tạo ra trang servlet. Cú pháp như sau: Error! Khi cần một biến nào đó có giá trị tồn cục từ khi mở cho đến khi kết thúc trình duyệt, ta chọn đối tượng session. Đối tượng session sẽ tạo biến cục bộ cho phép lưu một giá trị nào đó từ trang JSP này đến trang JSP khác trong suốt phiên làm việc của chúng ta. Để đối tượng session có thể lưu giữ những biến của chương trình ta cần phải khai báo như sau: Error! Trong đó name là tên biến value là giá trị của biến. session = pageContext.getSession() session.setAttribute(java.lang.String name, java.lang.Object value) Đồ án tốt nghiệp đại học GVHD: Nguyễn Đức Thuần SVTH: Nguyễn Văn Ty Trang 19 Khi cần truy xuất một biến nào đó của đối tượng session ta cần phải sử dụng phương thức getAtribute() như sau: name chính là tên của biến mà ta cần truy xuất. Error! 2.4. Đối tượng Application: Đối tượng application tham chiếu đến javax.servlet.ServletContext cho phép lưu giữ cấu hình tồn cục của Servlet và JSP. Cách đối tượng application khởi tạo như sau: Error! Trong đó pageContext là một đối tượng JspFactory. Đối tượng application có phạm vi hoạt động ở cấp ứng dụng, nghĩa là có thể giữ giá trị của tất cả các trang JSP ở những session khác nhau cho tới khi JSP engine bị đóng lại. Tương tự như session, ta có thể gọi phương thức application.setAtribute() để lấy về giá trị lưu giữ trong application. Phương thức application.setAtribute() được dùng để đặt trị cho biến cần chứa trong application. 2.5. Đối tượng Out: Đối tượng out đùng để ghi kết xuất gởi về trình duyệt. Đối tượng out hình thành từ lớp java.io.Writer. Ví dụ: Error! dùng để ghi câu “Hello world!” lên trình duyệt của máy khách. 2.6. Đối tượng Config: Đối tượng config tượng trưng cho lớp ServletConfig, nó được định nghĩa là đối tượng tạo bởi servlet chứa các thông tin cấu hình của servlet. Với thông tin cấu hình này servlet sẽ truy cập đối tượng ServletContext. Phương thức khởi dựng như sau: Error! pageContext là một đối tượng JspFactory. Trong nhiều trường hợp ta không cần phải sử dụng đối tượng config. Truy cập đến ServletContext thông qua đối tượng application cũng đạt được kết quả tương tự. 2.7. Đối tượng Exception: Đối tượng Exception chỉ tồn tại trong trang xử lý lỗi (error page). Nó dùng để tham chiếu đến nguyên nhân gây ra lỗi mà trang xử lý lỗi có liên quan. out.print(“Hello world!”); session. getAttribute(java.lang.String name) application = pageContext.getServletContext(); config = pageContext.getservletconfig(): Đồ án tốt nghiệp đại học GVHD: Nguyễn Đức Thuần SVTH: Nguyễn Văn Ty Trang 20 Lỗi có thể xuất hiện trong quá trình hoạt động của trang JSP ở hai giai đoạn: giai đoạn thứ nhất lỗi thường phát sinh ở bước khởi tạo. Ở bước này trang JSP nhận yêu cầu từ trình khách và chuẩn bị thực thi, tuy nhiên trước khi thực thi trang JSP cần được dịch ra mã .class của Java và quá trình dịch có thể sinh lỗi. Lỗi ở bước này còn gọi là lỗi thời điểm dịch (translation time error). Giai đoạn thứ hai, trang JSP có thể phát sinh lỗi trong quá trình phản hồi các yêu cầu xử lý. Lỗi này được gọi là lỗi thời điểm yêu cầu (request time error). Kiểu lỗi JSP thứ nhất có thể xuất hiện khi trang JSP lần đầu tiên được triệu gọi. Trang JSP sẽ đi qua quá trình biên dịch từ tâïp tin nguồn .jsp thành mã Java .java sau đó được biên dịch thành đối tượng servlet ở mã byte-code là tập tin .class. Lỗi ở giai đoạn này thường do quá trình biên dịch thất bại hoặc do lỗi cú pháp khi thông dịch từ JSP sang mã nguồn Java. Lỗi này thường được báo với trạng thái mã lỗi là 500 hoặc trình chủ Web có thể thông báo những mã lỗi biên dịch của riêng Java. Lỗi tại thời điểm dịch thường được quản lý bởi bộ thông dịch JSP (JSP engine). Kiểu lỗi thứ hai của trang JSP liên quan đến quá trình xử lý các yêu cầu (request). Những lỗi này còn được xem là lỗi lúc thực thi (runtime error). Chúng có thể xuất hiên bên trong nội dung trang JSP hoặc xuất phát từ lời gọi phương thức nào đó của một đối tượng. Thường đối với kiểu lỗi này ngoại lệ (excepton) sẽ được phát sinh. Các ngoại lệ có thể bị đón bắt và xử lý bởi các đoạn mã JSP thích hợp (thường là trong khối lệnh try{} catch (Exception){}). Tuy nhiên đối với những ngoại lệ phát sinh nhưng không được người ta viết trang JSP đón bắt xử lý thích hợp thì ngoại lệ và lỗi sẽ được gởi đến bộ xử lý lỗi của trình biên dịch JSP. Bản thân trình biên dịch JSP sẽ sinh ra trang thông báo mô tả cụ thể lỗi trả về cho trình khách. Ta có thể hồn tồn đón bắt và thay thế những trang thông báo lỗi này sử dụng đối tượng exception. Để tạo ra trang thông báo lỗi ta cần khai báo như sau: Error! 3. Các hành động của JSP: Hành động trong JSP là quá trình trừu tượng hố việc thực thi hay yêu cầu JSP thực hiện một nhiệm vụ nào đó. a. Hành động : Hành động được dùng để cung cấp và tạo các giá trị cho các tham số theo dạng name/value. thường dùng chung với các hành động <JSP: include>, , . Cú pháp của hành động được mô tả như sau: //Chỉ thị trang JSP hiện hành là trang xử lý lỗi //hiển thị nội dung thông báo lỗi phát sinh Error: has been reported. Đồ án tốt nghiệp đại học GVHD: Nguyễn Đức Thuần SVTH: Nguyễn Văn Ty Trang 21 Error! Name: thuộc tính này trình bày tên của thông số tham chiếu. Value: thuộc tính này trình bày giá trị của tên được tham chiếu. b. Hành động : Hành động cung cấp cấu trúc cho sự phối hợp tài nguyên tĩnh và hành động của trang JSP hiện tại. Cú pháp của hành động này như sau: Error! Error! Page: thuộc tính này trình bày quan hệ đường dẫn của tập tin ta muốn include. Flush: thuộc tính này trình bày giá trị Boolean là true hay false. Cú pháp đầu tiên mô tả yêu cầu nhúng (include) tập tin cần đưa vào trang JSP. Cú pháp thứ hai chứa đựng phần tử con param được dùng để làm tham số cho mục đích include. c. Hành động : Hành động cho phép trình dịch JSP gởi đi tại thời điểm thực thi một yêu cầu hiện hành đến tài nguyên tĩnh, servlet, hay trang JSP khác. Khi hành động này thực thi nó sẽ kết thúc trang hiện tại. Hành động có thể chứa hành động . Những thuộc tính này cung cấp các giá trị cho thông số yêu cầu dùng cho việc chuyển hướng. Cú pháp của hành động được mô tả như sau: Error! < jsp: forward page = “relativeURLspec”> Đồ án tốt nghiệp đại học GVHD: Nguyễn Đức Thuần SVTH: Nguyễn Văn Ty Trang 22 Page: thuộc tính này diễn tả quan hệ URL của đích mà hành động <jsp: forward> sẽ chuyển đến. Hành động thường được dùng như một điều kiện trong JSP để chuyển hướng xử lý. d. Hành động : Hành động cho phép JSP tạo trang HTML chứa đựng tính hợp lệ của cấu trúc trình duyệt máy khách, ví dụ như đối tượng Object hay đối tượng nhúng (Embed). Hành động tạo một thẻ hay đưa ra dòng xuất của đối tượng response. Cú pháp của hành động như sau: Error! Thuộc tính của hành động cho phép cấu hình dữ liệu để thể hiện phần tử đó. Type: thuộc tính này thể hiện loại plugin cần đưa vào. Ta có thể dùng applet làm một thành phần nhúng. Code: thuộc tính này cho biết tên của lớp (class) sẽ được nhúng. Codebase: thuộc tính này là tham chiếu cơ sở hay đường dẫn liên hệ đến tập tin plugin .class. 4. JDBC và ODBC (Java Database Connectivity và Open Database Connectivity). 4.1. JDBC. JDBC (Java Database Connectivity) là giao thức của Java dùng để thực hiện câu lệnh SQL. JDBC cung cấp tập hợp các lớp và giao diện cho phép phát triển các ứng dụng Java và ứng dụng Web liên quan đến truy xuất cơ sở dữ liệu. Tương tác căn bản nhất của của JDBC được liệt kê như sau: Mở một kết nối với cơ sở dữ liệu (Open connection). Thực thi các câu lệnh SQL (Execute SQL). Xử lý dữ liệu (Process results). <jsp:plugin type = “pluginType” code = “classFile” codebase = “relativeURLpath” > . . . Đồ án tốt nghiệp đại học GVHD: Nguyễn Đức Thuần SVTH: Nguyễn Văn Ty Trang 23 Đóng kết nối (Close connnection). Đoạn mã sau đây sẽ diễn giải từng bước cách thực hiện kết nối với cơ sở dữ liệu bằng JDBC: // Bước 1. Khai báo biến Connection cn; Statement stat; ResultSet rs; // Mở kết nối cơ sở dữ liệu ODBC với tên nguồn dữ liệu (datasource name)Woodstore thông qua ODBC static final String DBDriver ="sun.jdbc.odbc.JdbcOdbcDriver"; static final String strConn ="jdbc:odbc:woodstore"; // Bước 2. Tham chiếu đến đối tượng cơ sở dữ liệu stat = conn.createStatement(); // Bước 3. Thực hiện câu lệnh SQL sSQL = "select * from items where " + sWhere; // Bước 4 Xử lý dữ liệu While (rs.next() ){ … }// Kết thúc vòng While //Bước 4. Đóng kết nối rs.close(); stat.close(); con.close(); 4.2. ODBC Open Database Connectivity (ODBC) là một trong những kỹ thuật giao tiếp cơ sở dữ liệu kiểu cũ được Microsoft cung cấp. Nó chính là bậc tiền bối của ADO. Một trong những lý do chính của Microsoft khi giới thiệu kỹ thuật này là cho phép lập trình viên có một phương pháp dễ dàng đễ truy cập nội dung của các cơ sở dữ liệu không thuộc về một định dạng quen thuộc đối với lập trình viên. Nói cách khác, ta không cần biết đến ngôn ngữ lập trình Xbase vẫn có thể truy cập đến một file DBF hay Access Basic để lấy dữ liệu trong một file MDB. Vì SQL là ngôn ngữ không thân thiện lắm đối với người sử dụng nên ta phải sử dụng qua một công cụ trung gian đóng vai trò thiết kế để thể hiện các câu lệnh của SQL cho người sử dụng dễ thao tác hơn, công cụ đó chính là JRUN, để JRUN có thể truy xuất các tập tin MDF của SQL ta phải sử dụng cầu nối ODBC. Đồ án tốt nghiệp đại học GVHD: Nguyễn Đức Thuần SVTH: Nguyễn Văn Ty Trang 24 Ta có thể thấy rằng ODBC làm việc như phần ruột của WINDOWS, nó sẽ sử dụng các trình điều khiển trong các DLL để thi hành công việc. ODBC có hai tập hợp các trình điều khiển: một tập hợp sử dụng tiếng nói của trình quản lí cơ sở dữ liệu và tập kia cung cấp phương pháp giao tiếp thông thường cho ngôn ngữ lập trình. Sự kết hợp của hai tập thông qua một giao diện chấp nhận được cho phép JRUN truy cập nội dung của cơ sở dữ liệu bằng cách sử dụng một tập hàm chuẩn các hàm gọi. Dĩ nhiên có nhiều kiểu tiện ích DLL đi kèm với ODBC. Ví dụ như một trong các DLL sẽ cho phép ta làm chủ nguồn dữ liệu ODBC. Còn giao diện chủ cho ODBC có trog file CPL (bảng điều khiển) ở thư mục SYSTEM . ODBC đưa ra đảm bảo rằng có thể cung cấp được phương pháp để lấy nội dung trong cơ sở dữ liệu mà không có vấn đề gì. Mặc dù trong một số trường hợp, nó không cung cấp được cách tốt nhất để có thể chuyển đổi dữ liệu giữa trình quản lí cơ sở dữ liệu và JRUN, nhưng nói chung là tốt. Chỉ có một điều duy nhất cần chú ý là tốc độ thi hành của nó rất chậm. Nhưng các phiên bản mới của ODBC đã có những cải tiến đáng kể về tốc độ. Do đó ngày nay nó đã được đánh giá khả quan hơn nhiều. Hầu như công việc lập trình ứng dụng mà JSP và servlet thường thực hiện nhất đó là lưu trữ và truy xuất cơ sở dữ liệu.Việc truy xuất cơ sở dữ liệu trong JSP và servlet dựa vào trình truy xuất ODBC theo chuẩn java. Đồ án tốt nghiệp đại học GVHD: Nguyễn Đức Thuần SVTH: Nguyễn Văn Ty Trang 25 Chương III ĐẶC TẢ TÍNH NĂNG PHẦN II CÀI ĐẶT ỨNG DỤNG Đồ án tốt nghiệp đại học GVHD: Nguyễn Đức Thuần SVTH: Nguyễn Văn Ty Trang 26 Dựa vào yêu cầu của bài tốn, ta nhận thấy hệ thống xây dựng phục vụ chủ yếu cho ba vấn đề sau: * Quản trị hệ thống. * Diễn đàn (forum). * Khách mua hàng. I. QUẢN TRỊ HỆ THỐNG Quản trị hệ thống là người làm chủ ứng dụng, họ có quyền kiểm sốt mọi hoạt động của hệ thống. Mỗi quản trị hệ thống sẽ được cấp một username và password, để thực hiện những chức năng của mình, họ phải đăng nhập vào hệ thống bằng username và password của họ. Nếu như quá trình đăng nhập thành công thì quản trị hệ thống có những chức năng sau: * Chức năng của quản trị đối với quản trị: Thay đổi những thông tin của quản trị. Thêm quản trị. Xóa bỏ quản trị. * Chức năng của quản trị đối với sản phẩm: Thêm sản phẩm mới. Xóa sản phẩm. Cập nhật lại sản phẩm. Hiển thị các sản phẩm, hay xóa sản phẩm khi hết hạn sử dụng. * Chức năng của quản trị đối với đơn đặt hàng: Hiển thị đơn đặt hàng. Xóa đơn đặt hàng. * Chức năng của quản trị đối với khách hàng: Thêm khách hàng mới. Thay đổi thông tin khách hàng. Xố bỏ khách hàng. II. KHÁCH MUA HÀNG. Khách mua hàng là những người vào hệ thống để tìm kiếm các mặt hàng cần mua và đặt hàng với hệ thống. Khách mua hàng có thể tìm hàng mình cần theo: Tên mặt hàng (có thể là một ký tự, chữ, câu….). Tên loại hàng. Đồ án tốt nghiệp đại học GVHD: Nguyễn Đức Thuần SVTH: Nguyễn Văn Ty Trang 27 Khách hàng có thể thêm bớt những sản phẩm mình muốn hay không muốn mua vào trong hay ra khỏi giỏ hàng của mình. Sau khi tìm được hàng mình cần, họ đặt mua hàng với hệ thống. Hệ thống sẽ chuyển đơn đặt hàng của họ cho dịch vụ mà họ đặt mua. III. DIỄN ĐÀN (FORUM). Diễn đàn sẽ giúp khách hàng, cũng như những người trong công ty trao đổi, học hỏi những kinh nghiệm lẫn nhau. Chức năng của diễn đàn: Liệt kê tất cả các topic. Xem nội dung một topic. Trả lời một topic. Xố một topic. Chương IV XÂY DỰNG ỨNG DỤNG WOOD STORE I. HOẠT ĐỘNG VÀ LƯU ĐỒ CỦA ỨNG DỤNG. 1. Hoạt động của ứng dụng. Một ứng dụng e_commerce đơn giản là web site cung cấp thông tin để khách hàng có thể liên lạc và biết rõ về sản phẩm và những dịch vụ mà công ty đưa ra. Tiếp đến khách hàng có thể đặt mua, thanh tốn và hẹn ngày giao hàng hay nhận sự hổ trợ về dịch vụ từ nhà cung cấp. Tất cả các dịch vụ nêu trên đều diễn ra trên mạng và kiểm sốt bởi ứng dụng web này. Hai hình thức cơ bản diễn ra trên mạng và kiểm sốt bởi ứng dụng thương mại điện tử ngày nay là B2B (Business to Business) còn gọi là từ doanh Đồ án tốt nghiệp đại học GVHD: Nguyễn Đức Thuần SVTH: Nguyễn Văn Ty Trang 28 nghiệp đến doanh nghiệp, và B2C (Business to Customer) còn gọi là từ doanh nghiệp đến người tiêu dùng. Ứng dụng Wood Store của ta là một Web site hổ trợ việc bán các sản phẩm gỗ trên mạng. Từ trang chủ này, người dùng có thể tìm kiếm, xem các sản phẩm trong tuần, duyệt theo các thể loại sản phẩm khác nhau. Ngồi ra khách hàng còn có thể đăng ký thành viên trong web site, tham dự diễn đàn (forum). Đầu tiên khách hàng có thể tham khảo công ty qua trang giới thiệu. Trang này sẽ gới thiệu cho ta biết về công, và những điều cần biết. Hình3.1: Trang giới thiệu về công ty Cụ thể, khi người dùng kích chuột vào một sản phẩm, họ có thể biết được tên, giá cả, những chú ý khác về sản phẩm,… Đồ án tốt nghiệp đại học GVHD: Nguyễn Đức Thuần SVTH: Nguyễn Văn Ty Trang 29 Hình3.2: Trang chủ Hình3.3: Trang chi tiết sản phẩm Nếu muốn mua sản phẩm đó, khách hàng bấm nút Add to Shopping Cart. Sản phẩm cần mua sẽ được đưa vào giỏ hàng. Giỏ hàng là nơi chứa danh sách các mục hàng mà người dùng chon mua trong quá trình duyệt Web site. Người dùng có thể thay đổi số lượng mua, thêm bớt các mục hàng tại đây hoặc quay trở lại chọn các mục hàng khác. Một khi đã quyết định mua, khách hàng bấm vào nút nhấn Check Out để đi đến trang xác nhận thanh tốn. Đồ án tốt nghiệp đại học GVHD: Nguyễn Đức Thuần SVTH: Nguyễn Văn Ty Trang 30 Hình3.4: Trang giỏ hàng Lúc này, khách hàng thấy rõ tổng số tiền cần phải trả, số mặt hàng cần mua cùng với số lượng, đơn giá cụ thể. Mục đích để người dùng kiểm tra lại lần cuối những mặt hàng mình đã chọn. Nếu đồng ý mua hàng, người dùng bấm vào nút Order Now. Trang điền các thông tin về giao hàng và thanh tốn sẽ xuất hiện (Hình Creater Order). Tại đây nhiệm vụ của khách hàng là cung cấp thêm các thông tin để tạo đơn hàng. Những thông tin này bao gồm: loại hình thanh tốn (bằng tiền mặt, bằng credit card, sec), cách thức giao hàng, địa chỉ liên lạc,… sau cùng khách hàng nhấn vào nút Save Order để tạo đơn đặt hàng và hồn tất quá trình giao dịch. Web site của ta sẽ lưu đơn hàng vào cơ sở dữ liệu, tạo mã số đơn hàng và thông báo đến khách hàng giao dịch đã hồn tất. Hình 3.5: Trang check out Đồ án tốt nghiệp đại học GVHD: Nguyễn Đức Thuần SVTH: Nguyễn Văn Ty Trang 31 Hình3.6: Trang creater Order Để hổ trợ khách hàng trong quá trình mua sắm trên mạng ta cung cấp thêm cơ chế tìm kiếm trên Web site. Từ trangchủ, nếu nhập vào một tên sản phẩm nào đó và nhấn nút search, danh mục các sản phẩm có trong danh sách sản phẩm sẽ hiển thị theo mong muốn của khách hàng. Hình 3.7: Trang tìm kiếm(Search) Ngồi việc tìm kiếm theo tên sản phẩm, để tạo thuận tiện cho người dùng ta bố trí thêm trang thực hiện tìm kiếm những yêu cầu cao hơn (để đến với trang này người dùng kích chuột vào liên kết Advance Search của trang chủ). Trang tìm kiếm Advance Search cho phép tìm mục hàng hay tên sản phẩm, tên công ty sản xuất, giá cao nhất và giá thấp nhất… Đồ án tốt nghiệp đại học GVHD: Nguyễn Đức Thuần SVTH: Nguyễn Văn Ty Trang 32 Hình3.8: Trang tìm kiếm yêu cầu cao hơn (AdvancedSearch) Ngồi ra, người dùng có thể chọn mục Registration từ trang chủ để đăng ký làm thành viên của Web site. Trang đăng ký sẽ nhập đầy đủ những thông tin cần thiết giúp người dùng tận dụng những Web site forum, … Đăng ký làm thành viên cũng là yêu cầu bắt buộc nếu như khách hàng đó thực hiện mua hàng trên Web site. Những thông tin này được Web site lưu trữ để liên lạc với khách hàng. Hỗ trợ các dịch vụ hậu mãi cho khách hàng sau này. Vì những thông tin đăng ký sẽ được sử dụng về sau nên bạn phải nhập chính xác thông tin này. Nếu nhập sai bạn sẽ được yêu cầu nhập lại các trường thông tin không hợp lệ. Hình 3.9: Trang đăng ký (Registration) Người dùng trước khi lướt qua Web có thể chọn mục Sign In từ trang chủ để đăng nhập vào Web site. Nếu khách hàng đăng ký làm thành viên của Web site bạn sẽ được cấp một tài khoản đăng nhập (gồm Username/password). ta sử dụng tài khoản này để đăng nhập vào hệ thống. Đồ án tốt nghiệp đại học GVHD: Nguyễn Đức Thuần SVTH: Nguyễn Văn Ty Trang 33 2. Lưu đồ hoạt động của ứng dụng. 2. Các lưu đồ hoạt động của website. a. Lưu đồ hoạt động của web site phục vụ khách hàng và người quản trị. b. sơ đồ phân rã các chức năng của ứng dụng. Trang chủ (Home page) Các dịch vụ forum,… Xem nội dung chi tiết một sản phẩm Chọn sản phẩm cần mua thêm vào danh mục giỏ hàng (Shopping Cart) Xác nhận việc mua hàng (Check out) Đặt hàng Thành Viên? Quản trị Đăng nhập (login) Lưu đơn hàng và hẹn ngày giao hàng Tìm kiếm Yes No Sản phẩm Đăng ký SƠ ĐỒ PHÂN RÃ CÁC CHỨC NĂNG ADMIN FORUM KHÁCH HÀNG Đồ án tốt nghiệp đại học GVHD: Nguyễn Đức Thuần SVTH: Nguyễn Văn Ty Trang 34 c. Lưu đồ mua hàng trên mạng d. Lưu đồ xử lý kiểm tra khách hàng mua hàng : Không tồn tại Tồn tại Bắt đầu mua hàng Màn hình giao tác Kết thúc Chọn hàng hóa Đặt hàng Đăng ký thành viên Kết thúc Xác nhận đơn hàng Mở table members Kiểm tra người dùng ? Tìm kiếm hàng hóa Yêu cầu nhập username-password Bắt đầu đăng nhập Đồ án tốt nghiệp đại học GVHD: Nguyễn Đức Thuần SVTH: Nguyễn Văn Ty Trang 35 e. Lưu đồ xử lý kiểm tra người quản trị. Yêu cầu nhập username-password Mở table members Kiểm tra có tồn tại? Bắt đầu đăng nhập Đồ án tốt nghiệp đại học GVHD: Nguyễn Đức Thuần SVTH: Nguyễn Văn Ty Trang 36 II. XÂY DỰNG ỨNG DỤNG WOOD STORE 1. Thiết kế xử lý. 1.1. Thiết kế xử lý cho người quản lý. 1.1.1. Phân tích các hành động. Để thiết kế các xử lý phục vụ cho người quản lý, ta cần phân tích kỹ các hoạt động của người quản lý để có thể thực hiện trong thực tế. Và từ sự phân tích này ta sẽ có những xử lý thích hợp cho hệ thống. Các hành động của một công ty trong thực tế để theo dõi quá trình mua bán hàng hóa sẽ được mô tả bằng bảng sau: Các hành động của người quản lý trong thực tế được mô tả bằng bảng sau: STT HOẠT ĐỘNG MÔ TẢ 1 Quản lý khách hàng Quản lý những khách hàng Đồ án tốt nghiệp đại học GVHD: Nguyễn Đức Thuần SVTH: Nguyễn Văn Ty Trang 37 2 Quản lý đơn hàng Quản lý các đơn hàng của khách hàng 3 Quản lý sản phẩm Cập nhật(thêm, xố, sửa) các sản phẩm 1.1.2. Thiết kế xử lý. a. Quản lý khách hàng.  Thay đổi thông tin về khách hàng: Hoạt động này được người quản lý thực hiện nhằm thay đổi thông tin của khách hàng như password, họ, tên, email, địa chỉ…  Thêm một khách hàng.  Xố một khách hàng Một người quản lý có thể xố bỏ một khách hàng nếu khách hàng đó không đủ những thông tin cần thiết, hoặc khách hàng đó không tuân thủ những qui định của công ty. Tóm lại: các hoạt động mà người quản lý có thể tương tác với server để quản lý khách hàng được mô tả bằng sơ đồ sau: Như vậy cần thiết kế các khối xử lý sau để đáp ứng các hành động của khách hàng. XỬ LÝ: Liệt kê danh sách khách hàng(XLKH01) Xử lý này được mô tả như sau:  Tiếp nhận yêu cầu liệt kê danh sách khách hàng .  Lấy danh sách khách hàng từ cơ sở dữ liệu .  Đưa ra danh sách khách hàng . XỬ LÝ: Thay đổi thông tin của khách hàng(XLKH02) Xử lý này được mô tả như sau:  Tiếp nhận yêu cầu thay đổi thông tin.  Lấy các thông tin cần thay đổi.  Cập nhật thông tin thay đổi vào cơ sở dữ liệu.  Thông báo quá trình thay đổi thành công. XỬ LÝ: Thêm khách hàng(XLKH03) Xử lý này được mô tả như sau:  Tiếp nhận đăng ký của khách hàng.  Yêu cầu các thông tin về khách hàng cần thêm. Liệt kê danh sách khách hàng Thay đổi thông tin khách hàng Thêm khách hàng vào hệ thống Xóa khách hàng khỏi hệ thống Đồ án tốt nghiệp đại học GVHD: Nguyễn Đức Thuần SVTH: Nguyễn Văn Ty Trang 38  Kiểm tra các thông tin cần thêm vào xem có phù hợp không. Nếu hợp lệ thì tiếp tục, ngược lại báo không hợp lệ và quay lại bước hai của khối xử lý này.  Ghi nhận thông tin của khách hàng vừa thêm vào cơ sở dữ liệu.  Thông báo quá trình đăng ký thành công. XỬ LÝ: Xố khách hàng(XLKH04) Xử lý này được mô tả như sau :  Tiếp nhận yêu cầu xố khách hàng.  Lấy danh sách khách hàng cần xố.  Xố khách hàng khỏi cơ sở dữ liệu. b. Quản lý sản phẩm:  Thay đổi thông tin sản phẩm .  Thêm sản phẩm.  Xố một sản phẩm: khi một sản phẩm nào đó mà người quản lý thấy cần phải xố đi. Tóm lại: Các hoạt động mà người quản lý tương tác với Server để quản lý sản phẩm được mô tả bằng sơ đồ sau: Như vậy các khối xử lý cần thiết để đáp ứng các hành động của người quản lý trong lĩnh vực sản phẩm như sau: XỬ LÝ: Liệt kê danh sách các sản phẩm (XLSP01)  Tiếp nhận yêu cầu liệt kê danh sách sản phẩm .  Lấy danh sách các sản phẩm từ cơ sở dữ liệu  Đưa ra danh sách các sản phẩm . XỬ LÝ: Thay đổi thông tin sản phẩm(XLSP02)  Tiếp nhận yêu cầu thay đổi thông tin sản phẩm muốn thay đổi.  Lấy các thông tin muốn thay đổi về sản phẩm .  Thay đổi các thông tin này trên tất cả các bảng có liên quan đến mã sản phẩm cần thay đổi.  Cập nhật lại cơ sở dữ liệu. XỬ LÝ: Thêm sản phẩm(XLSP03) Liệt kê các sản phẩm Thay đổi thông tin sản phẩm Thêm một sản phẩm Xoá một sản phẩm Đồ án tốt nghiệp đại học GVHD: Nguyễn Đức Thuần SVTH: Nguyễn Văn Ty Trang 39 Xử lý này được mô tả như sau:  Tiếp nhận yêu cầu thêm sản phẩm  Lấy mã số sản phẩm (item_id) lớn nhất +1 trong bảng items để tạo khố cho sản phẩm mới sắp tạo.  Kiểm tra các yêu cầu cần thêm vào xem có phù hợp không, nếu hợp lệ thì tiếp tục bước 4 của khối xử lý này, ngược lại thì quay lại bước 2 của khối xử lý này.  Ghi nhận thông tin của sản phẩm vừa thêm vào cơ sở dữ liệu. XỬ LÝ: Xố sản phẩm(XLSP04)  Tiếp nhận yêu cầu xố sản phẩm bằng cách lấy khố của sản phẩm muốn xố.  Xố tất cả các bảng có liên quan đến mã sản phẩm này trong cơ sở dữ liệu. c. Quản lý đơn hàng:  Xem thông tin đơn hàng .  Xố một đơn hàng XỬ LÝ: Liệt kê danh sách các đơn hàng(XLĐH01)  Tiếp nhận yêu cầu liệt kê danh sách đơn hàng.  Lấy danh sách các đơn hàng từ cơ sở dữ liệu.  Đưa ra danh sách các đơn hàng. XỬ LÝ: Xố đơn hàng(XLĐH02)  Tiếp nhận yêu cầu xố đơn hàng bằng cách lấy khố của đơn hàng muốn xố.  Xố tất cả các bảng có liên quan đến mã đơn hàng này trong cơ sở dữ liệu.  Thông báo quá trình xố thành công. Tổng kết các xử lý Như vậy, các xử lý phục vụ cho công ty đã được xây dựng. Chúng được tóm tắt lại bằng bảng mô tả và sơ đồ sau: Bảng dưới đây chú sẽ chú thích các khối xử lý XLĐN01 XLKH02 XLKH03 XLKH04 XLKH01 XLSP01 XLSP02 XLSP03 XLSP04 XLKT05 XLĐH01 XLĐH02 Đồ án tốt nghiệp đại học GVHD: Nguyễn Đức Thuần SVTH: Nguyễn Văn Ty Trang 40 STT KHỐI XỬ LÝ MÔ TẢ 1 XLĐN01 Đăng nhập vào hệ thống 2 XLKT05 Kết thúc phiên làm việc 3 XLKH01 Liệt kê danh sách khách hàng 4 XLKH02 Thay đổi thông tin khách hàng 5 XLKH03 Thêm khách hàng mới 6 XLKH04 Xố khách hàng 7 XLĐH01 Liệt kê danh sách đơn hàng 8 XLĐH02 Xố đơn hàng 9 XLSP01 Liệt kê danh sách sản phẩm 10 XLSP02 Thay đổi thông tin sản phẩm 11 XLSP03 Thêm sản phẩm 12 XLSP04 Xố sản phẩm 1.2. Thiết kế xử lý khách hàng. Các xử lý được thiết kế trong phần này sẽ đáp ứng các hành động phục vụ khách hàng trong quá trình tìm kiếm và mua mặt hàng mình cần. Danh sách các xử lý được mô tả bằng bảng sau: STT XỬ LÝ HOẠT ĐỘNG 1 Tìm hàng Tìm kiếm hàng hóa 2 Chọn hàng Lựa chọn mặt hàng trong hệ thống 3 Liêt kê hàng chọn Liệt kê danh sách hàng đã chọn 4 Xóa hàng Xóa mặt hàng đã chọn 5 Cập nhật hàng Thay đổi số lượng mua của mặt hàng đã chọn 6 Mua hàng Đặt mua các mặt hàng đã chọn 7 Đăng ký mới Khách hàng phải đăng ký làm thành viên a. Tìm hàng. Hành động tìm hàng được thực hiện khi khách hàng cần tìm một mặt hàng nào đó từ hệ thống. Để thực hiện hành động tìm hàng, khách hàng sẽ đưa ra các từ khóa cho các mặt hàng cần tìm. Server lấy thông tin về các từ khóa này, tìm kiếm các mặt hàng thỏa điều kiện trong cơ sở dữ liệu và hiển thị danh sách các mặt hàng tìm được. XỬ LÝ: Tìm hàng (XLKH01) Xử lý này được mô tả như sau: Tiếp nhận yêu cầu tìm mặt hàng Lấy các từ khóa tìm hàng từ yêu cầu. Tìm kiếm các mặt hàng thỏa yêu cầu tìm kiếm trong cơ sở dữ liệu Đồ án tốt nghiệp đại học GVHD: Nguyễn Đức Thuần SVTH: Nguyễn Văn Ty Trang 41 Hiển thị danh sách các mặt hàng tìm được. b. Chọn hàng. Trong quá trình tìm kiếm các mặt hàng ở hệ thống, khách hàng sử dụng hoạt động này để chọn mặt hàng khách hàng cần. Hoạt động này sẽ đặt mặt hàng được chọn vào danh sách các mặt hàng được chọn. XỬ LÝ: Chọn hàng (XLKH02) Xử lý này được mô tả như sau: Tiếp nhận yêu cầu chọn hàng. Lấy mặt hàng được chọn từ yêu cầu. Thực hiện việc đặt mặt hàng được chọn vào danh sách hàng chọn. Thông báo việc thực hiện chọn hàng thành công. c. Liệt kê hàng chọn. Hành động này sẽ liệt kê tất cả các mặt hàng mà khách hàng chọn trong quá trình tìm hàng. Hành động này là cơ sở để thực hiện hai hành động: cập nhật hàng chọn và xóa hàng chọn. XỬ LÝ: Liệt kê hàng chọn (XLKH03) Xử lý này được mô tả như sau: Tiếp nhận yêu cầu liệt kê hàng chọn. Lấy số hiệu session của khách hàng từ yêu cầu. Lấy các mặt hàng mà khách hàng đã chọn từ số hiệu session này. Liệt kê danh sách các mặt hàng được chọn. d. Xóa hàng chọn. Hoạt động xóa hàng chọn được thực hiện khi khách hàng có nhu cầu xóa một mặt hàng mà họ đã chọn trong quá trình tìm kiếm hàng hóa. Để thực hiện hành động này, khách hàng sẽ cung cấp cho server danh sách các mặt hàng cần xóa. XỬ LÝ: Xóa hàng chọn (XLKH04) Xử lý này được mô tả như sau: Tiếp nhận yêu cầu xóa hàng chọn. Lấy danh sách các mặt hàng cần xóa từ yêu cầu. Xóa các mặt hàng thỏa mãn yêu cầu từ danh sách hàng chọn. Thông báo việc xóa hàng chọn thành công. e. Cập nhật hàng chọn. Hoạt động cập nhật hàng chọn được khách hàng sử dụng để cập nhật số lượng hàng mà khách hàng đã sử dụng. Khi thực hiện hành động này, khách hàng sẽ cung Đồ án tốt nghiệp đại học GVHD: Nguyễn Đức Thuần SVTH: Nguyễn Văn Ty Trang 42 cấp tên mặt hàng cũng như số lượng hàng cần cập nhật. Server sẽ tiếp nhận yêu cầu này, thay đổi các thông tin cần thiết và thông báo quá trình cập nhật hàng thành công. XỬ LÝ: Cập nhật mặt hàng (XLKH05) Xử lý này được mô tả như sau: Tiếp nhận yêu cầu cập nhật mặt hàng. Tiếp nhận mã mặt hàng và số lượng hàng cần cập nhật. Cập nhật số lượng hàng cần thiết. Thông báo quá trình cập nhật mặt hàng thành công. f. Đăng ký mua hàng. Hoạt động đăng ký mua hàng được khách hàng sử dụng để đăng ký mua các mặt hàng đã chọn. Khi thực hiện hành động này, khách hàng sẽ cung cấp họ tên, địa chỉ giao hàng. Server tiếp nhận các thông tin này và cập nhật đơn đặt hàng của khách hàng vào cơ sở dữ liệu. XỬ LÝ: Đăng ký mua hàng (XLKH06) Xử lý này được mô tả như sau: Tiếp nhận yêu cầu đăng ký mua hàng. Lấy thông tin của khách hàng từ yêu cầu. Từ thông tin này và hóa đơn đặt hàng, cập nhật các thông tin cần thiết vào cơ sở dữ liệu. Thông báo quá trình đặt hàng thành công. g. Đăng kí mới (Tạo mới khách hàng ). Khách hàng muốn tham gia mua hàng phải đăng kí, bao gồm các thông tin do công ty bắt buộc thông qua chương trình, để tiện cho việc quản lý. Các bước đăng kí bao gồm: XỬ LÝ: Đăng kí mới khách hàng(XLKH07)  Tiếp nhận yêu cầu đăng kí username  Tiếp nhận các thông tin đăng kí của username  Kiểm tra các thông tin này xem có phù hợp không như username, password, email… nếu không phù hợp thì quay lại bước hai của khối xử lý này, ngược lại thì tiếp tục.  Lấy max(member_id)+1 theo member_id trong bảng members để tạo khố cho khách hàng .  Ghi nhận các thông tin vào cơ sở dữ liệu.  Thông báo quá trình đăng kí thành công. Đồ án tốt nghiệp đại học GVHD: Nguyễn Đức Thuần SVTH: Nguyễn Văn Ty Trang 43 Tổâng kết xử lý Các xử lý đáp ứng các hoạt động của khách hàng được tổng kết bằng sơ đồ và bảng sau: Bảng dưới đây sẽ chú thích các khối xử lý STT KHỐI XỬ LÝ MÔ TẢ 1 XLKH01 Tìm kiếm hàng hóa 2 XLKH02 Lựa chọn mặt hàng trong hệ thống 3 XLKH03 Liệt kê danh sách hàng đã chọn 4 XLKH04 Xóa mặt hàng đã chọn 5 XLKH05 Thay đổi số lượng đặt mua của mặt hàng đã chọn 6 XLKH06 Đặt mua các mặt hàng đã chọn 7 XLKH07 Đăng ký thành viên mới 8 XLKH08 Kết thúc mua sắm 2. Thiết kế cơ sở dữ liệu. a. Sơ đồ thực thể kết hợp. XLKH06 XLKH04 XLKH05 XLKH03 XLKH08 XLKH01 XLKH02 XLKH07 CTDH_MH MEMBERS Member_id Member_login Member_password Member_level First_name Last_name Email Phone Address Notes Bank_type_id Account_number SHOPPINGCAR T User_id Item_id Item_desc Price quantity ITEMS Item_id Category_id Name Producer Price Product_url Image_url Notes Is_recommended ORDERDETAILS Order_id Item_id Item_desc Quantity price BANK_TYPES Bank_type_id Name CATEGORIE S m em O rd er de ta ils - ite m s mem - sho C at eg or ie s - i te m Ed it - i te m s ba nk - m em Sho - Items Đồ án tốt nghiệp đại học GVHD: Nguyễn Đức Thuần SVTH: Nguyễn Văn Ty Trang 44 b. Thiết kế cơ sở dữ liệu bảng. * Bảng cơ sở dữ liệu : Xây dựng cơ sở dữ liệu cho wood store bao gồm các bảng sau: Editorial_categories:Bảng chứa các đề mục cho trang chủ KEY COMLUMN NAME DATATYPE LENGTH K Editorial_cat_id Smallint 2 Editorial_cat_name Varchar 50 Chú thích: Editorial_cat_id: Mã số đề mục cho trang chủ. Editorial_cat_name: Tên đề mục cho trang chủ. Editorials:Bảng chi tiết các đề mục cho trang chủ KEY COMLUMN NAME DATATYPE LENGTH K Article_id Smallint 2 Editorial_cat_id Smallint 2 Article_title Varchar 200 Article_desc Varchar 200 Item_id Smallint 2 Chú thích: Article_id: Mã số chi tiết của nội dung đề mục. Editorial_cat_id: Mã số đề mục cho trang chủ. Article_title: Tiêu đề chi tiết của đề mục. Article_desc: Nội dung chi tiết của đề mục. Đồ án tốt nghiệp đại học GVHD: Nguyễn Đức Thuần SVTH: Nguyễn Văn Ty Trang 45 Item_id: Sản phẩm mà đề mục mô tả. Categories: Bảng danh mục các thể loại sản phẩm KEY COMLUMN NAME DATATYPE LENGTH K Category_id Smallint 2 Name Varchar 50 Chú thích: Category_id: Mã số phân loại. Category_id: Tên phân loại. Items: Bảng danh mục chi tiết nội dung các sản phẩm KEY COMLUMN NAME DATATYPE LENGTH K Item_id Smallint 2 Category_id Smallint 2 Name Varchar 50 Producer Varchar 50 Price Varchar 50 Product_url Varchar 250 Image_url Varchar 100 Notes Varchar 200 Is_recommended smallint 2 Chú thích: Item_id: Mã số sản phẩm. Category_id: Mã số phân loại. Name: Tên sản phẩm. Producer: Tên công ty sản xuất. Price: Đơn giá. Product_url: Đường dẫn chứa ảnh của sản phẩm. Notes: Giới thiệu sơ về sản phẩm. Is_recommended: Cờ cho phép giới thiệu với khách hàng sản phẩm ở trang chủ. Members: Bảng danh mục chứa thông tin thành viên KEY COMLUMN NAME DATATYPE LENGTH K Member_id Int 4 Member_login Varchar 20 Member_password Varchar 20 Đồ án tốt nghiệp đại học GVHD: Nguyễn Đức Thuần SVTH: Nguyễn Văn Ty Trang 46 Member_level Smallint 2 First_name Varchar 30 Last_name Varchar 30 Email Varchar 50 Phone Varchar 50 Address Varchar 50 Notes Varchar 200 Bank_type_id Smallint 2 Account_number Varchar 50 Chú thích: Member_id: Mã số thành viên. Member_login: Tên đăng nhập. Member_password: Mật khẩu. Member_level: Quyền đăng nhập(1-quyền User thường. 2 - quyền cho người quản trị). First_name: Họ Last_name: Tên. Email: Địa chỉ Email. Phone: Điện thoại. Address: Địa chỉ liên lạc. Notes: Ghi chú khác. Bank_type_id: Tên ngân hàng. Account_number: Số tài khoản ngân hàng. Orders:bảng chứa đơn đặt hàng KEY COMLUMN NAME DATATYPE LENGTH K Order_id Int 4 Member_id Int 4 Payment Varchar 50 Shipping Varchar 50 Orderdate Datetime 8 Chú thích: Order_id: Mã số đơn hàng. Member_id:Mã số thành viên. Payment: Hình thức thanh tốn. Đồ án tốt nghiệp đại học GVHD: Nguyễn Đức Thuần SVTH: Nguyễn Văn Ty Trang 47 Shipping: Hình thức giao hàng. Orderdate:Ngày giao hàng. OrderDetails: bảng chứa chi tiết đơn hàng KEY COMLUMN NAME DATATYPE LENGTH K Order_id Int 4 Item_id Smallint 2 Item_desc Varchar 50 Quantity Smallint 2 price Float 8 Chú thích: Order_id: Mã số đơn hàng. Item_id: Mã số sản phẩm. Item_desc: Tên sản phẩm Quantity: Số lượng mua. Price: Đơn giá. Bank_types:bảng chứa các loại ngân hàng KEY COMLUMN NAME DATATYPE LENGTH K Bank_type_id Smallint 2 Name Varchar 50 Chú thích: Bank_type_id: Mã số ngân hàng. Name: Tên ngân hàng. ShoppingCart:bảng chứa các thông tin về giỏ hàng KEY COMLUMN NAME DATATYPE LENGTH User_id Int 4 Item_id Smallint 2 Item_desc Varchar 50 Price Float 8 quantity Smallint 2 Chú thích: User_id: Mã số thành viên đăng nhập. Item_id: Mã số sản phẩm. Item_desc:Tên sản phẩm Đồ án tốt nghiệp đại học GVHD: Nguyễn Đức Thuần SVTH: Nguyễn Văn Ty Trang 48 Price: Đơn giá Quantity: Số lượng. 3. Các trang dùng cho người quản trị. 3.1. Trang AdminWoodView (Quản trị sản phẩm) Trang này dùng để xem danh sách các mục hàng hiện có trong kho. Tại đây nhà quản trị có thể chọn mục thêm mới, sữa đổi hoặc xố đi các mặt hàng đang có. Vấn đề bảo mật trong trang quản trị này cần phải đặt lên hàng đầu. Bởi những thông tin quản trị thường là những thông tin quan trọng, chỉ danh cho những người có thẩm quyền thì mới được phép sử dụng trang quản trị này. Vì lý do này, hầu như các trang quản trị ta đều gọi hàm checkSecurity() ở đầu trang. Trang AdminWoodView có 3 liên kết cơ bản, một liên kết cho phép thêm mới mục hàng (Add new), liên kết thứ hai cho phép hiệu chỉnh nội dung của mục hàng hiện hành (Edit). Liên kết cuố i cùng cho phép xố mục hàng khỏ i danh sách (Delete). 3.2.AdminOrderView (Quản trị đơn hàng). Quản trị đơn hàng chủ yếu giúp người quản lý xem thông tin các đơn hàng mà khách hàng đã đặt hàng qua mạng. Xem những thông tin mà khách hàng trong cơ sở Đồ án tốt nghiệp đại học GVHD: Nguyễn Đức Thuần SVTH: Nguyễn Văn Ty Trang 49 dữ liệu. Trang này giúp cho người quản lý xem và xố các đơn đặt hàng trong bảng Orders và OrderDetails. 3.3.AdminMemberView (Quản trị người dùng) Ngồi việc quản lý đơn hàng, thay đổi lượng sản phẩm trong kho, ta cung cấp thêm các trang cho phép nhà quản trị quản lý các thành viên đăng ký với Web site. Trang quản trị người dùng này hoạt động giống với các trang quản lý các, nó cơ chế duyệt xem danh sách các thành viên đã đăng ký, xố thành viên đăng ký. Chương V Đồ án tốt nghiệp đại học GVHD: Nguyễn Đức Thuần SVTH: Nguyễn Văn Ty Trang 50 XÂY DỰNG ỨNG DỤNG FORUM I. DIỄN ĐÀN (FORUM) VÀ CƠ CHẾ HOẠT ĐỘNG. 1. Diễn đàn. Trong các ứng dụng Web hoặc các Web site lớn, thường thấy một góc của ứng dụng mang tên diễn đàn hay còn gọi với tên thông dụng trên Internet là forum. Diễn đàn là nơi mọi người đưa ra các ý kiến bàn bạc thảo luận liên quan đến một chủ đề nào đó. Ví dụ diễn đàn có thể giúp cho con người trao đổi kinh nghiệm và học hỏi lẫn nhau, … Diễn đàn là nơi khách hàng có thể trao đổi các vấn đề gút mắc với các công ty, hoặc những người truy nhập vào mà có khả năng tháo gỡ các gút mắc mà khách hàng yêu cầu. Đây cũng là nơi trao đổi các vấn đề trong công ty. 2. Cơ chế hoạt động. Đầu tiên truy cập vào trang chủ của web site trên trang chủ sẽ có nút Forum. Ta nhấn vào nút này sẽ đưa chúng ta đến trang chủ của diễn đàn (trang index.jsp). Nơi đây ta có thể tham khảo các chủ đề hiện có hoặc thêm vào các chủ đề thảo luận mới chúng ta gọi từ topic. Mỗi mục ta thêm vào được gọi là “tuyến” hay thread. Hình 2.1 là trang chủ của diễn đàn Hình 2.1: Trang chủ của diễn đàn Tại trang chủ, ta có thể sắp xếp các đề mục theo chủ đề, theo tên người gửi bài hoặc theo ngày tháng, hoặc ta có thể xố đi một chủ đề. Nếu muốn xem nội dung của một chủ đề đã được mọi người thảo luận trước đó như thế nào, ta có thể kích chuột vào tên của từng chủ đề. Danh sách và nội dung thảo luận sẽ được trang viewthread.jsp hiển thị như hình 2.2 Đồ án tốt nghiệp đại học GVHD: Nguyễn Đức Thuần SVTH: Nguyễn Văn Ty Trang 51 Hình 2.2: Trang xem nội dung chủ đề Từ trang chủ, ta cũng có thể chọn hyperlink New Thread để tạo một mục mới (một chủ đề mới) hình 2.3. Hình 2.3: Tạo một chủ đề mới Từ trang chủ, ta có thể nhập vào một chuỗi thông tin và nhấn nút Search xem đã có người thảo luận về thông tin mà ta cần tìm hay chưa hình 2.4. Đồ án tốt nghiệp đại học GVHD: Nguyễn Đức Thuần SVTH: Nguyễn Văn Ty Trang 52 Hình 2.4 là kết quả tìm kiếm về chủ đề Một khi danh sách các đề mục khá dài, để hiển thị, sử dụng kỹ thuật phân trang chỉ cho hiển thị 5 đề mục trên một trang. Ta đã hiểu qua cách hoạt động của diễn đàn. II. XÂY DỰNG ỨNG DỤNG FORUM. 1. Thiết kế diễn đàn. 1.1. Thiết kế xử lý. Các hoạt động chính của diễn đàn trong chương trình bán hàng là: Liệt kê tất cả các topic của diễn đàn. Tìm kiếm một topic. Tạo mới một topic. Trả lời một topic. Xố một topic. Tóm lại: Cơ chế một diễn đàn được mô tả bằng sơ đồ sau: Error! XỬ LÝ: Liệt kê tất cả các topic Các topic ở đây là các vấn đề mà khách hàng muốn trao đổi với công ty, hoặc muốn các thành viên trong công ty với nhau nhằm bàn bạc về một vấn đề nào đó. Xử lý này được mô tả như sau: Tiếp nhận yêu cầu liệt kê các topic. Lieät keâ taát caû caùc topic Tìm kieám moät topic Taïo môùi moät topic Traû lôøi moät topic Lieät keâ taát caû caùc ñaùp öùng Xoaù moät topic Đồ án tốt nghiệp đại học GVHD: Nguyễn Đức Thuần SVTH: Nguyễn Văn Ty Trang 53 Truy xuất cơ sở dữ liệu (bảng messages) Xuất ra màn hình các topic. XỬ LÝ: Tạo mới một topic Khi cần một khách hàng có thể trao đổi các vấn đề mà cần bàn bạc đến các khách hàng khác và mong có ý kiến trao đổi của nhiều người. Việc tạo mới một topic được mô tả như sau: Tiếp nhận yêu cầu tạo mới một topic. Tiếp nhận các nội dung của việc tạo topic như tên topic, người tạo topic và nội dung topic. Lấy max(message_id)+1 trong bảng messages để tạo khố cho topic. Lưu vào trong cơ sở dữ liệu. XỬ LÝ: Tìm kiếm theo nội dung topic Yêu cầu này đặt ra khi có quá nhiều topic, người sử dụng chỉ muốn tìm kiếm một topic có chủ đề giống chủ đề mình cần tìm. Mô tả việc tìm kiếm một nội dung topic như sau: Tiếp nhận yêu cầu tìm kiếm topic Lấy thông tin tìm kiếm. Truy xuất cơ sở dữ liệu có topic có chữ giống với nội dung tìm kiếm. Liệt kê các topic thoả yêu cầu tìm kiếm. XỬ LÝ: Liệt kê tất cả các đáp ứng cho một topic Khi khách hàng hoặc thành viên của công ty chọn một topic để xem xét các trả lời cho topic tương ứng thì yêu cầu này cần phải thực hiện như sau: Tiếp nhận yêu cầu cần liệt kê. Lấy mã số của tên topic cần liệt kê (mã số = message_id). Truy xuất cơ sở dữ liệu tương ứng với message_id đó. Liệt kê tất cả các đáp ứng của topic. XỬ LÝ: Đáp ứng một topic Mỗi khách hàng hoặc thành viên của công ty có thể trao đổi kinh nghiệm về một vấn đề mà mình biết cho các khách hàng hoặc thành viên khác mà họ đang quan tâm vấn đề đó. Các bước xử lý được mô tả như sau: Tiếp nhận yêu cầu đáp ứng. Lấy mã số của topic cần đáp ứng. Ghi nhận các thông tin của người đáp ứng (tên, nội dung đáp ứng) vào cơ sở dữ liệu. XỬ LÝ: Xố một topic Tiếp nhận yêu cầu xố một topic Đồ án tốt nghiệp đại học GVHD: Nguyễn Đức Thuần SVTH: Nguyễn Văn Ty Trang 54 Lấy mã số của topic cần xố. Xố tất cả nội dung của topic trong cơ sở dữ liệu 1.2. Thiết kế bảng dữ liệu Xây dựng diễn đàn bằng JSP cho Web site này, chúng ta cần một bảng cơ sở dữ liệu để lưu nội dung của chủ đề bàn bạc, tên tác giả, người gửi bài, ngày tháng bài được gởi, … cùng các trang JSP tương tác khác. Messages:Bảng chứa thông tin của diễn đàn KEY COMLUMN NAME DATATYPE LENGTH K Message_id Smallint 2 Message_parent_id Smallint 2 Topic Varchar 50 Author Varchar 50 Date_entered Datetime 8 Message Varchar 300 Chú thích: Message_id: Khố duy nhất cho mỗi đề mục. Message_parent_id: Quan hệ với đề mục cha (NULL nếu là đề mục gốc). Topic: Tiêu đề cần thảo luận của đề mục. Author: Tên người gởi bài. Date_entered: Ngày gởi bài. Message: Nội dung cần thảo luận. 2. Chức năng các trang JSP cho ứng dụng forum: bao gồm các trang sau. 2.1. Trang index.jsp Trước hết là trang index.jsp, đây là trang chủ của một ứng dụng. Trong trang này ta đọc từ bảng dữ liệu message các chủ đề hiện có. Hiển thị các chủ đề và phân trang chúng(5 mẫu tin đọc được trên một trang). Người dùng có thể kích chuột vào các liên kết Previous hoặc Next để đi đến các trang dữ liệu khác. Ta cũng được cung cấp cơ chế sắp xếp dữ liệu theo tên đề mục (topic), tên người gửi, ngày tháng bài được gửi… Trang chủ index.jsp cũng bao gồm một thẻ trỏ đến trang search.jsp thực hiện thao tác tìm kiếm khi ta nhấn vào search (submit). 2.2. Phần tiêu đề trang: chỉ là file chứa các hình ảnh tiêu đề và logo dành cho ứng dụng sẽ xuất hiện ở mọi trang giao diện JSP khác. 2.3. Trang viewthread.jsp Khi người dùng kích chuột vào một hyperlink của một chủ đề cần thảo luận ta sẽ sử dụng trang viewthread.jsp để hiển thị chi tiết các mục trả lời đã được gởi lên. Đồ án tốt nghiệp đại học GVHD: Nguyễn Đức Thuần SVTH: Nguyễn Văn Ty Trang 55 Mỗi chủ đề cung cấp số mid (message_id) trên đường liên kết URL dạng query string, trang viewthread.jsp sử dụng tham số này để tìm ra chủ đề chính cũng như các câu trả lời con liên quan (căn cứ vào trường message_parent_id). 2.4. Trang newthread.jsp Nếu người dùng muốn tạo một chủ đề mới, họ có thể kích chuột vào mục newthread của trang chủ. Trang newthread.jsp dưới đây sẽ hiển thị giao diện để người dùng nhập vào tên người gởi bài, tên chủ đề và nội dung. 2.5. Trang savethread.jsp Nhiệm vụ của trang này khá đơn giản. Đầu tiên nó tiếp nhận dữ liệu do trang newthread.jsp gửi lên. Tiếp đến, là tạo khố cho mục dữ liệu chèn vào. Khố được tạo bằng cách lấy giá trị lớn nhất của trường message_id hiện hành cộng thêm 1. sau cùng lệnh SQL INSERT được gọi để chèn dữ liệu vào bảng. 2.6. Trang reply.jsp Trong quá trình xem trả lời của các mục thảo luận, người dùng có thể nhấn vào nút Reply để phản hồi hoặc góp thêm ý kiến vào mục thảo luận. Trang reply.jsp rất giống với trang newthread.jsp, tuy nhiên trang reply.jsp liên quan đến các đề mục đã có. 2.7. Trang savereply.jsp Tương tự như trang savethread.jsp trước đây, trang savereply.jsp thực hiện chức năng lưu câu trả lời vào bảng dữ liệu. Tuy nhiên, vì đây là câu trả lời liên quan đến đề mục đã có, ta lấy khố của đề mục cha từ đối số gửi lên bởi trang reply.jsp mang tên mid. Sau cùng, lệnh INSERT của SQL được gọi để chèn dữ liệu cho câu trả lời vào bảng dữ liệu. 2.8. Trang search.jsp Một khi trang web của ta được nhiều người sử dụng truy cập và thảo luận trên forum, lượng đề mục cũng như số luợng câu trả lời sẽ tăng lên. Chúng ta cần cung cấp cơ chế cho phép người dùng tìm kiếm xem một đề mục nào đó đã được thảo luận trước đó hay chưa. Trang search.jsp sẽ thực hiện công việc này. Cơ chế hiển thị của trang search.jsp rất giống với trang index.jsp, tuy nhiên trang search.jsp thực hiện chức năng tìm kiếm trong mệnh đề WHERE của câu lệnh SQL dựa vào dữ liệu từ ô nhập liệu mang tên s_topic. Trang search.jsp được gọi từ thuộc tính action của thẻ trong trang index.jsp. Nội dung như sau Đồ án tốt nghiệp đại học GVHD: Nguyễn Đức Thuần SVTH: Nguyễn Văn Ty Trang 56 Chương VI HẠN CHẾ – HƯỚNG CẢI TIẾN 1. Hạn chế Như vậy, em đã thiết kế thành công và đã hiện thực được mô hình bán hàng qua mạng (thương mại điện tử). Nhưng với lượng thời gian có hạn và nội dung đề tài quá lớn, nên không thể hồn thiện tất các chức năng cần thiết cho mô hình. Chính vì lý do này, hệ thống còn một số hạn chế nhất định là điều khó tránh khỏi. Dưới đây là một số hạn chế mà không thể xây dựng: Quá trình kiểm tra và thử nghiệm hệ thống chưa được chú ý vì lý do không đủ nhân lực và thời gian thực hiện còn hạn hẹp. Hệ thống giúp đỡ sử dụng của hệ thống chưa được xây dựng. Hạn chế này sẽ gây khó khăn rất nhiều cho người dùng cuối (end user). Hệ thống chỉ có bản cài đặt trên môi trường windows, chưa có bản cài đặt chính thức, thống nhất cho các môi trường khác. Và một số hạn chế khác sẽ phát sinh trong quá trình kiểm tra của các beta tester. Công cụ xây dựng này còn quá đơn giản. Chương trình xây dựng phức tạp nên việc cập nhật, nâng cấp chương trình hơi khó thực hiện. 2. Hướng cải tiến Nhìn chung, em đã thực hiện và xây dựng được các phần chính của hệ thống. Ở mức độ vừa và nhỏ, hệ thống có thể được áp dụng vào thực tế. Tuy nhiên, hệ thống cần có có một số cải tiến sau trong tương lai. Có thể nâng cấp và cải tiến để đưa vào vận hành sử dụng. Xây dựng hệ thống trợ giúp cho người sử dụng. Đồ án tốt nghiệp đại học GVHD: Nguyễn Đức Thuần SVTH: Nguyễn Văn Ty Trang 57

Các file đính kèm theo tài liệu này:

  • pdfĐồ án tốt nghiệp đại học- Nghiên cứu công nghệ JSP & Java, xây dựng Website bán hàng cho công ty cổ phần chế biến gỗ Việt Đức Kha.pdf
Luận văn liên quan