Bài tập Lập trình web với java
BÀI 9: Bảo mật website
Sử dụng các cấu hình bảo mật trong một website
9.1. Xây dựng ứng dụng Web với xác thực Form Authentication
Yêu cầu: Xây dựng trang login form sử dụng cơ chế xác thực form
Hướng dẫn sử dụng: người dùng nhập vào tài khoản và mật khẩu để đăng nhập
Tóm tắt yêu cầu:
Thiết kế giao diện
26 trang |
Chia sẻ: maiphuongtl | Lượt xem: 3222 | Lượt tải: 2
Bạn đang xem trước 20 trang tài liệu Bài tập Lập trình web với java, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
TRUNG TÂM TIN HỌC – ĐẠI HỌC KHOA HỌC TỰ NHIÊN TP.HCM
227 Nguyễn Văn Cừ - Quận 5- Tp.Hồ Chí Minh
Tel: 38351056 – Fax 8324466 – Email: ttth@t3h.hcmus.edu.vn
Mã tài liệu: DT_NCM_LT_DC_LTMNM1_BT
Phiên bản 1.0 – Tháng 03/2014
BÀI TẬP
CHƯƠNG TRÌNH LẬP TRÌNH VIÊN
CÔNG NGHỆ JAVA
---
MODULE 3: LẬP TRÌNH WEB VỚI JAVA
Bài tập
Module 3: Lập trình Web với Java 2/26
BÀI 1: Tổng quan J2EE
- Cài đặt và làm quen với mối trường phát triển ứng dụng web trên nền tảng công nghệ
JEE
- Phát triển ứng dụng web tĩnh đơn giãn sử dụng công nghệ html, javascript và css
1.1. Cài đặt môi trường Application Server
Yêu cầu: Cài đặt Apache Tomcat 7 trong môi trường console của hệ điều hành
Hướng dẫn sử dụng:
Tóm tắt yêu cầu:
Phải cài đặt trước: Java SDK, các trình duyệt (có thể là Firefox, IE, Chrome,..)
Thuật giải: Không có
Hướng dẫn:
− Download Apache Tomcat phiên bản 7 tại địa chỉ
70.cgi hoặc tìm kiếm download trên google
− Giải nén và lưu trữ vào thư mục trên ổ đĩa
− Cài đặt các biến môi trường JAVA_HOME và CATALINA_HOME tương ứng cho thư mục
cài đặt java (thư mục jdk) và Apache Tomcat
− Mở console (bấm tổ hợp phím Window + R), chuyển đến thư mục bin của Tomcat và
thực hiện các lệnh start, stop cho môi trường Server
Có thể cấu hình thêm các lệnh start và stop vào biến môi trường $Path mà không
cần phải chuyển đến thư mục bin của Tomcat
− Mở trình duyệt và truy cập đến Apache Tomcat
1.2. Cài đặt môi trường Application Server
Yêu cầu: Cài đặt Apache Tomcat trên môi trường soạn thảo Eclipse IDE
Hướng dẫn sử dụng:
Tóm tắt yêu cầu:
Thuật giải: Không có
Hướng dẫn:
− Download Apache Tomcat phiên bản 7 tại địa chỉ
70.cgi hoặc tìm kiếm download trên google
Bài tập
Module 3: Lập trình Web với Java 3/26
− Giải nén và lưu trữ vào thư mục trên ổ đĩa
− Mở Eclipse IDE và thêm mới Apache Tomcat vào server trong Eclipse
− Thực hiện start và stop môi trường Apache Tomcat server trong Eclipse
− Thực hiện gọi Apache Tomcat từ trình duyệt. Trong trường hợp lỗi không tìm thấy trang
(lỗi 404) thì copy thư mục ROOT trong $CATALINA_HOME/webapp vào trong thư mục
$Eclipse_Workspace\.metadata\.plugins\org.eclipse.wst.server.core\tmp0\wtpwebapps
$CATALINA_HOME là thư mục Apache Tomcat
$Eclipse_Workspace là thư mục workspace của Eclipse IDE
Có thể tmp0 trong $Eclipse_Workspace được thay thế bởi tmp1
1.3. Phát triển ứng dụng web tĩnh
Yêu cầu: Xây dựng ứng dụng web tĩnh trong Apache Tomcat
Hướng dẫn sử dụng:
Tóm tắt yêu cầu:
Thiết kế giao diện
Nhập
Xuất
Qui tắc xử lý
Thuật giải:
Hướng dẫn:
Bài tập
Module 3: Lập trình Web với Java 4/26
− Tạo mới thư mục web tĩnh có tên staticwebBTMS trong thư mục webapp của
$CATALINA_HOME
− Tạo ra các thành phần của trang web tĩnh (copy các trang html, css, javascript, images
được cung cấp trong phần bài tập vào thư mục webcontent trong cấu trúc static
project)
− Thực hiện start, stop Apache Tomcat trong môi trường console và sử dụng browser
triệu gọi trang chủ của web (home.html)
1.4. Phát triển ứng dụng dynamic web project
Yêu cầu: Xây dựng dynamic web project trong Eclipse IDE
Hướng dẫn sử dụng:
Tóm tắt yêu cầu:
Thiết kế giao diện
Nhập
Xuất
Qui tắc xử lý
Thuật giải:
Hướng dẫn:
− Tạo mới dynamic web project trong Eclipse IDE có tên dynamicwebBTMS
− Tạo ra các trang html (copy các trang html, css, javascript, images được cung cấp trong
phần bài tập vào thư mục webcontent trong cấu trúc static project)
− Triển khai lên server và sử dụng browser triệu gọi trang chủ của web (home.html)
Bài tập
Module 3: Lập trình Web với Java 5/26
BÀI 2: Servlet
- Xây dựng một Servlet đơn giản và cấu trúc thư mục của ứng dụng Servlet
- Xây dựng cấu trúc triển khai web.xml trong ứng dụng web
2.1. Xây dựng cấu trúc ứng dụng Servlet
Yêu cầu: Xây dựng một trang Servlet xuất ra một câu chào “Hello World”
Hướng dẫn sử dụng:
Tóm tắt yêu cầu:
Thiết kế giao diện
Nhập
Xuất
Qui tắc xử lý
Thuật giải:
Hướng dẫn:
- Tạo thư mục web trong thư mục $CATALINA_HOME/webapp có tên structureServlet
theo cấu trúc ứng dụng Servlet
- Tạo ra trang index.html
- Tạo ra servlet có tên HelloWorldSrv.java và biên dịch thành file bytecode
- Tạo ra file cấu hình web.xml trong thư mục WEB-INF
Bài tập
Module 3: Lập trình Web với Java 6/26
- Start Tomcat và truy cập trong trình duyệt
2.2. Tạo các trang Servlet trong Eclipse IDE
Yêu cầu: Xây dựng trang Servlet và hiện thực phương thức Get để xuất ra một lời chào
Hướng dẫn sử dụng:
Tóm tắt yêu cầu:
Thiết kế giao diện
Nhập
Xuất
Qui tắc xử lý
Thuật giải:
Hướng dẫn:
- Tạo dynamic web project trong Eclipse có tên là XmlAnnotationWeb
- Định nghĩa 2 trang Servlet có tên XmlServlet và AnntationServlet hiện thực phương thức
get xuất ra lời chào
- Thực hiện cấu hình các trang servlet theo 2 cách dùng xml (XmlServlet) trong file
web.xml và annotation trong chính servlet đó (AnnotationServlet)
- Tạo thêm trang index.html và tạo 2 link gọi đến 2 servlet ở trên
- Triển khai lên Application Server Tomcat và triệu gọi bên Client
Bài tập
Module 3: Lập trình Web với Java 7/26
BÀI 3: Java Server Page
- Sử dụng các thẻ trong trang JSP
- Sử dụng các biến ẩn trong trang JSP
3.1. Tạo ứng dụng xử lý và tương tác giữa các trang JSP
Yêu cầu: Tạo ra trang jsp nhập vào tên và xuất ra lời chào
Hướng dẫn sử dụng:
Tóm tắt yêu cầu:
Thiết kế giao diện:
Nhập
Xuất
Qui tắc xử lý
Thuật giải:
Hướng dẫn:
- Tạo ra dynamic web có tên jspwebapp
- Tạo ra 2 trang index.jsp và trang response.jsp
- Triển khai lên Tomcat server
Bài tập
Module 3: Lập trình Web với Java 8/26
3.2. Tương tác giữa trang JSP và Servlet
Yêu cầu: Xây dựng chức năng đăng nhập
Hướng dẫn sử dụng:
Tóm tắt yêu cầu:
Thiết kế giao diện:
Nhập
Xuất
Qui tắc xử lý
- Nhập thông tin tài khoản, mật khẩu và thực hiện xử lý kiểm tra thông tin đăng trên
Servlet tương ứng.
Bài tập
Module 3: Lập trình Web với Java 9/26
- Dữ liệu xác thực tài khoản và mật khẩu được đặc tả mặc định
- Trường hợp xác thực thành công thì tạo thuộc tính session hiển thị trên trang chủ,
ngược lại trở lại trang login hiển thị message không thành công và yêu cầu người
dùng nhập lại
Thuật giải:
Hướng dẫn:
- Tạo ra dynamic web project có tên btms
- Tạo ra trang login.jsp và trang home.jsp
- Tạo ra lớp hỗ trợ để định nghĩa các giá trị tài khoản, mật khẩu và có tên là ConfigUtils
- Tạo ra trang servlet để xử lý login có tên LoginSrv.java
- Triển khai lên Tomcat Server
Bài tập
Module 3: Lập trình Web với Java 10/26
BÀI 4: Servlet nâng cao
Sử dụng các cấu hình session, cookie, hidden field, event-listener và filter trong ứng dụng
web
4.1. Sử dụng Servlet Config và Servlet Context
Yêu cầu: Hiện thực lại bài 3.2 với thông tin tài khoản và mật khẩu trong config
Hướng dẫn sử dụng: người dùng truy cập, đăng nhập và thoát
Tóm tắt yêu cầu:
Thiết kế giao diện
Nhập
Xuất
Qui tắc xử lý
- Trường hợp xác thực thành công thì chuyển trang profile hiển thị các thông tin của
người dùng. các thông tin này được cấu hình trong context của Web.xml
Thuật giải:
Hướng dẫn: Sử dụng lại bài tập 3.2
- Cấu hình web.xml thêm các cấu hình config và context
- Định nghĩa lớp Entity thể hiện các thông tin của một tài khoản có tên Account
- Cập nhật lại lớp LoginSrv
Bài tập
Module 3: Lập trình Web với Java 11/26
- Tạo mới file profile.jsp và lấy dữ liệu session trong lớp Login Servlet gửi lên
- Triển khai lên Tomcat Server
4.2. Sử dụng Even-Listener để quản lý truy cập ứng dụng web
Yêu cầu: Đếm số lượng Session trong một ứng dụng khi có một session mới được tạo ra
hoặc một session bi hủy trong ứng dụng btms
Hướng dẫn sử dụng:
Tóm tắt yêu cầu:
Thiết kế giao diện
Nhập
Xuất
Qui tắc xử lý
- Khi client gọi truy cập Web lần đầu tiên thì Server tiến hành ghi log thông tin session
được tạo ra
- Người dùng thoát (log out) trong trang home.jsp, profile.jsp để hủy một session
Thuật giải:
Hướng dẫn:
- Tạo các lớp listener có tên SessionCounter
- Cấu hình các lớp listener và time-out trong file cấu hình triển khai trong web.xml
- Tạo ra Logout Servlet (LogoutSrv) để hủy session
- Cấu hình lại các trang jsp (home.jsp, profile.jsp) để thực đăng xuất
4.3. Sử dụng Filter để lọc các yêu cầu gọi từ người client-side
Yêu cầu: Thực hiện chức năng Login Filter yêu cầu người dùng đăng nhập trước khi thực
hiện các thao tác khác trong ứng dụng btms
Hướng dẫn sử dụng:
Tóm tắt yêu cầu:
Thiết kế giao diện
Nhập
Xuất
Qui tắc xử lý
Bài tập
Module 3: Lập trình Web với Java 12/26
- Kiểm tra người dùng đã đăng nhập chưa, nếu chưa đăng nhập thì chuyển trang
đăng nhập. Ngược lại, chuyển tới trang yêu cầu
Thuật giải:
Hướng dẫn:
- Tạo lớp Filter với LoginFilter
- Cấu hình filter trong web.xml với tất cả các request
- Triển khai
4.4. Sử dụng Filter cho request và response ecoding charater
Yêu cầu: Thêm chức năng cập nhật Profile cho ứng dụng btms
Hướng dẫn sử dụng:
Tóm tắt yêu cầu:
Thiết kế giao diện
Nhập
Xuất
Qui tắc xử lý
- Đối với trang jsp chứa form nhập tiếng việt thì trong Servlet phải đặc tả encoding
cho request và response để nhận tiếng việt
Thuật giải:
Hướng dẫn:
Bài tập
Module 3: Lập trình Web với Java 13/26
- Tạo lớp Filter với EncodingChareter thiết lập request và response với encoding charater
UTF-8
- Cấu hình filter trong web.xml với tất cả các request
- Tạo trang servlet để cập nhật thông tin profile của tài khoản đó có tên ProfileSrv (cấu
hình thuộc tinh action của form trong trang profile.jsp chỉ đến Profile Servlet) và sử
dụng session để lưu lại thông tin cập nhật
- Triển khai
Bài tập
Module 3: Lập trình Web với Java 14/26
BÀI 5: JSP nâng cao
- Sử dụng khái niệm Custom Tag để định nghĩa ra những thẻ mới cho việc tối ưu hiển thị
dữ liệu
- Phân chia layout và sử dụng các thành phần chung (trang JSP tái sử dụng)
- Sử dụng Java Bean kết hợp với form
5.1. Tái sử dụng các trang JSP trong một ứng dụng web
Yêu cầu: Cập nhật lại các trang JSP trong btms project để sử dụng các thành phần JSP
tái sử dụng
Hướng dẫn sử dụng:
Tóm tắt yêu cầu:
Thiết kế giao diện
Nhập
Xuất
Qui tắc xử lý
Thuật giải:
Hướng dẫn:
- Tạo ra các trang JSP tái sử dụng chung cho nhiều trang JSP gồm header.jsp, footer.jsp,
message.jsp, right.jsp, navigator.jsp,…
- Cập nhật lại các trang login.jsp, home.jsp và profile.jsp
5.2. Tạo Tag Handler hiện thực các giao diện
Yêu cầu: Tạo các lớp Tag handler hiện thực các thẻ xuất lời chào, cấu trúc if và cấu trúc
vòng lặp
Hướng dẫn sử dụng:
Tóm tắt yêu cầu:
Thiết kế giao diện
Bài tập
Module 3: Lập trình Web với Java 15/26
Nhập
Xuất
Qui tắc xử lý
Thuật giải:
Hướng dẫn:
- Tạo ra dynamic web project với với SimpleTag
- Tạo ra file TLD (tag lib descriptor) có tên CustomTag.tld với uri
- Tạo ra các lớp Tag Handler tương ứng với các tag định nghĩa trong CustomTag.tld
- Tạo ra trang index.html và các trang Jsp tương ứng để sử dụng các thẻ định nghĩa đó
- Triển khai
5.3. Tạo Tag Handler thừa kế các Tag Handler có sẵn
Yêu cầu: Tạo ra các trang Tag Handler xử thừa kế lớp TagSupport trong JSP
Hướng dẫn sử dụng:
Tóm tắt yêu cầu:
Thiết kế giao diện
Bài tập
Module 3: Lập trình Web với Java 16/26
Nhập
Xuất
Qui tắc xử lý
Thuật giải:
Hướng dẫn:
- Tạo ra dynamic web project với với AdvanceTag
- Tạo ra file TLD (tag lib descriptor) với SampleLib.tld
- Tạo ra các lớp Tag Handler tương ứng
- Tạo ra trang index.html và các trang Jsp tương ứng để sử dụng các thẻ định nghĩa đó
- Triển khai
5.4. Cách sử dụng JavaBean trong trang JSP
Yêu cầu: Tạo ra form đơn giản cho phép người dùng nhập và xuất thông tin của địa chỉ
Hướng dẫn sử dụng:
Tóm tắt yêu cầu:
Thiết kế giao diện
Bài tập
Module 3: Lập trình Web với Java 17/26
Nhập
Xuất
Qui tắc xử lý
Thuật giải:
Hướng dẫn:
− Tạo ra dynamic web project với tên AddressApp
− Tạo ra lớp Java Bean có tên Address
− Tạo ra các trang jsp gồm cho phép nhập và hiển thị dữ liệu về Address bean
− Triển khai
Bài tập
Module 3: Lập trình Web với Java 18/26
BÀI 6: EL & JSTL
Cách loại bỏ các source code java trong trang JSP của các ứng dụng JEE bằng cách sử
dụng ngỗn ngữ biểu thức (Expression Language) và tập thẻ thư viện chuẩn JSTL
6.1. Sử dụng JSTL Tag Core cập nhật lại các URL
Yêu cầu: Cập nhật lại các địa chỉ URL trong các trang JSP trong btms project bằng cách
sử dụng thẻ url trong JSTL core
Hướng dẫn sử dụng:
Tóm tắt yêu cầu:
Thiết kế giao diện
Nhập
Xuất
Qui tắc xử lý:
Thuật giải:
Hướng dẫn:
- Import thư viện JSTL vào trong thư mục lib của btms project (thư viện jstl có trong thư
mục lib của apache tomcat nên đã tự động import cùng với server)
- Tạo mới trang jsp định nghĩa các thư viện JSTL trong thư mục common có tên là
taglibs.jsp
- Import trang taglibs.jsp vào các trang còn lại và cập nhập lại các url định nghĩa trong
các trang jsp đó
- Triển khai
6.2. Sử dụng JSTL Formatting Tag để nạp resource bundle vào trang JSP
Yêu cầu: Tạo file resource bundle và cập nhật lại các label trong các jsp dùng key trong
file resource bundle đó
Hướng dẫn sử dụng:
Tóm tắt yêu cầu:
Thiết kế giao diện
Nhập
Bài tập
Module 3: Lập trình Web với Java 19/26
Xuất
Qui tắc xử lý
Thuật giải:
Hướng dẫn:
− Tạo file resource bundle (có thể định nghĩa file tiếng viết và file tiếng anh)
− Thêm định nghĩa JSTL formatting trong file taglibs.jsp trong common
− Đặc tả các resource bundle và cập nhật lại các lable trong các trang jsp
− Triển khai
Bài tập
Module 3: Lập trình Web với Java 20/26
BÀI 7: Mô hình MVC với JSP/Servlet
Triển khai ứng dụng kết hợp JSP/Servlet theo mô hình hoạt động của kiến trúc phần mềm
MVC
7.1. Xây dựng hệ thống quản lý bán vé xe
Yêu cầu: Mở rộng bài 3.2, xây dựng thêm các chức năng của hệ thống bán vé gồm:
- Quản lý danh sách các tuyến đường
- Quản lý danh sách xe (có trong bến)
- Quản lý danh sách lịch khởi hành theo từng ngày của từng tuyến xe
- Tạo lịch khởi hành (chuyến) theo từng ngày của từng tuyến xe
- Quản lý danh sách bán vé: còn vé và hết vé của các chuyến
- Đặt vé online hoặc điện thoại
Hướng dẫn sử dụng:
Tóm tắt yêu cầu:
Thiết kế giao diện
Nhập
Xuất
Qui tắc xử lý
Thuật giải:
Hướng dẫn:
Bài tập
Module 3: Lập trình Web với Java 21/26
BÀI 8: Web service
Tạo ra các web service trong một ứng dụng Website
8.1. Tạo ra ứng dụng web service
Yêu cầu: Trong bài tập 3.2, hiện thực web service cho phép client gọi hàm đăng nhập và
lấy về danh sách tài khoản
Hướng dẫn sử dụng:
Tóm tắt yêu cầu:
Thiết kế giao diện
Nhập
Xuất
Qui tắc xử lý
Thuật giải:
Hướng dẫn:
- Import thử viện jax-ws
- Hiện thực lớp Web Service gồm interface và lớp hiện thực
- Định nghĩa file cấu sun-jaxwx.xml và cấu hình trong file web.xml
8.2. Xây dựng thêm các Web service
Yêu cầu: Trong bài 7.1, xây dựng thêm các service cho phép người dùng tìm kiếm các
chuyến còn vé hoặc hết, đặt vé và thanh toán
Hướng dẫn sử dụng:
Tóm tắt yêu cầu:
Thiết kế giao diện
Nhập
Xuất
Qui tắc xử lý
Thuật giải:
Bài tập
Module 3: Lập trình Web với Java 22/26
Hướng dẫn:
Bài tập
Module 3: Lập trình Web với Java 23/26
BÀI 9: Bảo mật website
Sử dụng các cấu hình bảo mật trong một website
9.1. Xây dựng ứng dụng Web với xác thực Form Authentication
Yêu cầu: Xây dựng trang login form sử dụng cơ chế xác thực form
Hướng dẫn sử dụng: người dùng nhập vào tài khoản và mật khẩu để đăng nhập
Tóm tắt yêu cầu:
Thiết kế giao diện
Nhập
Xuất
Qui tắc xử lý
Thuật giải:
Hướng dẫn:
- Tạo các trang login và trang lỗi
- Cấu hình tài khoản trong tomcat-user.xml
- Cấu hình thông tin xác thực trong file cấu hình triển khai web.xml
9.2. Cấu hình HTTPS cho ứng dụng web
Yêu cầu: Cấu hình https cho Tomcat server
Hướng dẫn sử dụng:
Bài tập
Module 3: Lập trình Web với Java 24/26
Tóm tắt yêu cầu:
Thiết kế giao diện
Nhập
Xuất
Qui tắc xử lý
Thuật giải:
Hướng dẫn:
- Sử dụng java key tools để sinh ra key (private key và request key)
- Thực hiện ký chứng thực để sinh ra certificate
- Cấu hình private key và certificate vào trong cấu hình của Tomcat server
Bài tập
Module 3: Lập trình Web với Java 25/26
BÀI 10: Tổng kết
Tổng hợp lại kiến thức về phát triển website dùng JSP/Servlet và áp dụng trong mô hình
phát triển theo MVC
Tổng hợp các bài tập trong các chương và xây dựng thành website hoàn chỉnh
Bài tập
Module 3: Lập trình Web với Java 26/26
Mục lục
Các file đính kèm theo tài liệu này:
- 20140707bt_module_3_4796.pdf