Vì vậy,chúng em xin giới thiệu 1 hệ thống quản lý thư viện, đáp ứng được 1 số chức năng cơ bản cần thiết của một hệ thống quản lý thư viện là quản lý tài liệu, bạn đọc,quản lý cập nhật v
Trang 1TRƯỜNG ĐẠI HỌC BÁCH KHOA HÀ NỘI VIỆN CÔNG NGHỆ THÔNG TIN VÀ TRUYỀN THÔNG
-BÁO CÁO BÀI TẬP LỚN
Môn: Phân tích thiết kế hệ thống hướng đối tượng
Đề tài : Phân tích thiết kế hệ thống quản lí thư viện
Giáo viên hướng dẫn: TS Nguyễn Hữu Đức
Sinh viên thực hiện: Nhóm 13
Trang 2M c l c: ục lục: ục lục:
Lời nói đầu 3
I Khảo sát nghiệp vụ 4
1.Mô tả chung hệ thống nghiệp vụ 4
1.1 Hoạt động của 1 hệ thống thư viện nói chung: 4
1.2 Yêu cầu của hệ thống: 5
2.Danh sách quy trình nghiệp vụ 5
3.Đặc tả quy trình nghiệp vụ 5
4.Mô hình hóa quy trình nghiệp vụ 9
II Phân tích 10
1.Đối tác và ca sử dụng 10
1.1 Đối tác 10
2.Đặc tả ca sử dụng 10
2.1 Sơ đồ usecase tổng quát 11
2.2 Quản lí truy cập 12
2.3 Tìm kiếm 14
2.4 Quản lí sách 19
2.5 Quản lí người dùng 22
2.6Quản lí mượn trả sách 26
2.7 Quản lí báo cáo 28
3.Phân tích kiến trúc và hành vi 30
3.1 Biểu đồ trình tự hệ thống 30
3.2 Biểu đồ lớp 35
III Thiết kế 40
1.Phân rã thành gói các chức năng 40
2.Mô hình phân tầng theo công nghệ 41
2.1 Giới Thiệu Yii Framework 41
2.2 Các thành phần trong Project dùng Yii Framework: 42
2.3 Luồng hoạt động trong Yii project 43
Kết luận 44
Tài liệu tham khảo: 45
Trang 3Lời nói đầu
Hiện nay, thư viện là một hệ thống khá phổ biến trong các trường học cũngnhư trên các tỉnh thành trong cả nước Đi cùng với sự phát triển của các thư viện
là nhu cầu của bạn đọc tăng lên, và số lượng sách trong thư viện cũng tăng lên rấtnhiều so với những hệ thống thư viện đơn giản và nhỏ lẻ trước đây
Và, cũng một yêu cầu được đặt ra cùng với sự phát triển đó là làm thế nào đểquản lý các thông tin trong thư viện một cách tót nhất và có hiệu quả nhất Vì vậy,chúng em xin giới thiệu 1 hệ thống quản lý thư viện, đáp ứng được 1 số chức năng
cơ bản cần thiết của một hệ thống quản lý thư viện là quản lý tài liệu, bạn đọc,quản lý cập nhật và quản lý quá trình mượn và trả sách trong thư viện Hệ thống
mà em đang giới thiệu tập trung chủ yếu vào quản lý dữ liệu ( tài liệu, bạn đoc ) vàquản lý mượn, trả sách…
Chúng em xin chân thành cảm ơn thầy giáo TS Nguyễn Hữu Đức và các bạntrong lớp HTTT-K53 đã giúp đỡ chúng em hoàn thành việc phân tích thiết kế hệthống này!
Trang 4I Khảo sát nghiệp vụ.
1.Mô tả chung hệ thống nghiệp vụ
1.1 Hoạt động của 1 hệ thống thư viện nói chung:
Đối với các hệ thống quản lý thư viện nói chung mà em đã từng được chứngkiến, thì có thể nhận thấy 1 hệ thống quản lý thư viện thường có các hoạt động cơbản sau :
Thư viện làm các phích sách theo vần A…B…C , mỗi ô phích có nhiềuphích sách, mỗi phích sách bao gồm các thông tin về Mã sách, Tên sách, Tên tácgiả, Năm xuất bản, Thể loại… Khi bạn đọc muốn mượn sách thì tra cứu thông tintrên phích sách rồi ghi vào phiếu mượn
Một dạng của phiếu mượn:
Bạn đọc đến với thư viện sẽ được cấp cho một phiếu mượn trên đó ghi đầy
đủ các thông tin về bạn đọc như : họ tên, mã số thẻ, ngày cấp…
Mượn sách: Bạn đọc tìm kiếm và ghi thông tin sách cần mượn lên phiếumượn, sau khi kiểm tra đầy đủ thông tin trên phiếu mượn và thẻ mượn, người quản
lý sẽ kiểm tra điều kiện mượn của sinh viên và cho phép mượn sách, lưu lại một sốthông tin trong phiếu em chưa mượn để quản lý
Trang 5Trả sách: Khi bạn đọc mang sách đến trả tại thư viện, người quản lý sẽ dựavào thông tin trên phiếu mượn đã được lưu lại để kiểm tra sách và thời gian trả, xácnhận sách trả cho bạn đọc.
Bạn đọc mà trả muộn hơn thời gian quy định sẽ bị phạt
1.2 Yêu cầu của hệ thống:
Dựa vào các hoạt động cơ bản của một hệ thống thư viện, ta có thể thấyđược những yêu cầu cơ bản của một hệ thống quản lý thư viện là :
- Cung cấp cho người quản lý các thông tin về các đầu sách trong thư viện,các đầu sách theo từng thể loại , số sách đang được mượn, số sách rỗi (chưa đượcmượn)…
- Hỗ trợ việc quản lý thông tin về bạn đọc
- Hỗ trợ cập nhật các thông tin về tài liệu và bạn đọc như : các lần tái bản, t
hêm sách, thêm bạn đọc, xóa bạn đọc, thay đổi thông tin tài liệu, thay đổithông tin bạn đọc…
- Hỗ trợ người quản lý trong quá trình xác nhận cho mượn và trả sách với bạnđọc
- Đối với một thư viện online, hệ thống quản lý thư viện còn cho phép bạnđọc có thể tìm kiếm, tra cứu tài liệu trực tiếp trên internet và lựa chọn các đầu sáchmình cần trước khi thực hiện quá trình mượn sách tại thư viện
2.Danh sách quy trình nghiệp vụ
Từ mô tả chung về hệ thống nghiệp vụ, chúng ta rút ra các quy trình nghiệp vụ chính của hệ thống:
- Cho mượn sách: một sinh viên có nhu cầu mượn sách sẽ lên thư viện lập phiếu yêu cầu mượn sách, và sẽ được mượn sách của thư viện
- Nhận trả sách: khi đến hạn trả sách, sinh viên sẽ mang sách lên thư viện trả lại sách
Trang 6Cho mượn sách:
Trang 7Nhận trả sách:
Trang 8Cập nhật sách:
Trang 94.Mô hình hóa quy trình nghiệp vụ
Trang 10II Phân tích
1.Đối tác và ca sử dụng
1.1 Đối tác
Qua quá trình khảo sát nghiệp vụ ta nhận thấy hệ thống gồm 3 tác nhân là:
- Sinh viên: Sinh viên là đối tác thực hiện việc mượn trả sách Sinh viên có thể đăng nhập vào hệ thống để biết thông tin về quá trình mượn trả sách của mình, tìm kiếm những đầu sách muốn mượn trong thư viện
- Nhân viên thư viện: là tác nhân thực hiện công việc ghi nhận cho mượn và trả sách của sinh viên, thực hiện cập nhật sách khi thư viện nhập thêm sách mới về,thực hiện quản lí sinh viên, lập các báo cáo cho cấp trên
- Quản lí thư viện: là người có quyền hạn cao nhất, có tất cả các khả năng của nhân viên, và có khả năng quản lí nhân viên
Trang 112.1 Sơ đồ usecase tổng quát
Trang 12Phương thức cơ bản 1 Người dùng chọn chức năng
Trang 13Thiết kế giao diện:
thư viện
thống muốn thoát ra khỏi hệ thống
Sự kiện kích hoạt Người dùng chọn chức năng đăng xuấtĐiều kiện kiên quyết Người dùng phải đăng nhập
Phương thức cơ bản 1 Người dùng chọn chức năng
Trang 142.3 Tìm kiếm
Trang 15Tìm sách theo từ khóa:
thư viện
thống muốn tìm kiếm sách trong cơ sở
dữ liệu
Sự kiện kích hoạt Người dùng chọn chức năng tìm kiếm
theo từ khóa Điều kiện kiên quyết Người dùng phải đăng nhập
Phương thức cơ bản 1 Người dùng chọn tìm kiếm theo
từ khóa
2 Hệ thống trả về form tìm kiếm theo từ khóa
3 Người dùng nhập từ khóa và tìmkiếm
4 Hệ thống trả về kết quả tìm kiếm
Phương thức thay thế
người sử dụng muốn tìm
Ngoại Lệ
Thiết kế giao diện
Trang 16Tìm sách theo thể loại:
thư viện
thống muốn tìm kiếm sách trong cơ sở
dữ liệu
Sự kiện kích hoạt Người dùng chọn chức năng tìm kiếm
theo thể loại Điều kiện kiên quyết Người dùng phải đăng nhập
Phương thức cơ bản 1 Người dùng chọn tìm kiếm theo
thể loại
2 Hệ thống trả về form tìm kiếm theo thể loại
3 Người dùng nhập từ khóa và tìmkiếm
4 Hệ thống trả về kết quả tìm kiếm
Phương thức thay thế
người sử dụng muốn tìm
Ngoại Lệ
Thiết kế giao diện:
Trang 17Tìm kiếm sinh viên:
thư viện muốn tìm sinh viên để thực hiện ghi nhận mượn trả
Sự kiện kích hoạt Nhân viên thư viện chọn chức năng
tìm kiếm sinh viên Điều kiện kiên quyết Nhân viên phải đăng nhập
Phương thức cơ bản 1 Người dùng chọn tìm kiếm sinh
viên
2 Hệ thống trả về form tìm kiếm theo thể loại
3 Nhân viên nhập mã số sinh viên
4 Hệ thống trả về kết quả tìm kiếm
Phương thức thay thế
Ngoại Lệ
Thiết kế giao diện:
Trang 18Tìm kiếm nhân viên:
thông tin của nhân viên
Sự kiện kích hoạt Quản lí thư viện chọn chức năng tìm
kiếm nhân viên Điều kiện kiên quyết Quản lí thư viện phải đăng nhập
Phương thức cơ bản 1 Người dùng chọn tìm kiếmnhân
Trang 192.4 Quản lí sách
Quản lí cập nhật sách:
mới, xóa sách ko có trong thư viện, sửathông tin về sách, nhân viên thư viện sẽdùng usecase này
Sự kiện kích hoạt Nhân viên thư viện vào quản lí sách Điều kiện kiên quyết Nhân viên thư viện phải đăng nhập
Phương thức cơ bản 1 Nhân viên chọn một trong các
chức năng thêm sách, xóa sách, thay đổi sách
2 Hệ thống cập nhật kết quả vào
Trang 20Thiết kế giao diện:
Trang 21Thêm thể loại sách:
Trang 222.5 Quản lí người dùng
Thêm sinh viên:
cần thêm tài khoản cho sinh viên truy cập vào hệ thống thư viện của trường
Sự kiện kích hoạt Khóa mới vào trường, nhân viên thư
viện cập nhật sinh viên mới
Điều kiện kiên quyết Nhân viên thư viện phải đăng nhập
Phương thức cơ bản 1 Nhân viên chọn thêm sinh viên
2 Hệ thống tạo một trường sinh viên mới trong cơ sở dữ liệu
Phương thức thay thế
dùng thư việnNgoại Lệ
Tần suất sử dụng Mỗi năm dùng một lần khi có khóa
mới nhập trường
Trang 23Thiết kế giao diện:
Xóa sinh viên:
thành trả sách thư viện
Sự kiện kích hoạt Nhân viên thư viện xóa sinh viên đã ra
trườngĐiều kiện kiên quyết Nhân viên thư viện phải đăng nhập
Phương thức cơ bản 1 Nhân viên chọn xóa sinh viên
2 Hệ thống xóa sinh viên và lưu trong cơ sở dữ liệu
Phương thức thay thế
Trang 24Thiết kế giao diện:
Thêm nhân viên:
Sự kiện kích hoạt Quản lí thêm nhân viên mới
Điều kiện kiên quyết Quản lí phải đăng nhập
Phương thức cơ bản 1 Quản lí chọn thêm nhân viên
2 Hệ thống thêm nhân viên mới Phương thức thay thế
Ngoại Lệ
Thiết kế giao diện:
Trang 25Xóa nhân viên:
Sự kiện kích hoạt Quản lí thư viện thực hiện xóa nhân
viênĐiều kiện kiên quyết Quản lí thư viện phải đăng nhập
Phương thức cơ bản 1 Quản lí thư viện chọn xóa nhân
viên
2 Hệ thống xóa nhân viên và lưu
cơ sở dữ liệu Phương thức thay thế
Trang 262.6Quản lí mượn trả sách
Cho mượn sách:
viên thư viện thực hiện cập nhật thông tin sách mà sinh viên đã mượn
Sự kiện kích hoạt Sinh viên đến mượn sách và nhân viên
nhận phiếu mượn sách của sinh viên.Điều kiện kiên quyết Nhân viên thư viện phải đăng nhập
Phương thức cơ bản 1 Nhân viên nhập số hiệu sinh
viên, mã sách sinh viên mượn
2 Hệ thống lưu thông tin này vào
cơ sở dữ liệu Phương thức thay thế
được lưu
Ngoại Lệ
Trang 27Thiết kế giao diện:
Nhận trả sách:
thư viện nhận lại sách và lưu thông tin
Sự kiện kích hoạt Sinh viên đến trả sách, nhân viên thư
viện nhận sách
Điều kiện kiên quyết Nhân viên thư viện phải đăng nhập
Phương thức cơ bản 1 Nhân viên nhập số hiệu sinh
viên, mã sách sinh viên mượn
2 Hệ thống kiểm tra và xóa thông tin về sách đã trả của sinh viên Phương thức thay thế
Ngoại Lệ
Trang 28Thiết kế giao diện:
2.7 Quản lí báo cáo
Trang 29Quản lí báo cáo:
hình hoạt động của thư viên như sách thiếu, sách hết, sinh viên quá hạn trả
mà chưa trả sách
Sự kiện kích hoạt Quản lí thư viện, nhân viên thư viện
lập báo cáoĐiều kiện kiên quyết Nhân viên thư viện, quản lí thư viện
phải đăng nhập Phương thức cơ bản 1 Chọn loại báo cáo cần lập và lập
Trang 303.Phân tích kiến trúc và hành vi
3.1 Biểu đồ trình tự hệ thống
Usecase đăng nhập:
Trang 31Usecase đăng xuất:
Trang 32Usecase cập nhật sách:
Usecase tìm kiếm nhân viên
Trang 33Usecase tìm kiếm sách:
Trang 34Usecase tìm kiếm sinh viên:
Usecase tìm kiếm theo thể loại sách:
Trang 353.2 Biểu đồ lớp
Usecase đăng nhập:
Trang 36Usecase tìm kiếm:
Trang 37Usecase quản lí nhân viên:
Usecase quản lí sinh viên:
Trang 38Usecase cho mượn sách:
Usecase nhận trả sách:
Trang 39Usecase quản lí báo cáo:
Trang 40III Thiết kế
1.Phân rã thành gói các chức năng
Qua quá trình phân tích ở trên, chúng em thiết kế thành các gói chức năng sau:
Trang 412.Mô hình phân tầng theo công nghệ
Ở đây chúng em sử dụng framework Yii được viết bằng ngôn ngữ PHP.Dướiđây,chúng em xin trình bày kiến trúc của framework và cách thức hoạt động của nó
2.1 Giới Thiệu Yii Framework
- Yii Framework là framework sử dụng ngôn ngữ PHP được thiết kế theo mô hình MVC Yii ra đời lần đầu tiên năm 2008 do một tác giả là Quiang Xue viết
ra Quiang Xeng cũng chính là người đứng đầu nhóm xây dựng Prado một
framework khác của PHP
- Trong quá trình phát triển Prado,nhận thấy nhiều nhược điểm của Prado đặc biệt là về hiệu năng,Quiang và nhóm phát triển Prado đã quyết định xây dựng lại một framework mới kế thừa những ưu điểm của Prado và mang rất nhiều cải tiến mới mẻ,độc đáo khiến cho Yii Framework trở thành một trong những framework
có hiệu năng cao nhất và thích hợp cho việc xây dựng các ứng dụng web rất đa dạng ở nhiều loại hình,quy mô với sự tiết kiệm rất nhiều thời gian và công sức cho người phát triển
- Yii là có nhiều ưu điểm nổi bật so với các framework ra đời trước.Sau đây làmột số ưu điểm nổi bật của Yii
+Yii được thiết kế theo mô hình Framework ,mô hình phổ biến được áp dụng cho phần lớn các framework PHP giúp thuận tiện cho người phát triển trong quá trình phát triển,sửa lỗi ,bảo dưỡng
+Yii sử dụng ActiveRecord Design Pattern để biểu diễn và thao tác với dữ liệu một cách trong sáng và chặt chẽ.Đồng thời ,Yii cũng cung cấp 2 cách nữa để làm việc với CSDL là DAO (Data Access Object) và Query Builder.Mỗi cách lại
có những ưu ,nhược điểm riêng,người phát triển có thể chọn lựa cách thức phù hợpnhất trong từng trường hợp
+Yii sử dụng Jquery là thư viện Javascript mặc định,hỗ trợ rất tốt cho Ajax+Yii có các widget giúp cho người phát triển rất dễ dàng trong xây dựng giao diện người dùng
Trang 422.2 Các thành phần trong Project dùng Yii Framework:
Một website sử dụng Framework Yii sẽ có cấu trúc tĩnh cơ bản như sau:
+Một file Bootrap index.php
Là bootrap script để xử lý yêu cầu ban đầu của người dùng.Nó là script duy nhất mà người dùng có thể trực tiếp yêu cầu thực thi
+Application: Đối tượng các đối tượng gom nhóm các ngữ cảnh thực thi mà trong đó có thể sử dụng yêu cầu người dùng,quản lý các controller và các
component của hệ thống
+Các component của ứng dụng:
Yii có kiến trúc component.Có thể thêm các component cho Yii để thực hiệncác chức năng cụ thể một cách dễ dàng.Để sử dụng các component của Yii,ta cần thêm các thông tin cấu hình trong file config
+Controller
Là một thể hiện của lớp Ccontroller.Nó được tạo bởi đối tượng application khi có yêu cầu từ người dùng được gửi đến.Khi một yêu cầu được thực
hiện,controller sẽ thực thi action được yêu cầu.action của Yii đơn giản chỉ là
phương thức mở đầu bằng từ khóa “action”.Controller đọc dữ liệu từ model ,xử lý
và trả về kết quả cho view tương ứng
+Model
Là một thể hiện của lớp CModel được được dùng để biểu diễn dữ liệu,các quy tắc biểu diễn dữ liệu và mối quan hệ giữa chúng.Mỗi model biểu diễn một đối tượng dữ liệu đơn.Nó có thể là một hàng của một bảng hoặc một trường của
HTML form.Mỗi trường của dữ liệu tương ứng với một thuộc tính của model.Trong Yii có 2 loại Model: Cform và CactiveRecord.Cả hai đều là lớp con của Cmodel.Cform được sử dụng để biểu diễn dữ liệu thu thập từ người dùng thông qua form
Cactive Record sử dụng Active Record design pattern (Đối tượng truy cập
dữ liệu trừu tượng) để biểu diễn dữ liệu trong các bảng của CSDL
+Layout
Trang 43Layout là một view đặc biệt trong Yii.Nó quy định giao diện ,bố cục chung cho cả trang.Trong Layout ,view của action được thực hiện sẽ được truyền vào quabiến $content.
+Widget là thể hiện của lớp Cwidget và các lớp con của Cwidget.Widget chủ yếu dùng để tạo giao diện.Widget thường được dùng để tạo ra các đối tượng giao diện tương đối phức tạp như ClistView, CdetailedView, CgridView, Calendar,…Widget tạo ra sự tiện dụng cho người phát triển ,giúp việc sử dụng lại code được thực hiện dễ dàng và hiệu quả hơn rất nhiều
2.3 Luồng hoạt động trong Yii project
- hi có request từ người dùng,đầu tiên file bootrap index.php sẽ được thực thi
và tạo ra đối tượng Cwebapplication.Đối tượng này làm nhiệm vụ quản lý các controller và component
- Đối tượng Webapp sẽ xác định thông tin chi tiết về yêu cầu của người dùng thông qua component request
- Đối tượng Webapp xác định controller và action được gọi đến thông qua component URL Manager
- Sau khi xác định được controller và action ,Webapp gọi đến controller và action đó Một thể hiện của Controller được tạo ra.Trước khi action được thực thi,controller sẽ tạo ra và thực thi bộ lọc tương ứng với action đó.Nếu thỏa mãn cácđiều kiện của bộ lọc thì action sẽ được thực thi.Ngược lại ,nếu không thỏa mãn cácyêu cầu thì sẽ có thông báo lỗi
- Khi thực hiện action,action đọc dữ liệu từ model rồi render đến 1 view nào
đó và truyền dữ liệu đến view đó.View đọc dữ liệu từ model
- View thực thi widget
- View đã được render được nhúng vào layout
- Cuối cùng ,action trả lại kết quả cho người dùng