1、 1 / 15软件系统分析与设计实验报告学 院:计算机科学与技术学院专 业:软件工程学 号:*姓 名:*实验名称:图书管理系统用例建模时 间:2 / 15一、 实验内容与要求本实验要求学生对学校的图书馆管理系统进行需求分析,对系统功能进行用例建模,画出用例图,类图以及相应的时序图。在使用 UML 对系统建模时,学会使用 UML 建模工具,熟悉工具中的功能。二、用例分析1、读者“ 借书还书系统” 用例图书(from Actors)书(from Use Cases)书(from Use Cases)书(from )书(from Use Cases)11、 行为者:主要行为者:读者。12、 前置条件
2、:读者进入图书管理系统。13、 事件流:1.3.1、主要事件流:1.3.1.1:读者检索所需图书信息,并查看;1.3.1.2:读者检索到所需图书,登录系统,开始借书;1.3.1.3:系统查询图书信息,图书数目是否可借;3 / 151.3.1.3.1:图书显示可借,借书成功;1.3.1.3.2:图书显示不可借,借书失败;1.3.1.4:进入续借图书界面,续借图书;1.3.1.5:系统查看预约记录,1.3.1.5.1:没有冲突,续借成功;1.3.1.5.2:有冲突,续借失败;1.3.3.1:1.3.1.6:读者归还图书;1.3.1.6.1:归还时间没有逾期,归还成功;1.3.1.5.2:归还时间逾
3、期,逾期处罚,归还成功;1.3.2、备选事件流:1.3.2.1:图书检索信息失败,未检索到图书,重新输入信息检索;1.3.2.2:未曾检索到用户检索的图书,系统显示相关联的信息的图书;1.3.2.3:用户名或密码输入错误,登录系统失败,重新输入用户名或密码登录;1.3.2.4:系统显示图书不可借后,进入图书预约界面,输入信息预约图书;1.3.3、异常事件流:1.3.3.1:读者登录系统失败,未曾注册用户;1.3.3.1.1:返回系统注册用户后,重新登录。14、 后置条件:退出系统。15、16、 扩展点:无。2、 “图书信息管理系统”用例图4 / 15书书(from Actors)书书书(fro
4、m Use Cases)书书书(from Use Cases)书书书(from Use Cases)书书(from Use Cases)书书(from Use Cases)书书(from Use Cases)书书(from Use Cases) 21、行为者:主要行为者:管理员;22、前置条件:管理员打开图书信息管理系统;23、事件流:2.3.1:主要事件流:2.3.1.1:图书管理员输入管理员登录信息,登录系统;2.3.1.2:进入图书信息管理界面,查看已有图书信息,是否有需要购入图书;2.3.1.2.1:录入新购进图书信息,并确认;2.3.1.3:进入读者信息管理界面,管理已有用户信息;2
5、.3.1.4:进入信息通知界面,查看已有用户图书借阅、预约情况;2.3.1.4.1:查看读者所预约图书,自动查询图书信息,确认是否已有可借图书,有则通知读者;2.3.1.4.2:查询读者已借图书信息,根据已借时间及归还时间分类;2.3.1.4.2.1:所借图书即将逾期,启动系统提醒功能;2.3.1.4.2.2:所借图书已经逾期,启动逾期及处罚通知功能;2.3.2:备选事件流:2.3.2.1:管理员用户名或登录名错误,重新登录;2.3.2.2:需要购进新图书,存储信息,通知相关人员;2.3.2.3:读者预约图书没有可借图书,不予通知;2.3.2.4:预约通知提醒后,删除该预约记录;2.3.2.5
6、:读者所借图书距离归还时间仍很久,无需通知;5 / 152.3.3:异常事件流:2.3.3.1:登录失败超过一定次数后,系统冻结该用户名,一段时间后可以重用;24、后置条件:退出系统;25、扩展点:无。三、 “图书管理系统”类图及关系1、 阅读者信息类:1.1、类名:阅读者信息;1.2、属性名:1.2.1、private: ID 类型:String;6 / 151.3、方法:未定。2、 读者类:2.1、类名:读者 ;2.2、属性名:1.2.1、private:ID 类型:String;2.3、方法:未定。3、 管理员类:3.1、类名:管理员3.2、属性名:1.2.1、private: ID 类
7、型:String;3.3、方法:未定。4、 Book 类:4.1、类名:book4.2、属性名:4.2.1、private: 书号 类型:String;4.2.2、private: 书名 类型:String;4.2.3、private: 出版号 类型:String;4.2.4、private: 出版社名 类型:String;4.2.5、private: 作者 类型:String;4.3、方法:未定。5、 Copy_book 类:5.1、类名:copy_book;5.2、属性名:5.2.1、private: 书号 类型:String;5.2.2、private: 书名 类型:String;5.2
8、.3、private: 出版号 类型:String ;5.2.4、private: 出版社名 类型:String;5.2.5、private: 作者 类型:String;5.2.6、private:count 类型:String;5.3、方法:未定。6、 借还书记录类:6.1、类名:借还书记录;6.2、属性名:6.2.1、private: 书号 类型:String;6.2.2、private: 书名 类型:String;6.2.3、private:读者姓名 类型:String;6.2.4、private: 出版社名 类型:String ;6.2.5、private: 作者 类型:String
9、;6.2.6、private:borrowdate 类型:Date ;7 / 156.2.7、private:due_Date 类型:Date ;6.2.8、private:real_Date 类型:Date ;6.3、方法:6.3.1、private:getDate() 返回值:Date;6.3.2、private:isOverDate() 返回值:bool ;6.3.3、private:opname() 返回值:void ;7、 预约类:7.1、类名:Reservation;7.2、属性:7.2.1:private:书名 类型:String;7.2.2:private:作者 类型:Stri
10、ng;7.2.4:private:读者 ID 类型:String;7.2.4:private:预约时间 类型:Date ;7.3、方法:未定。四、图书管理系统时序图及分析1) 、时序图内容时序图是显示对象之间交互的图,这些对象是按时间顺序排列的。该图书馆管理系统主要含有以下几个重要的时序图,其他对象的时序图和这些类似。1、 借书时序图;2、 还书时序图;3、 预约时序图。2) 、时序图分析1、借书时序图8 / 15:书 :书书 书书书 书loan 书 copy_bok bok Resrvation书书 login书show_reader书1:check书 borw书 getrader()2:c
11、heck书 getbokinf() 3:check()1:isBorw()bulidinf()2:isBorw()3:isBorw()4:isborw()【借书时序图说明】1、 login():读者将需借书目交给管理员,管理员登陆系统。2、 show_reader():显示读者的信息的函数。3、 check():验证读者是否有借书的权利。4、 borrow():读者借书函数。5、 getreader():获取读者信息的函数。6、 check():检验读者是否符合借书条件函数。7、 getbookinf():获取书目信息函数。8、 check():检查书籍是否被预约的函数。9、 isBorrow
12、():返回未被预约函数。10、 builtinf():建立借阅信息函数。11、 isBorrow():返回借阅信息函数。12、 isBorrow():返回借阅成功函数。13、 isBorrow:借阅成功,将书交给读者。借书时,读者先将书拿予管理员,管理员对书籍和读者进行检验,若书籍和读者都符合借书条件,则借书成功。2、还书时序图9 / 15: 书 : 书书 书书 bok loan书 login书getbokinf书getborowinf()getborowDate()getnowDate()isOverDate()returnwork()return【还书时序图说明】1、 login():读者
13、将书籍交给管理员,管理员登录系统。2、 getbookinf():管理员扫描条形码,获取书籍信息函数。3、 getborrowinf():获取借阅信息函数。4、 getborrowDate():获取借阅时间函数。5、 getnowDate():获取现在时间函数。6、 isOverDate():是否超出借阅时间函数。7、 work():处理函数,处理时间差。8、 return:消息返回。还书时,读者先将书交给管理员,由管理员扫描书籍,若书籍没有过期等违规现象,还书成功。3、预约时序图10 / 15: 书 书书书 copy_bok Reservationboklogin书 getbokinf()c
14、heck书 reservation书getbok书build书return result【预约图书时序图说明】1、 login():登录系统。2、 getbookinf():获取图书信息函数。3、 check():检查是否有图书可借函数。4、 reservation():确定预约图书函数。5、 getboook():获取预约图书信息函数。6、 built():建立预约信息函数。7、 return:消息返回。读者在借书时,发现自己所需要借的书目无法借阅,进入预约界面,建立预约记录。五、状态图【状态图说明】 书籍在未变成图书馆在库书籍时,为新加书籍状态。书籍处于在库状态时既可以预订也可以外借,外借
15、后变为借出状态。处于预订状态时也可以外借,超出预订时间期限则从预订状态直接转为可用状11 / 15态。借阅者在规定的预订时间内也可以考虑取消预订,取消预订后书籍的状态转为可用。外借书籍归还后变为可用状态。六、六、活动图活动图描述的是某流程中的任务的执行,活动图描述活动是如何协同工作的,当一个操作必须完成一系列事情,而又无法确定以什么样的顺序来完成这些事情时,活动图可以更清晰地描述这些事情。 。在本图书馆管理系统中,我们主要描述了图书馆系统的借书、还书和预订的活动图。(1)借书活动图 【借书活动图说明】 12 / 15管理员首先要扫描读者的借书证,检验证件是否符合图书馆借书条件,若该读者的借书数
16、量还未达到最大规定数量,并且其所借书籍均未属于过期范围,则符合借书条件。则再扫描书籍条形码,检查书籍是否是不可借书籍或者已经被预订,若被预订,则取消预订,方可借书。在这些条件都符合时则更新书籍信息和读者的借阅信息,记录好借书的时间。(2)还书活动图 【还书活动图说明】 图书管理员对书籍进行扫描,若书籍已经过期,则要求读者还请欠款才能还书,读者缴应交罚款后,更新书目信息和读者信息。13 / 15(3)预订图书活动图【预订书籍活动图说明】读者先进入系统查询自己所需要的书籍,显示书籍信息,检验书籍是否属于可预订书籍,若符合条件则检查书籍是否已经被预订或已经被外借,若都未成立,则读者登录系统,并对该书
17、籍进行预订。14 / 15图书馆管理系统的类图【类图说明】 (1) reader 类是借阅者的类,它的属性很多,包括借阅者的账户 ID (reader_id ) 、姓名( reader_Name) 、地址(Address) 、班级(class) 、所借书籍的书目(borrowed)等。其中主要操作有借书(addborrowed)和还书(deleteborrowed)和预订 (reservation)等。 (2) admin 类是管理员类,他有编号和姓名属性,操作主要是书籍的增删改和 读者的增删改等等。 (3) Title 类是记录书目信息的类,包括书籍的名字(name ) 、作者(author) 、 book_id 等属性。(4) Item 类是具体某本书的类,属性包括书籍号(id) 。操作包括预订 (reserve) 、按书目查找(find_on_title)等。 (5) borrow 类是某本书的借阅信息类,包括所借阅书籍的15 / 15ISBN、借阅的时间(date)等。 (6) Reservation 类是预订信息类,每个预订信息包括预订日期(date) 、所预订书籍的 ISBN、预订书籍的用户 ID(UserID)等属性。 (7) persistent store 类是书籍永久的存储类,在数据库中的存储数据,其他对与书籍有关的活动都要经过其存储类。 、