Tải bản đầy đủ (.pdf) (60 trang)

Đồ án phát triển website so sánh giá bán laptop và phụ kiện trên các sàn thương mại điện tử

Bạn đang xem bản rút gọn của tài liệu. Xem và tải ngay bản đầy đủ của tài liệu tại đây (2.11 MB, 60 trang )

ĐẠI HỌC QUỐC GIA TP. HỒ CHÍ MINH
TRƯỜNG ĐẠI HỌC CÔNG NGHỆ THÔNG TIN
KHOA CÔNG NGHỆ PHẦN MỀM
-----🙞🙜🕮🙞🙜-----

BÁO CÁO ĐỒ ÁN 2 – LỚP SE121.N11

ĐỀ TÀI:
PHÁT TRIỂN WEBSITE SO SÁNH GIÁ BÁN LAPTOP
VÀ PHỤ KIỆN TRÊN CÁC SÀN THƯƠNG MẠI ĐIỆN
TỬ

GVHD: Ths.Huỳnh Hồ Thị Mộng Trinh


Sinh viên thực hiện:

Mai Long Thành

19522232

Nguyễn Thiện Sua

19522144

Thành phố HCM, tháng 6 năm 2023

2


LỜI CẢM ƠN


Lời đầu tiên, nhóm tác giả xin chân thành cảm ơn q thầy cơ khoa Cơng nghệ
Phần mềm, trường Đại Học Công Nghệ Thông Tin, ĐHQG TP.HCM, đã tận tình
hướng dẫn nhóm trong suốt thời gian qua. Những kiến thức mà thầy cô đã truyền đạt
là nền tảng quan trọng để nhóm có thể hồn thành đề tài này.
Nhóm tác giả xin gửi lời cảm ơn chân thành đến ThS. Huỳnh Hồ Thị Mộng Trinh,
cảm ơn cô đã tận tình hướng dẫn và tạo điều kiện tốt nhất cho nhóm hồn thành đề tài
này. Những lời động viên, góp ý chân tình của cơ là động lực q báu để nhóm vượt
qua những khó khăn khi tìm hiểu và thực hiện đề tài. Trong thời gian qua, nhóm tác
giả đã cố gắng vận dụng những kiến thức nền tảng đã học, kết hợp học hỏi và tìm hiểu
cơng nghệ mới để ứng dụng xây dựng đề tài môn học. Tuy nhiên trong quá trình thực
hiện, do kiến thức và kinh nghiệm cịn nhiều hạn chế, khó tránh khỏi những thiếu sót.
Chính vì vậy, nhóm tác giả rất mong nhận được sự góp ý từ q thầy cơ để nhóm hồn
thiện thêm những kiến thức mà nhóm đã học tập, làm hành trang q báu cho nhóm
trong cơng việc sau này. Mọi đóng góp xin vui lịng gửi về email:
hoặc
Sau cùng, nhóm tác giả xin kính chúc quý thầy cô ở khoa Công nghệ phần mềm và
cô Huỳnh Hồ Thị Mộng Trinh thật dồi dào sức khỏe, niềm tin để tiếp tục thực hiện sứ
mệnh cao đẹp của mình là truyền đạt kiến thức cho thế hệ mai sau.
Xin chân thành cảm ơn q thầy cơ !
Nhóm tác giả

3


NHẬN XÉT
(Của giáo viên hướng dẫn)
.........................................................................................................................
.........................................................................................................................
.........................................................................................................................
.........................................................................................................................

.........................................................................................................................
.........................................................................................................................
.........................................................................................................................
.........................................................................................................................
.........................................................................................................................
.........................................................................................................................
.........................................................................................................................
.........................................................................................................................
.........................................................................................................................
.........................................................................................................................
.........................................................................................................................
.........................................................................................................................
.........................................................................................................................
.........................................................................................................................

4


DANH SÁCH THÀNH VIÊN NHÓM

Tên thành viên

MSSV

Mai Long Thành

19522232

Nguyễn Thiện Sua


19522144

5


TỔNG QUAN BÁO CÁO
TÊN ĐỀ TÀI: Phát triển xây dựng website so sánh giá bán laptop và phụ kiện trên
các sàn thương mại điện tử.
GIẢNG VIÊN HƯỚNG DẪN: Huỳnh Hồ Thị Mộng Trinh.
THỜI GIAN THỰC HIỆN: Từ ngày 27/02/2023 đến hết ngày 04/07/2023.
NỘI DUNG:
1. Lý do chọn đề tài
-

Máy tính, laptop đang dần trở nên phổ biến trong cuộc sống với giá thành ngày
càng có xu hướng giảm. Hơn nữa, mức thu nhập của mọi người tăng cao, nên ai
cũng có thể sở hữu một chiếc máy tính, laptop để phục vụ cơng việc của mình.

-

Hiện nay để tìm mua một laptop thì sẽ có rất nhiều sàn thương mại điện tử
bn bán với giá thành khác nhau. Do đó người mua sẽ khá là mơ hồ trong việc
lựa chọn điểm mua với giá thành hợp lý nhất.

-

Cũng đã từng là khách hàng loay hoay trong việc lựa chọn sàn thương mại mua
laptop có giá thành hợp lý nhất, chúng em hiểu rõ và mong muốn tìm kiếm
được giải pháp để giải quyết được tình trạng đó. Chúng em quyết định chọn đề
tài này để giúp những người có nhu cầu mua laptop hoặc phụ kiện máy tính có

thể xem xét giá cả sản phẩm trên tất cả sàn thương mại và lựa chọn mua với giá
hợp lý nhất.
Hiện trạng các trang web so sánh hiện nay:
+ Giao diện khó dùng cho những người mới tiếp xúc với thiết bị cơng
nghệ.
+ Thiếu một số tính năng cần thiết.

6


+ Các tính năng quan trọng chưa thực sự nổi bật.
+ Chưa cho thấy sự thay đổi giá thành sản phẩm.
+ Màu sắc không thu hút.
=> Với những vấn đề trên, chúng em quyết định lựa chọn đề tài xây dựng
website so sánh giá bán laptop và phụ kiện trên các sàn thương mại điện tử để
tiến hành nghiên cứu và xây dựng.
2. Những gì đã làm được ở đồ án 1

- Tìm giá tốt nhất cho sản phẩm.
- Có biểu đồ đường thể hiện tỉ lệ lên xuống của 1 sản phẩm trên nhiều sàn
(3 sàn thương mại).
- Xem biến động giá.
- Xem tháng giảm giá nhiều nhất.
3. Mục tiêu đề ra
-

Phát triển thêm chức năng và tối ưu website từ đồ án 1:

+ Đăng nhập/đăng xuất.
+ Xác thực người dùng.

+ Thêm vào danh sách yêu thích.
+ Tối ưu cache, tốc độ load trang.
+ Thêm validate cho các component form.
+ Tự động đặt hàng.
+ Nhận tin khuyến mãi.
4. Phạm vi, quy mô
-

Môi trường, platform: website

-

Phạm vi: so sánh giá trên 3 sàn thương mại điện tử: An phát computer, An
Khang và GearVN.

-

Phạm vi chức năng:
● Đăng nhập/đăng xuất
○ Đăng nhập với username và password.
7


● Xác thực người dùng
○ Hiển thị permission dựa trên role của user.
○ Chặn user cố ý truy cập vào màn hình khơng được phép truy cập
● Thêm vào danh sách yêu thích
○ Thêm sản phẩm vào danh sách yêu thích.
○ Load danh sách yêu thích dựa theo user.
○ Loại bỏ sản phẩm trong danh sách yêu thích.

● Nhận tin khuyến mãi
○ Thơng báo tự động khi có flash sale của sản phẩm mà khách hàng
quan tâm vào email mà khách hàng cung cấp.
● Tự động đặt hàng
○ Tự động đặt hàng khi sản phẩm có giá thấp hơn hoặc bằng giá
người dùng setup.
5. Đối tượng sử dụng: Tất cả người dùng có nhu cầu muốn so sánh giá và tìm
mua laptop và phụ kiện máy tính.
6. Phương pháp thực hiện:
-

Phương pháp làm việc: Làm việc nhóm 2 thành viên thông qua cả 2 phương
thức online và offline dưới sự hướng dẫn của giảng viên hướng dẫn.

-

Phương pháp nghiên cứu:
+ Phân tích nhu cầu sử dụng của đối tượng người dùng.
+ Nghiên cứu tài liệu các công nghệ liên quan.
+ Kiểm tra, tham khảo các website khác để tối ưu hóa trang web.

-

Phương pháp cơng nghệ:
+ Tìm hiểu về các ngôn ngữ mới và áp dụng framework vào để tối ưu hóa
hiệu suất.
+ Xây dựng giao diện web để tương tác với người dùng và nhận phản hồi,
sửa chữa nếu cần thiết để đưa ra sản phẩm hoàn chỉnh nhất.
+ Tìm hiểu cách thức hoạt động của các tính năng trang web.


7. Nền tảng công nghệ:

8


-

Front-end: html, css, javascript, ReactJS.

-

Back-end: ASP.NET core.

-

Database: MySQL.

-

Validate form: React hook form, class – validator.

-

Xác thực: JWT.

-

Tự động đặt hàng: Selenium.

-


Tối ưu tải trang: Lazy loading Technology.

8. Kết quả mong đợi:
-

Hoàn thiện được website đáp ứng đầy đủ mục tiêu đề ra.

-

Trang web có thể thực hiện chính xác u cầu của khách hàng.

-

Trang web có khả năng tương tác với người dùng với mức độ ổn định.

-

Các chức năng của website hoạt động đúng đắn, chính xác, dễ sử dụng.

9. Hướng phát triển:
-

Trang blog.

-

Thêm ngôn ngữ tiếng Anh.

-


Liên kết đến các trang review sản phẩm.

-

Thêm chatbot hỗ trợ.

-

Thêm forum công nghệ.

-

Mở rộng thêm nhiều sản phẩm hơn.

-

Tổng hợp voucher của các sàn thương mại điện tử.

10. Kế hoạch làm việc:
-

Thời gian thực hiện: Từ ngày 27/02/2023 đến hết ngày 17/07/2023.

-

Quy trình làm việc được lên kế hoạch triển khai như sau:
+ Giai đoạn 1 (27/02/2023 - 24/04/2023): Hoàn thiện được sơ bộ front end và chức năng cơ bản. Giai đoạn này gồm 4 sprint:
+ Sprint 1 (27/02/2023 -> 04/03/2023): tìm hiểu cơng nghệ, khảo
sát các trang web liên quan.

+ Sprint 2 (06/03/2023 -> 16/03/2023): phân tích yêu cầu.
+ Sprint 3 (17/03/2023 -> 24/03/2023): xây dựng CSDL, xử lý
ngôn ngữ tự nhiên.
9


+ Sprint 4 (25/03/2023 -> 24/04/2023): xây dựng website, xây
dựng server, xây dựng một số chức năng cơ bản.
+ Giai đoạn 2 (25/05/2023 - 25/06/2023): Tiếp tục hoàn thiện các chức
năng còn lại và triển khai viết báo cáo. Giai đoạn này gồm 2 sprint:
+ Sprint 5 (25/05/2023 -> 21/06/2023: hồn thiện các chức năng
cịn lại ở giai đoạn 1, tìm và sửa lỗi trong quá trình xây dựng
chức năng.
+ Sprint 6 (22/06/2023 -> 25/06/2023): Triển khai sản phẩm, viết
báo cáo.
+ Giai đoạn 3 (26/06/2023 - 30/06/2023) Kiểm tra lỗi và hoàn thiện sản
phẩm. Giai đoạn này gồm 2 sprint:
+ Sprint 7 (26/06/2023 -> 28/06/2023): Kiểm tra lại tổng quan sản
phẩm và sửa lỗi.
+ Sprint 8 (29/06/2023 -> 30/06/2023): kiểm tra file báo cáo, chỉnh
sửa hoặc thay đổi nếu có.
11. Phân cơng cơng việc:
-

Cơng việc chung:
+ Phân tích u cầu.
+ Khảo sát trang web.
+ Tìm hiểu cơng nghệ.
+ Viết báo cáo.


• Cơng việc riêng:
+ Mai Long Thành: front-end, UX/UI design, tối ưu hóa website.
+ Nguyễn Thiện Sua: back-end.

10


Mục lục
TỔNG QUAN VỀ ĐỀ TÀI .............................................................. 13
1.1 Sơ lược đồ án 1 .......................................................................................... 13
1.2 Mục tiêu đề tài............................................................................................ 14
1.3 Đối tượng nghiên cứu ................................................................................ 14
1.3.1 Lý Thuyết ......................................................................................... 14
1.3.2 Thực Tiễn ......................................................................................... 14
1.4 Các bước nghiên cứu ................................................................................. 15
1.5 Bố cục đề tài ............................................................................................... 15
CƠ SỞ LÝ THUYẾT ....................................................................... 15
2.1 Tanstack (React query) .............................................................................. 15
2.2 Kỹ thuật Lazyloading ................................................................................. 19
2.3 React hook form ......................................................................................... 20
2.4 Phân quyền với JWT .................................................................................. 21
2.5 Selenium..................................................................................................... 23
PHÂN TÍCH ĐẶC TẢ YÊU CẦU .................................................. 24
3.1 Usecase, đặc tả usecase .............................................................................. 24
Sơ đồ usecase ................................................................................... 24
Đặc tả usecase................................................................................... 25
3.2 Sequence diagram ...................................................................................... 38
Tìm kiếm sản phẩm .......................................................................... 38
3.3 Activity diagram ........................................................................................ 39
3.3.1 Nhận ưu đãi khuyến mãi .................................................................. 39

3.4 Collaboration diagram ............................................................................... 40
Sắp xếp danh sách sản phẩm ............................................................ 40
THIẾT KẾ KIẾN TRÚC .................................................................. 41
4.1 Kiến trúc tổng thể ....................................................................................... 41
4.2 Kiến trúc từng thành phần .......................................................................... 41
Website (client) ................................................................................ 41
MySQL ............................................................................................. 42

11


THIẾT KẾ DỮ LIỆU ....................................................................... 43
5.1 Sơ đồ logic ................................................................................................. 43
5.2 Mô tả sơ đồ logic ....................................................................................... 43
THIẾT KẾ GIAO DIỆN .................................................................. 45
6.1 Sơ đồ các màn hình .................................................................................... 45
6.2 Danh sách các màn hình ............................................................................ 45
6.3 Mơ tả các màn hình .................................................................................... 46
Trang chủ .......................................................................................... 46
Trang tìm kiếm ................................................................................. 47
Màn hình thơng tin sản phẩm ........................................................... 48
Trang đăng nhập ............................................................................... 50
Trang đăng ký ................................................................................... 51
Trang hướng dẫn .............................................................................. 52
Trang danh sách yêu thích ................................................................ 53
Trang danh sách theo dõi.................................................................. 54
Trang danh sách địa chỉ .................................................................... 54
PHÁT TRIỂN VÀ CÀI ĐẶT ỨNG DỤNG .................................... 55
7.1 Môi trường phát triển ứng dụng ................................................................. 55
7.2 Môi trường triển khai ứng dụng ................................................................. 56

7.3 Kết quả đánh giá ........................................................................................ 56
KẾT LUẬN VÀ HƯỚNG PHÁT TRIỂN ....................................... 56
8.1 Kết luận ...................................................................................................... 56
8.2 Kết quả đạt được ........................................................................................ 57
8.3 Điểm đặc sắc của đề tài .............................................................................. 58
8.4 Hướng phát triển ........................................................................................ 58
TÀI LIỆU THAM KHẢO ...................................................................................... 58
BẢNG PHÂN CÔNG CÔNG VIỆC ...................................................................... 59

12


TỔNG QUAN VỀ ĐỀ TÀI
1.1 Sơ lược đồ án 1
- Các tính năng đã hồn thành:


Đăng nhập/ đăng xuất.



Đăng ký tài khoản.



Xem danh sách sản phẩm.



Tìm kiếm sản phẩm.




So sánh giá.



Biểu đồ hiển thị giá theo từng thời điểm.



Quản lí thơng tin cá nhân.



Cho người dùng tự thêm một sản phẩm trên sàn thương mại bất kì để theo dõi
giá sản phẩm.



Phân trang.

- Các cơng nghệ đã sử dụng:
• Front-end: reactjs.
• Back-end: ASP.NET.
- Kết quả đạt được:
• Website hồn thiện với đầy đủ chức năng đã đặt ra.
• Thực hiện chính xác yêu cầu của khách hàng.
Các vấn đề cần phải xử lý trong website mà đề tài đặt ra trong đồ án 2 là:


STT

Tên yêu cầu

Khía cạnh

1

Danh sách xem sản phẩm yêu thích

User

2

Validate input của người dùng

User

13


STT

Tên yêu cầu

Khía cạnh

3

Danh sách địa điểm


User

4

Tự động đặt hàng

User

5

Danh sách sản phẩm đang theo dõi

User

6

Điều hướng đến các trang sản phẩm trên sàn thương mại.

User

1.2 Mục tiêu đề tài
Mục tiêu đề tài là nghiên cứu các thuật tốn, cơng nghệ giúp tối ưu những chức năng
đã làm được ở đồ án 1 ngoài ra thêm một vài chức năng nâng cao tạo nên một website
so sánh giá các sản phẩm cơng nghệ hồn chỉnh – tối ưu hố về mọi mặt, mang lại một
sản phẩm chất lượng.
1.3 Đối tượng nghiên cứu
1.3.1 Lý Thuyết
1. Nghiên cứu kỹ thuật lazyload.
2. Nghiên cứu cách validate form với useForm, class validator.

3. Nghiên cứu tối ưu hóa việc call api với use query.
4. Nghiên cứu xác thực người dùng.
5. Nghiên cứu tự động đặt hàng với selenium
1.3.2 Thực Tiễn
1. Xây dựng ứng dụng gồm client, server.
2. Xây dựng website bằng tiếng Việt.
14


3. Xây dựng đồ thị bằng dữ liệu có sẵn.
4. Lấy thông tin, dữ liệu, giá trên các sàn thương mại điện tử.
5. Tự động cập nhật giá sản phẩm sau một thời gian cụ thể.
6. Tự động gửi mail khi có ưu đãi khuyến mãi.
1.4 Các bước nghiên cứu
1. Phân tích u cầu.
2. Lựa chọn cơng nghệ.
3. Nghiên cứu cơ sở lý thuyết dựa trên công nghệ đã chọn.
4. Áp dụng lý thuyết vào xây dựng ứng dụng thực tiễn.
5. Kiểm tra, tham khảo các ứng dụng khác để tối ưu hóa ứng dụng.
1.5 Bố cục đề tài


Cơ sở lý thuyết.



Phân tích thiết kế.




Giải pháp xây dựng.



Triển khai ứng dụng.



Kết luận và hướng phát triển.

CƠ SỞ LÝ THUYẾT
Những gì đã nghiên cứu được trong đồ án 1:
• Framework front-end: reactjs.
• Framework back-end: ASP.NET.
• Ngơn ngữ lập trình javascript.
• Cơ sở dữ liệu MySQL.
 Đồ án 2 sẽ dựa trên cơ sở lý thuyết đã nghiên cứu trong đồ án 1, đồng thời
nghiên cứu, áp dụng cách tối ưu và clean source code.
2.1 Tanstack (React query)

15


Hình 2.1. logo TanStack

1. Giới thiệu
React Query là một thư viện quản lý trạng thái và thực hiện yêu cầu mạng
trong ứng dụng React. Nó cung cấp các cơng cụ và API cho phép bạn quản lý
trạng thái ứng dụng, cache dữ liệu, và thực hiện các yêu cầu HTTP hoặc bất kỳ
yêu cầu mạng nào khác.

Thư viện React Query giúp giảm bớt công việc phức tạp liên quan đến quản lý
trạng thái ứng dụng, tối ưu hóa việc truy vấn dữ liệu từ API và cung cấp các
khả năng như caching, tải lại dữ liệu tự động, xử lý lỗi và các tùy chọn tương
tác khác với dữ liệu.
React Query sử dụng các khái niệm như "query" (truy vấn), "mutation" (điều
chỉnh) và "invalidate" (vơ hiệu hóa) để mơ tả các hoạt động quan trọng trong
việc truy vấn và cập nhật dữ liệu. Nó cung cấp các hook như useQuery,
useMutation, và useQueryClient để bạn có thể tận dụng các tính năng này trong
ứng dụng React của mình.
Với React Query, bạn có thể xây dựng các ứng dụng React hiệu quả với khả
năng quản lý trạng thái dễ dàng và tối ưu hóa giao tiếp với API.
2. Cách triển khai react query
16


1. Cài đặt React Query: Sử dụng npm hoặc yarn để cài đặt React Query
bằng cách chạy lệnh sau trong thư mục dự án:

2. Cung cấp React Query cho ứng dụng: Tại file gốc của ứng dụng React
(thường là index.js hoặc App.js), nhập React Query và bọc ứng dụng
của trong một QueryClientProvider, như sau:

3. Sử dụng hook useQuery trong các thành phần của bạn: Trong các thành
phần React, bạn có thể sử dụng hook useQuery để thực hiện các yêu
cầu và quản lý trạng thái dữ liệu.

17


18



2.2 Kỹ thuật Lazyloading

Lazy loading (tải chậm) là một kỹ thuật trong lập trình và thiết kế giao diện
người dùng nhằm giảm thời gian tải và tối ưu hóa hiệu suất ứng dụng. Khi áp dụng
lazy loading, các tài nguyên như hình ảnh, video, hoặc mã nguồn JavaScript được tải
vào ứng dụng theo nhu cầu thực sự của người dùng, thay vì tải tất cả tài nguyên cùng
lúc khi trang web hoặc ứng dụng được mở.
Khi một trang web hoặc ứng dụng được tải lần đầu, chỉ những phần cần thiết
ban đầu được tải, trong khi các phần còn lại được trì hỗn tải cho đến khi cần thiết. Ví
dụ, khi người dùng cuộn trang xuống để xem thêm nội dung, các hình ảnh mới sẽ
được tải khi chúng hiển thị trong tầm nhìn của người dùng. Điều này giúp giảm thời
gian tải ban đầu, tăng tốc độ tải trang và giảm tải cho máy chủ.
Trong ngữ cảnh của ứng dụng web, lazy loading có thể được thực hiện bằng
cách sử dụng thuộc tính loading="lazy" trong các thẻ <img> hoặc <video>, hoặc
thông qua việc sử dụng các thư viện tải chậm chuyên dụng như LazyLoad hay
Intersection Observer API.
Các framework JavaScript như React và Angular cũng cung cấp các cơ chế
lazy loading cho các thành phần hoặc tập tin JavaScript để tối ưu hiệu suất ứng dụng.

19


Điều này đảm bảo rằng chỉ những thành phần cần thiết cho trang hiện tại được tải,
trong khi các thành phần khơng cần thiết được tải khi cần thiết (ví dụ: khi người dùng
chuyển đổi đến một trang khác).
2.3 React hook form

Trong React, để quản lý và xử lý biểu mẫu (form), bạn có thể sử dụng hook

useForm từ thư viện React Hook Form. React Hook Form là một thư viện hỗ trợ quản
lý biểu mẫu hiệu quả trong React, giúp bạn xử lý kiểm tra, gửi và xác thực dữ liệu một
cách dễ dàng

Cách triển khai:
1. Cài đặt React Hook Form: Sử dụng npm hoặc yarn để cài đặt React Hook Form
bằng cách chạy lệnh sau trong thư mục dự án.

2. Sử dụng useForm trong thành phần.

20


2.4 Phân quyền với JWT

21


JWT là viết tắt của JSON Web Token. Đây là một tiêu chuẩn mở (RFC 7519)
được sử dụng để truyền thông tin giữa các bên dưới dạng một đối tượng JSON an toàn
và đơn giản. JWT thường được sử dụng để xác thực và ủy quyền trong các ứng dụng
web và dịch vụ API.
Một JWT bao gồm ba phần chính: Header, Payload và Signature.

• Header: Chứa thơng tin về loại mã thơng báo (token) và thuật tốn mã hóa
được sử dụng.
• Payload: Chứa các thơng tin (claims) về người dùng hoặc tài liệu, ví dụ như tên
người dùng, quyền truy cập, hạn chế thời gian, v.v.
• Signature: Được tạo bằng cách ký hố Header và Payload sử dụng một khóa bí
mật (secret key) hoặc cặp khóa cơng khai / riêng (public/private key). Signature

được sử dụng để kiểm tra tính tồn vẹn và xác thực của JWT.
Khi một người dùng xác thực thành công bằng cách đăng nhập vào hệ thống,
máy chủ sẽ tạo một JWT và trả về cho người dùng. Người dùng sau đó gửi JWT
trong mỗi yêu cầu đến máy chủ để chứng minh rằng họ đã được xác thực và có
quyền truy cập vào tài nguyên cần thiết.

22


JWT có nhiều ưu điểm như tính di động, tiện lợi, và khả năng mở rộng. Nó giúp
tránh việc lưu trữ trạng thái phiên (session state) trên máy chủ và cho phép phân
tán và quyền truy cập an toàn trong môi trường phân tán.
2.5 Selenium

Selenium là một công cụ tự động hóa trình duyệt web phổ biến và mạnh mẽ.
Nó cho phép bạn điều khiển và kiểm soát các hoạt động trong trình duyệt web một
cách tự động, giúp tự động hóa các tác vụ như kiểm thử ứng dụng web, tự động
đăng nhập, lấy dữ liệu từ trang web, hoặc thực hiện các thao tác giao diện người
dùng trên trình duyệt.
Selenium hỗ trợ nhiều ngơn ngữ lập trình như Java, Python, C#, Ruby, và
JavaScript, cho phép bạn sử dụng ngơn ngữ mà bạn ưa thích để viết mã tự động
hóa.
Có hai phiên bản chính của Selenium:
1. Selenium WebDriver: Đây là phiên bản phổ biến nhất của Selenium và cung
cấp API để tương tác với trình duyệt web. Bạn có thể sử dụng WebDriver để
điều khiển các trình duyệt phổ biến như Chrome, Firefox, Safari, Edge, v.v.
2. Selenium IDE (Integrated Development Environment): Đây là một công cụ ghi
và tái chơi các hoạt động trên trình duyệt web một cách tự động. Selenium IDE
là một tiện ích mở rộng cho các trình duyệt web như Chrome và Firefox, và nó
cung cấp một giao diện đồ họa dễ sử dụng để ghi lại và thực hiện các hành

động trên trình duyệt.
Selenium cung cấp các chức năng như tìm kiếm phần tử trong trang web, nhập
liệu vào các trường đầu vào, nhấp chuột, kiểm tra các điều kiện, xử lý các cửa sổ
23


và khung, và thực hiện các thao tác giao diện người dùng khác. Bằng cách sử dụng
Selenium, bạn có thể tự động hóa các quy trình trong ứng dụng web của mình và
tiết kiệm thời gian và cơng sức cho việc kiểm thử và xử lý trình duyệt web.

PHÂN TÍCH ĐẶC TẢ YÊU CẦU
3.1 Usecase, đặc tả usecase
Sơ đồ usecase

Danh sách Usecase
Primary Actor
User

Use Cases
1. Sắp xếp sản phẩm
2. Sắp xếp giá tăng dần
24


3. Sắp xếp giá giảm dần
4. Tìm kiếm sản phẩm
5. Xem sản phẩm
6. Nhận ưu đãi khuyến mãi
7. Xem biên động giá
8. Xem biểu đồ so sánh giá

9. CRUD sản phẩm yêu thích
10. CRUD địa chỉ
Đặc tả usecase
Các use case từ UC-1 -> UC-8 được xem như người dùng đã truy cập vào website
TopSoSanh.
Các use case từ UC-2 -> UC-8 được xem như người dùng đã thực hiện use case UC-1.
3.1.2.1 Tìm kiếm sản phẩm

Use Case ID

UC-1

Use Case Name

Tìm kiếm sản phẩm

Description

Là người dùng, tơi muốn tìm kiếm sản
phẩm

Actor(s)

Khách hàng.

Priority

Must Have

Trigger


Người dùng muốn tìm kiếm sản phẩm
• Người dùng nhập từ khóa tìm

Pre-Condition(s):

kiếm.
• Người dùng ấn vào nút tìm kiếm.
• Hệ thống sử dụng keyword của

Post-Condition(s):

người dùng từ ơ tìm kiếm để lấy
api.
• Hệ thống lấy thành cơng api trả về

25


×