在国外做黄皮网站违法么,网站建设php培训,wordpress wowway,北京好的前端培训机构目 录 摘要 1 绪论 1.1研究目的与意义 1.2国内外研究现状 1.3ssm框架介绍 1.4论文结构与章节安排 2 牙科诊所管理系统系统分析 2.1 可行性分析 2.1.1 技术可行性分析 2.1.2 经济可行性分析 2.1.3 法律可行性分析 2.2 系统功能分析 2.2.1 功能性分析 2.2.2 非功能… 目 录 摘要 1 绪论 1.1研究目的与意义 1.2国内外研究现状 1.3ssm框架介绍 1.4论文结构与章节安排 2 牙科诊所管理系统系统分析 2.1 可行性分析 2.1.1 技术可行性分析 2.1.2 经济可行性分析 2.1.3 法律可行性分析 2.2 系统功能分析 2.2.1 功能性分析 2.2.2 非功能性分析 2.3 系统用例分析 2.4 系统流程分析 2.4.1 数据流程 2.4.2 业务流程 2.5本章小结 3 牙科诊所管理系统总体设计 3.1 系统功能模块设计 3.1.1整体功能模块设计 3.1.2用户模块设计 3.1.3 评论管理模块设计 3.1.4商城管理模块设计 3.1.5订单管理模块设计 3.2 数据库设计 3.2.1 数据库概念结构设计 3.3.2 数据库逻辑结构设计 3.4本章小结 4 牙科诊所管理系统详细设计与实现 4.1用户功能模块 4.1.1 前台首页界面 4.1.2 用户注册界面 4.1.3 用户登录界面 4.1.4药品详情界面 4.1.5收货地址界面 4.1.6我的订单界面 4.1.7牙科诊所界面 4.1.8挂号预约界面 4.1.9住院预约界面 4.2管理人员功能模块 4.2.1系统公告管理界面 4.2.2 系统用户管理界面 4.2.3资源管理界面 4.2.4 商城管理界面 4.2.5 模块管理界面 5系统测试 5.1 系统测试用例 5.2 系统测试结果 结论 参考文献 致 谢 摘要 信息化社会内需要与之针对性的信息获取途径但是途径的扩展基本上为人们所努力的方向由于站在的角度存在偏差人们经常能够获得不同类型信息这也是技术最为难以攻克的课题。针对牙科诊所管理系统等问题对如何通过计算机牙科诊所管理系统进行研究分析然后开发设计出牙科诊所管理系统已解决问题。 牙科诊所管理系统主要功能模块包括牙科诊所、挂号预约、检测信息、检测结果、住院预约、住院确认、住院费用、费用类型、满意度评价等信息维护采取面对对象的开发模式进行软件的开发和硬体的架设能很好的满足实际使用的需求完善了对应的软体架设以及程序编码的工作采取MySQL作为后台数据的主要存储单元采用java技术、Ajax技术进行业务系统的编码及其开发实现了本系统的全部功能。本次报告首先分析了研究的背景、作用、意义为研究工作的合理性打下了基础。针对牙科诊所管理系统的各项需求以及技术问题进行分析证明了系统的必要性和技术可行性然后对设计系统需要使用的技术软件以及设计思想做了基本的介绍最后来实现牙科诊所管理系统和部署运行使用它。 关键词ssm牙科诊所管理系统 MySQL Abstract In the information society, there is a need for targeted information acquisition channels, but the expansion of channels is basically the direction of peoples efforts. Due to the deviation in perspective, people often can obtain different types of information, which is also the most difficult topic for technology to overcome. Research and analyze how to use a computer dental clinic management system to address issues such as dental clinic management systems, and then develop and design a dental clinic management system to address these issues. The main functional modules of the dental clinic management system include dental clinics, registered appointments, testing information, testing results, hospitalization appointments, hospitalization confirmation, hospitalization expenses, expense types, satisfaction evaluation, and other information maintenance. The object-oriented development model is adopted for software development and hardware installation, which can effectively meet practical needs and improve the corresponding software installation and program coding work, Adopting MySQL as the main storage unit for backend data, and using Java and Ajax technologies for business system coding and development, all functions of this system have been achieved. This report first analyzes the background, role, and significance of the research, laying the foundation for the rationality of the research work. Analyze the various requirements and technical issues of the dental clinic management system, prove the necessity and feasibility of the system, and then provide a basic introduction to the technical software and design ideas required for designing the system. Finally, implement the dental clinic management system and deploy it for operation. Keywords:ssm Dental clinic management system; MySQL 1 绪论 1.1研究目的与意义 随着社会的发展人民生活水平的不断提高对牙齿健康越来越关注,牙科诊所的业务不断增长处理越来越复杂简单的人工经营管理已无法满足的需要成为诊所发展的瓶颈人们对牙科诊所管理系统的要求也越来越高。传统的手工操作模式病人帐目繁杂病人查帐困难病区和药房的药品浪费现象严重且无法追踪, 人工传送各种记帐单容易漏、错帐人工划价收费差错难以避免因此,如何提服务水平、提高工作效率成为迫待解决的问题。诊所管理信息化不仅能提高医务人员的工作效率和医疗水平而且能提高诊所的服务质量和管理水平,因此诊所对管理信息系统有着强烈的需求。利用电子计算机和通讯设备为诊所所属各部门提供病人诊疗信息和行政管理信息的收集、存储、处理、提取和数据医交换的能力并满足所有授权用户的功能需求。开发牙科诊所管理系统的目标就是立足诊所应用实际着眼院未来发展以强化诊所管理提高医疗质量方便患者就医和查询提高诊所的服务效率和服务质量设计一套符合国家功能规范要求安全稳定操作简便的诊所信息系统为诊所提供一套全方位的解决方案。 1.2国内外研究现状 目前国内外诊所信息管理采取的方式主要有一纯人工管理二利用一些建立在过时的系统底板上的系统进行管理。这两种方法目前看来有很大弊端前者由于管理人员文化程度不一可能在信息处理过程中出现记录丢失、信息传达有误等问题同时人工文件难以保存档案记录容易损坏或者丢失后者在一定程度上满足了信息处理和保存的问题但由于系统陈旧存在信息泄露的风险。在当今现代化社会任何诊所需要一个建立在新型系统上的管理系统以规范诊所本身的运营管理提高管理水平、工作效率实现利益的最大化。 目前国内外已出现多种诊所管理系统其技术类型也多种多样如基于ssm、Java系统所设计的管理软件但其主要应用于大型诊所的财务、医疗等关键部门小型诊所应用范围不广泛。针对国内外对诊所管理系统的需求一个合格的管理系统其软件功能要齐全完备操作简捷同时系统要具备一定的成长性、灵活性可不断完善提升自身的信息安全系数。 1.3ssm框架介绍 SSMSpringSpringMVCMyBatis框架集由Spring、MyBatis两个开源框架整合而成SpringMVC是Spring中的部分内容。常作为数据源较简单的web项目的框架。 Spring Spring就像是整个项目中装配bean的大工厂在配置文件中可以指定使用特定的参数去调用实体类的构造方法来实例化对象。也可以称之为项目中的粘合剂。 Spring的核心思想是IoC控制反转即不再需要程序员去显式地new一个对象而是让Spring框架帮你来完成这一切。 SpringMVC SpringMVC在项目中拦截用户请求它的核心Servlet即DispatcherServlet承担中介或是前台这样的职责将用户请求通过HandlerMapping去匹配ControllerController就是具体对应请求所执行的操作。SpringMVC相当于SSH框架中struts。 mybatis mybatis是对jdbc的封装它让数据库底层操作变的透明。mybatis的操作都是围绕一个sqlSessionFactory实例展开的。mybatis通过配置文件关联到各实体类的Mapper文件Mapper文件中配置了每个类对数据库所需进行的sql语句映射。在每次与数据库交互时通过sqlSessionFactory拿到一个sqlSession再执行sql命令。 页面发送请求给控制器控制器调用业务层处理逻辑逻辑层向持久层发送请求持久层与数据库交互后将结果返回给业务层业务层将处理逻辑发送给控制器控制器再调用视图展现数据。 1.4论文结构与章节安排 本文共分为六章章节内容安排如下 第一章为引言此章节对所设计和实现的系统的背景和状况以及意义进行详细的论述以及说明同时进行了论文整体框架的结构的简要介绍。 第二章为系统需求分析章节所做的主要的工作是对系统进行了技术、经济和操作方面可行性的分析对系统实行了总体功能的需求、用例分析。 第三章为系统的设计主要是对系统的功能结构进行设计并对系统数据库的概念结构以及物理结构的设计进行了分析。 第四章就是对系统的实现根据系统功能的划分分别的对系统所需要实现的前台客户功能和后台管理员功能进行了分析和说明。 第五章系统测试。主要对系统的部分界面进行测试并对主要功能进行测试 第六章总结。 2 牙科诊所管理系统系统分析 系统需求分析是系统开发的一个关键环节它在系统的设计和实现上起到了一个承上启下的位置。系统需求分析是对所需要做的系统进行一个需求的挖掘如果分析的准确可以精准的解决现实中碰到的问题。如果分析不到位会影响后期系统的实现。一个系统的优秀程度需求分析也是占据了非常大的比例如果需求分析不到位后面的系统设计要实现就是一个偏离导航的设计。 2.1 可行性分析 系统可行行分析是对系统对系统可行性进行一个探讨。在探讨系统的可行性上我们主要从技术上的可行性和经济上的可行性以及法律层面的可行性上进行分析如果三个层面度通过我们则认为系统是比较可行的。 2.1.1 技术可行性分析 牙科诊所管理系统存储所使用的是mysql数据库以及开发中所使用的是IDEA、Tomcat这些开发工具的使用能够给我们的编写工作带来许多的便利。系统使用ssm框架进行开发使系统的可扩展性和维护性更佳减少java配置代码简化编程代码目前ssm框架也是很多企业选择的框架之一。 2.1.2 经济可行性分析 从经济可行性上看项目在开发阶段需要一台开发PC在生产阶段需要web服务器和数据库服务器。一台个人PC从经济上来看也不是太多问题在后期的系统部署生产上来说服务器的投入也不会过高在经济层面上是一个比较可行的。 2.1.3 法律可行性分析 系统从法律层面上来没有对第三方有其他放有法律层面的问题系统数据库采用的Mysql 开源社区数据库、框架采用的是开源的ssm。系统资讯和相关内容也是呵呵法律层面的。在源码的管理上采用git开源进行管理所以在法律可行性上是成立的。 2.2 系统功能分析 2.2.1 功能性分析 牙科诊所管理系统我划分为了管理员模块、牙科医生模块以及系统用户模块这三大部分。 系统用户管理模块 1用户注册登录用户注册为系统用户并登录牙科诊所管理系统用户对个人信息的增删改查比如个人资料密码修改。 2用户查看药品用户进行药品信息的阅览通过发现喜欢的药品后可以加购购买评论收藏。 3系统公告用户点击“系统公告”菜单显示管理员在后台发布的所有的系统公告信息可以查看系统公告详情。 4护牙常识用户点击“护牙常识”菜单显示所有的护牙常识信息可以按照条件进行护牙常识的筛选或者输入关键词进行局部搜索点击可以进入护牙常识详细展示界面在此界面用户可以收藏、点赞和评论 5购物车用户对喜欢的药品可以加购在购物车里面可以查看到所有加购的商品支持对药品数量的更改、删除药品可以进行选择购买。 6我的订单用户在提交订单后可以对提交的订单进行管理。 7收货地址点击“我的”中“我的地址”按钮的时候就会显示出自己的收货地址信息支持对收货地址的增删改查操作。 8我的收藏点击“我的”中“我的收藏”按钮的时候就会显示出自己收藏的各种信息了支持对收藏信息的搜索查询如果你想不再收藏某一信息点击删除就可以了。 9牙科诊所当用户点击“牙科诊所”这一菜单按钮会显示管理员在后台发布的所有的牙科诊所支持通过关键词对牙科诊所进行搜索选择需要的牙科诊所点击可以进入到牙科诊所详细的介绍界面在详细界面可以查看到诊所的诊所医生、诊所名称、医生姓名、诊所电话、诊所地址、挂号费用、住院押金等信息同时可以进行预约挂号、住院预约、收藏操作 10预约挂号当用户在牙科诊所详情界面想要进行预约挂号点击下方的“预约挂号”按钮就会跳转到预约挂号信息填写界面根据界面提示输入预约挂号信息点击“提交”按钮预约挂号就完成了 11住院预约当用户在牙科诊所详情界面想要进行住院预约点击下方的“住院预约”按钮就会跳转到住院预约信息填写界面根据界面提示输入住院预约信息点击“提交”按钮住院预约就完成了 12我的账户在前台点击“我的”下面的“我的账户”可以对个人资料密码修改自己收藏的信息进行管控。 管理员管理模块 1登录管理员在后台可以输入用户名密码进行登录管理员的用户名和密码是在数据库中直接设定好的。 2轮播图管理员点击“轮播图”菜单可以对首页展示的轮播图进行增删改查。 3系统公告管理员点击“系统公告”菜单可以查看到系统中的所有系统公告信息对已经存在的系统公告管理员可以修改也可以添加新的系统公告或者删除系统公告。 4系统用户管理员点击“系统用户”菜单可以对系统中存在的用户进行管理包含了管理员用户、系统用户以及牙科医生。 5资源管理管理员点击“资源管理”菜单能够对其下子菜单护牙常识和常识的分类进行增删改查。 6模块管理在“模块管理”这一菜单下我们会看到牙科诊所、挂号预约、检测信息、检测结果、住院预约、住院确认、住院费用、费用类型、满意度评价管理员可以对其进行增删改查操作。 7商城管理综合管理所属牙科诊所管理系统中的所有的药品信息、药品分类以及用户提交的订单信息。 2.2.2 非功能性分析 牙科诊所管理系统的非功能性需求比如牙科诊所管理系统的安全性怎么样可靠性怎么样性能怎么样可拓展性怎么样等。具体可以表示在如下3-1表格中 表3-1牙科诊所管理系统非功能需求表 安全性 主要指牙科诊所管理系统数据库的安装数据库的使用和密码的设定必须合乎规范。 可靠性 可靠性是指牙科诊所管理系统能够按照用户提交的指示进行操作经过测试可靠性90%以上。 性能 性能是影响牙科诊所管理系统占据市场的必要条件所以性能最好要佳才好。 可扩展性 比如数据库预留多个属性比如接口的使用等确保了系统的非功能性需求。 易用性 用户只要跟着牙科诊所管理系统的页面展示内容进行操作就可以了。 可维护性 牙科诊所管理系统开发的可维护性是非常重要的经过测试可维护性没有问题 2.3 系统用例分析 牙科诊所管理系统的完整UML用例图分别是图2-1、图2-2。 图2-1就是系统用户角色的用例展示。 图2-1 牙科诊所管理系统系统用户角色用例图 图2-2就是管理员角色的用例展示。 图2-2 牙科诊所管理系统管理员角色用例图 2.4 系统流程分析 2.4.1 数据流程 开发牙科诊所管理系统最主要的一个目的目的就是实现对药品的在线选购图2-3就是系统的数据流图。 图2-3药品购买操作展开图 2.4.2 业务流程 分析完牙科诊所管理系统的数据流那么接下来我们来看系统的业务流程图2-4就是业务流程图 图2-4业务流程图 2.5本章小结 本章主要通过对牙科诊所管理系统的可行性分析、功能需求分析、系统用例分析、系统流程分析确定整个牙科诊所管理系统要实现的功能。同时也为牙科诊所管理系统的代码实现和测试提供了标准。 3 牙科诊所管理系统总体设计 本章主要讨论的内容包括牙科诊所管理系统的功能模块设计、数据库系统设计。 3.1 系统功能模块设计 3.1.1整体功能模块设计 在上一章节中主要对系统的功能性需求和非功能性需求进行分析并且根据需求分析了本牙科诊所管理系统中的用例。那么接下来就要开始对本牙科诊所管理系统的架构、主要功能和数据库开始进行设计。牙科诊所管理系统根据前面章节的需求分析得出其总体设计模块图如图3-1所示。 图3-1 牙科诊所管理系统功能模块图 3.1.2用户模块设计 本系统的用户包括管理员和用户两种用户模块的功能基本是相同的用户比管理员多了一个注册功能所以以用户模块的结构图为例进行分析用户模块结构图为例进行分析如下图 图3-2用户模块结构图 3.1.3 评论管理模块设计 牙科诊所管理系统是一个交流性质的公开平台用户在平台上提交评论增加用户之间的互动性。但是同时也为了更好的规范评论的内容给予管理员删除不合适的评论的功能所以需要专门设计一个评论管理模块具体的结构图如下 图3-3评论管理模块结构图 3.1.4商城管理模块设计 牙科诊所管理系统是中需要存储不少药品信息其模块功能结构具体的结构图如下 图3-4商城模块结构图 3.1.5订单管理模块设计 牙科诊所管理系统最重要的一个功能就是购买其模块功能结构具体的结构图如下 图3-5订单模块结构图 3.2 数据库设计 数据库设计一般包括需求分析、概念模型设计、数据库表建立三大过程其中需求分析前面章节已经阐述概念模型设计有概念模型和逻辑结构设计两部分。 3.2.1 数据库概念结构设计 下面是整个牙科诊所管理系统中主要的数据库表总E-R实体关系图。 图3-6 牙科诊所管理系统总E-R关系图 3.3.2 数据库逻辑结构设计 通过上一小节中牙科诊所管理系统中总E-R关系图上得出一共需要创建很多个数据表。在此我主要罗列几个主要的数据库表结构设计。 表address (收货地址) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 address_id int 10 0 N Y 收货地址 2 name varchar 32 0 Y N 姓名 3 phone varchar 13 0 Y N 手机 4 postcode varchar 8 0 Y N 邮编 5 address varchar 255 0 N N 地址 6 user_id mediumint 8 0 N N 用户ID[0,8388607]用户获取其他与用户相关的数据 7 create_time timestamp 19 0 N N CURRENT_TIMESTAMP 创建时间 8 update_time timestamp 19 0 N N CURRENT_TIMESTAMP 更新时间 9 default bit 1 0 N N 0 默认判断 表admission_confirmation (住院确认) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 admission_confirmation_id int 10 0 N Y 住院确认ID 2 admission_number varchar 64 0 N N 住院编号 3 clinic_doctor int 10 0 Y N 0 诊所医生 4 clinic_name varchar 64 0 Y N 诊所名称 5 doctors_name varchar 64 0 Y N 医生姓名 6 clinic_phone varchar 64 0 Y N 诊所电话 7 clinic_address varchar 64 0 Y N 诊所地址 8 system_users int 10 0 Y N 0 系统用户 9 user_name varchar 64 0 Y N 用户姓名 10 user_gender varchar 64 0 Y N 用户性别 11 date_of_hospitalization date 10 0 Y N 住院日期 12 medical_records varchar 255 0 Y N 病历档案 13 bed_number varchar 64 0 Y N 病床号 14 recommend int 10 0 N N 0 智能推荐 15 create_time datetime 19 0 N N CURRENT_TIMESTAMP 创建时间 16 update_time timestamp 19 0 N N CURRENT_TIMESTAMP 更新时间 表article (文章用于内容管理系统的文章) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 article_id mediumint 8 0 N Y 文章id[0,8388607] 2 title varchar 125 0 N Y 标题[0,125]用于文章和html的title标签中 3 type varchar 64 0 N N 0 文章分类[0,1000]用来搜索指定类型的文章 4 hits int 10 0 N N 0 点击数[0,1000000000]访问这篇文章的人次 5 praise_len int 10 0 N N 0 点赞数 6 create_time timestamp 19 0 N N CURRENT_TIMESTAMP 创建时间 7 update_time timestamp 19 0 N N CURRENT_TIMESTAMP 更新时间 8 source varchar 255 0 Y N 来源[0,255]文章的出处 9 url varchar 255 0 Y N 来源地址[0,255]用于跳转到发布该文章的网站 10 tag varchar 255 0 Y N 标签[0,255]用于标注文章所属相关内容多个标签用空格隔开 11 content longtext 2147483647 0 Y N 正文文章的主体内容 12 img varchar 255 0 Y N 封面图 13 description text 65535 0 Y N 文章描述 表article_type (文章分类) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 type_id smallint 5 0 N Y 分类ID[0,10000] 2 display smallint 5 0 N N 100 显示顺序[0,1000]决定分类显示的先后顺序 3 name varchar 16 0 N N 分类名称[2,16] 4 father_id smallint 5 0 N N 0 上级分类ID[0,32767] 5 description varchar 255 0 Y N 描述[0,255]描述该分类的作用 6 icon text 65535 0 Y N 分类图标 7 url varchar 255 0 Y N 外链地址[0,255]如果该分类是跳转到其他网站的情况下就在该URL上设置 8 create_time timestamp 19 0 N N CURRENT_TIMESTAMP 创建时间 9 update_time timestamp 19 0 N N CURRENT_TIMESTAMP 更新时间 表auth (用户权限管理) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 auth_id int 10 0 N Y 授权ID 2 user_group varchar 64 0 Y N 用户组 3 mod_name varchar 64 0 Y N 模块名 4 table_name varchar 64 0 Y N 表名 5 page_title varchar 255 0 Y N 页面标题 6 path varchar 255 0 Y N 路由路径 7 position varchar 32 0 Y N 位置 8 mode varchar 32 0 N N _blank 跳转方式 9 add tinyint 3 0 N N 1 是否可增加 10 del tinyint 3 0 N N 1 是否可删除 11 set tinyint 3 0 N N 1 是否可修改 12 get tinyint 3 0 N N 1 是否可查看 13 field_add text 65535 0 Y N 添加字段 14 field_set text 65535 0 Y N 修改字段 15 field_get text 65535 0 Y N 查询字段 16 table_nav_name varchar 500 0 Y N 跨表导航名称 17 table_nav varchar 500 0 Y N 跨表导航 18 option text 65535 0 Y N 配置 19 create_time timestamp 19 0 N N CURRENT_TIMESTAMP 创建时间 20 update_time timestamp 19 0 N N CURRENT_TIMESTAMP 更新时间 表cart (购物车) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 cart_id int 10 0 N Y 购物车ID 2 title varchar 64 0 Y N 标题 3 img varchar 255 0 N N 0 图片 4 user_id int 10 0 N N 0 用户ID 5 create_time timestamp 19 0 N N CURRENT_TIMESTAMP 创建时间 6 update_time timestamp 19 0 N N CURRENT_TIMESTAMP 更新时间 7 state int 10 0 N N 0 状态使用中已失效 8 price double 9 2 N N 0.00 单价 9 price_ago double 9 2 N N 0.00 原价 10 price_count double 11 2 N N 0.00 总价 11 num int 10 0 N N 1 数量 12 goods_id mediumint 8 0 N N 商品id[0,8388607] 13 type varchar 64 0 N N 未分类 商品分类 14 description varchar 255 0 Y N 描述[0,255]用于产品规格描述 表collect (收藏) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 collect_id int 10 0 N Y 收藏ID 2 user_id int 10 0 N N 0 收藏人ID 3 source_table varchar 255 0 Y N 来源表 4 source_field varchar 255 0 Y N 来源字段 5 source_id int 10 0 N N 0 来源ID 6 title varchar 255 0 Y N 标题 7 img varchar 255 0 Y N 封面 8 create_time timestamp 19 0 N N CURRENT_TIMESTAMP 创建时间 9 update_time timestamp 19 0 N N CURRENT_TIMESTAMP 更新时间 表comment (评论) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 comment_id int 10 0 N Y 评论ID 2 user_id int 10 0 N N 0 评论人ID 3 reply_to_id int 10 0 N N 0 回复评论ID空为0 4 content longtext 2147483647 0 Y N 内容 5 nickname varchar 255 0 Y N 昵称 6 avatar varchar 255 0 Y N 头像地址[0,255] 7 create_time timestamp 19 0 N N CURRENT_TIMESTAMP 创建时间 8 update_time timestamp 19 0 N N CURRENT_TIMESTAMP 更新时间 9 source_table varchar 255 0 Y N 来源表 10 source_field varchar 255 0 Y N 来源字段 11 source_id int 10 0 N N 0 来源ID 表dental_clinic (牙科诊所) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 dental_clinic_id int 10 0 N Y 牙科诊所ID 2 clinic_doctor int 10 0 Y N 0 诊所医生 3 clinic_name varchar 64 0 N N 诊所名称 4 doctors_name varchar 64 0 Y N 医生姓名 5 clinic_phone varchar 64 0 Y N 诊所电话 6 clinic_address varchar 64 0 Y N 诊所地址 7 clinic_cover varchar 255 0 Y N 诊所封面 8 registration_fee int 10 0 Y N 0 挂号费用 9 hospitalization_deposit int 10 0 Y N 0 住院押金 10 introduction_to_expertise text 65535 0 Y N 专长介绍 11 clinic_introduction longtext 2147483647 0 Y N 诊所介绍 12 recommend int 10 0 N N 0 智能推荐 13 create_time datetime 19 0 N N CURRENT_TIMESTAMP 创建时间 14 update_time timestamp 19 0 N N CURRENT_TIMESTAMP 更新时间 表dentist (牙科医生) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 dentist_id int 10 0 N Y 牙科医生ID 2 doctors_name varchar 64 0 Y N 医生姓名 3 clinic_name varchar 64 0 N N 诊所名称 4 clinic_address varchar 64 0 Y N 诊所地址 5 clinic_phone varchar 64 0 Y N 诊所电话 6 qualification_screenshot varchar 255 0 Y N 资格截图 7 examine_state varchar 16 0 N N 未审核 审核状态 8 recommend int 10 0 N N 0 智能推荐 9 user_id int 10 0 N N 0 用户ID 10 create_time datetime 19 0 N N CURRENT_TIMESTAMP 创建时间 11 update_time timestamp 19 0 N N CURRENT_TIMESTAMP 更新时间 表detection_information (检测信息) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 detection_information_id int 10 0 N Y 检测信息ID 2 test_number varchar 64 0 Y N 检测编号 3 clinic_doctor int 10 0 Y N 0 诊所医生 4 clinic_name varchar 64 0 Y N 诊所名称 5 doctors_name varchar 64 0 Y N 医生姓名 6 clinic_phone varchar 64 0 Y N 诊所电话 7 clinic_address varchar 64 0 Y N 诊所地址 8 system_users int 10 0 Y N 0 系统用户 9 user_name varchar 64 0 Y N 用户姓名 10 user_gender varchar 64 0 Y N 用户性别 11 test_date date 10 0 Y N 检测日期 12 testing_fee int 10 0 Y N 0 检测费 13 detection_content text 65535 0 Y N 检测内容 14 pay_state varchar 16 0 N N 未支付 支付状态 15 pay_type varchar 16 0 Y N 支付类型: 微信、支付宝、网银 16 recommend int 10 0 N N 0 智能推荐 17 create_time datetime 19 0 N N CURRENT_TIMESTAMP 创建时间 18 update_time timestamp 19 0 N N CURRENT_TIMESTAMP 更新时间 表detection_result (检测结果) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 detection_result_id int 10 0 N Y 检测结果ID 2 test_number varchar 64 0 N N 检测编号 3 clinic_doctor int 10 0 Y N 0 诊所医生 4 clinic_name varchar 64 0 Y N 诊所名称 5 doctors_name varchar 64 0 Y N 医生姓名 6 clinic_phone varchar 64 0 Y N 诊所电话 7 clinic_address varchar 64 0 Y N 诊所地址 8 system_users int 10 0 Y N 0 系统用户 9 user_name varchar 64 0 Y N 用户姓名 10 user_gender varchar 64 0 Y N 用户性别 11 test_date date 10 0 Y N 检测日期 12 testing_fee int 10 0 Y N 0 检测费 13 result_file varchar 255 0 Y N 结果文件 14 diagnostic_results text 65535 0 Y N 诊断结果 15 recommend int 10 0 N N 0 智能推荐 16 create_time datetime 19 0 N N CURRENT_TIMESTAMP 创建时间 17 update_time timestamp 19 0 N N CURRENT_TIMESTAMP 更新时间 表drug_information (药品信息) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 drug_information_id int 10 0 N Y 药品信息ID 2 drug_dosage_form varchar 64 0 Y N 药品剂型 3 drug_specifications varchar 64 0 Y N 药品规格 4 date_of_manufacture date 10 0 Y N 生产日期 5 drug_batch varchar 64 0 Y N 药品批次 6 production_address varchar 64 0 Y N 生产地址 7 recommend int 10 0 N N 0 智能推荐 8 cart_title varchar 125 0 Y N 标题[0,125]用于产品html的标签中 9 cart_img text 65535 0 Y N 封面图用于显示于产品列表页 10 cart_description varchar 255 0 Y N 描述[0,255]用于产品规格描述 11 cart_price_ago double 8 2 N N 0.00 原价[1] 12 cart_price double 8 2 N N 0.00 卖价[1] 13 cart_inventory int 10 0 N N 0 商品库存 14 cart_type varchar 64 0 N N 未分类 商品分类 15 cart_content longtext 2147483647 0 Y N 正文产品的主体内容 16 cart_img_1 text 65535 0 Y N 主图1 17 cart_img_2 text 65535 0 Y N 主图2 18 cart_img_3 text 65535 0 Y N 主图3 19 cart_img_4 text 65535 0 Y N 主图4 20 cart_img_5 text 65535 0 Y N 主图5 21 create_time datetime 19 0 N N CURRENT_TIMESTAMP 创建时间 22 update_time timestamp 19 0 N N CURRENT_TIMESTAMP 更新时间 表expense_type (费用类型) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 expense_type_id int 10 0 N Y 费用类型ID 2 expense_type varchar 64 0 Y N 费用类型 3 recommend int 10 0 N N 0 智能推荐 4 create_time datetime 19 0 N N CURRENT_TIMESTAMP 创建时间 5 update_time timestamp 19 0 N N CURRENT_TIMESTAMP 更新时间 表goods (商品信息) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 goods_id mediumint 8 0 N Y 产品id[0,8388607] 2 title varchar 125 0 Y N 标题[0,125]用于产品和html的title标签中 3 img text 65535 0 Y N 封面图用于显示于产品列表页 4 description varchar 255 0 Y N 描述[0,255]用于产品规格描述 5 price_ago double 8 2 N N 0.00 原价[1] 6 price double 8 2 N N 0.00 卖价[1] 7 sales int 10 0 N N 0 销量[0,1000000000] 8 inventory int 10 0 N N 0 商品库存 9 type varchar 64 0 N N 商品分类 10 hits int 10 0 N N 0 点击量[0,1000000000]访问这篇产品的人次 11 content longtext 2147483647 0 Y N 正文产品的主体内容 12 img_1 text 65535 0 Y N 主图1 13 img_2 text 65535 0 Y N 主图2 14 img_3 text 65535 0 Y N 主图3 15 img_4 text 65535 0 Y N 主图4 16 img_5 text 65535 0 Y N 主图5 17 create_time timestamp 19 0 N N CURRENT_TIMESTAMP 创建时间 18 update_time timestamp 19 0 N N CURRENT_TIMESTAMP 更新时间 19 customize_field text 65535 0 Y N 自定义字段 20 source_table varchar 255 0 Y N 来源表 21 source_field varchar 255 0 Y N 来源字段 22 source_id int 10 0 N N 0 来源ID 23 user_id int 10 0 Y N 0 添加人 表goods_type (商品类型) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 type_id int 10 0 N Y 商品分类ID 2 father_id smallint 5 0 N N 0 上级分类ID[0,32767] 3 name varchar 255 0 Y N 商品名称 4 desc varchar 255 0 Y N 描述 5 icon varchar 255 0 Y N 图标 6 source_table varchar 255 0 Y N 来源表 7 source_field varchar 255 0 Y N 来源字段 8 create_time timestamp 19 0 N N CURRENT_TIMESTAMP 创建时间 9 update_time timestamp 19 0 N N CURRENT_TIMESTAMP 更新时间 表hits (用户点击) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 hits_id int 10 0 N Y 点赞ID 2 user_id int 10 0 N N 0 点赞人 3 create_time timestamp 19 0 N N CURRENT_TIMESTAMP 创建时间 4 update_time timestamp 19 0 N N CURRENT_TIMESTAMP 更新时间 5 source_table varchar 255 0 Y N 来源表 6 source_field varchar 255 0 Y N 来源字段 7 source_id int 10 0 N N 0 来源ID 表hospitalization_appointment (住院预约) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 hospitalization_appointment_id int 10 0 N Y 住院预约ID 2 admission_number varchar 64 0 Y N 住院编号 3 clinic_doctor int 10 0 Y N 0 诊所医生 4 clinic_name varchar 64 0 Y N 诊所名称 5 doctors_name varchar 64 0 Y N 医生姓名 6 clinic_phone varchar 64 0 Y N 诊所电话 7 clinic_address varchar 64 0 Y N 诊所地址 8 hospitalization_deposit int 10 0 Y N 0 住院押金 9 appointment_date date 10 0 Y N 预约日期 10 system_users int 10 0 Y N 0 系统用户 11 user_name varchar 64 0 Y N 用户姓名 12 user_gender varchar 64 0 Y N 用户性别 13 health_qr_code varchar 255 0 Y N 健康二维码 14 medical_records varchar 255 0 Y N 病历档案 15 description_of_the_condition text 65535 0 Y N 病情描述 16 examine_state varchar 16 0 N N 未审核 审核状态 17 examine_reply varchar 16 0 Y N 审核回复 18 pay_state varchar 16 0 N N 未支付 支付状态 19 pay_type varchar 16 0 Y N 支付类型: 微信、支付宝、网银 20 recommend int 10 0 N N 0 智能推荐 21 create_time datetime 19 0 N N CURRENT_TIMESTAMP 创建时间 22 update_time timestamp 19 0 N N CURRENT_TIMESTAMP 更新时间 表hospitalization_expenses (住院费用) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 hospitalization_expenses_id int 10 0 N Y 住院费用ID 2 admission_number varchar 64 0 Y N 住院编号 3 clinic_doctor int 10 0 Y N 0 诊所医生 4 clinic_name varchar 64 0 Y N 诊所名称 5 doctors_name varchar 64 0 Y N 医生姓名 6 clinic_phone varchar 64 0 Y N 诊所电话 7 clinic_address varchar 64 0 Y N 诊所地址 8 system_users int 10 0 Y N 0 系统用户 9 user_name varchar 64 0 Y N 用户姓名 10 user_gender varchar 64 0 Y N 用户性别 11 bed_number varchar 64 0 Y N 病床号 12 expense_type varchar 64 0 Y N 费用类型 13 charging_date date 10 0 Y N 收费日期 14 fee_amount varchar 64 0 Y N 费用金额 15 enclosure varchar 255 0 Y N 附件 16 charge_remarks varchar 64 0 Y N 收费备注 17 pay_state varchar 16 0 N N 未支付 支付状态 18 pay_type varchar 16 0 Y N 支付类型: 微信、支付宝、网银 19 recommend int 10 0 N N 0 智能推荐 20 create_time datetime 19 0 N N CURRENT_TIMESTAMP 创建时间 21 update_time timestamp 19 0 N N CURRENT_TIMESTAMP 更新时间 表notice (公告) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 notice_id mediumint 8 0 N Y 公告id 2 title varchar 125 0 N N 标题 3 content longtext 2147483647 0 Y N 正文 4 create_time timestamp 19 0 N N CURRENT_TIMESTAMP 创建时间 5 update_time timestamp 19 0 N N CURRENT_TIMESTAMP 更新时间 表order (订单) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 order_id int 10 0 N Y 订单ID 2 order_number varchar 64 0 Y N 订单号 3 goods_id mediumint 8 0 N N 商品id[0,8388607] 4 title varchar 32 0 Y N 商品标题 5 img varchar 255 0 Y N 商品图片 6 price double 10 2 N N 0.00 价格 7 price_ago double 10 2 N N 0.00 原价 8 num int 10 0 N N 1 数量 9 price_count double 8 2 N N 0.00 总价 10 norms varchar 255 0 Y N 规格 11 type varchar 64 0 N N 未分类 商品分类 12 contact_name varchar 32 0 Y N 联系人姓名 13 contact_email varchar 125 0 Y N 联系人邮箱 14 contact_phone varchar 11 0 Y N 联系人手机 15 contact_address varchar 255 0 Y N 收件地址 16 postal_code varchar 9 0 Y N 邮政编码 17 user_id int 10 0 N N 0 买家ID 18 merchant_id mediumint 8 0 N N 0 商家ID 19 create_time timestamp 19 0 N N CURRENT_TIMESTAMP 创建时间 20 update_time timestamp 19 0 N N CURRENT_TIMESTAMP 更新时间 21 description varchar 255 0 Y N 描述[0,255]用于产品规格描述 22 state varchar 16 0 N N 待付款 订单状态待付款待发货待签收已签收待退款已退款已拒绝已完成 表praise (点赞) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 praise_id int 10 0 N Y 点赞ID 2 user_id int 10 0 N N 0 点赞人 3 create_time timestamp 19 0 N N CURRENT_TIMESTAMP 创建时间 4 update_time timestamp 19 0 N N CURRENT_TIMESTAMP 更新时间 5 source_table varchar 255 0 Y N 来源表 6 source_field varchar 255 0 Y N 来源字段 7 source_id int 10 0 N N 0 来源ID 8 status bit 1 0 N N 1 点赞状态:1为点赞0已取消 表registration_appointment (挂号预约) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 registration_appointment_id int 10 0 N Y 挂号预约ID 2 appointment_number varchar 64 0 Y N 预约号 3 clinic_doctor int 10 0 Y N 0 诊所医生 4 clinic_name varchar 64 0 Y N 诊所名称 5 doctors_name varchar 64 0 Y N 医生姓名 6 clinic_phone varchar 64 0 Y N 诊所电话 7 clinic_address varchar 64 0 Y N 诊所地址 8 registration_fee int 10 0 Y N 0 挂号费用 9 appointment_date date 10 0 Y N 预约日期 10 system_users int 10 0 Y N 0 系统用户 11 user_name varchar 64 0 Y N 用户姓名 12 user_gender varchar 64 0 Y N 用户性别 13 health_qr_code varchar 255 0 Y N 健康二维码 14 appointment_content text 65535 0 Y N 预约内容 15 pay_state varchar 16 0 N N 未支付 支付状态 16 pay_type varchar 16 0 Y N 支付类型: 微信、支付宝、网银 17 recommend int 10 0 N N 0 智能推荐 18 create_time datetime 19 0 N N CURRENT_TIMESTAMP 创建时间 19 update_time timestamp 19 0 N N CURRENT_TIMESTAMP 更新时间 表satisfaction_evaluation (满意度评价) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 satisfaction_evaluation_id int 10 0 N Y 满意度评价ID 2 system_users int 10 0 Y N 0 系统用户 3 user_name varchar 64 0 Y N 用户姓名 4 evaluation_date date 10 0 Y N 评价日期 5 evaluation_aspect varchar 64 0 Y N 评价方面 6 evaluation_content text 65535 0 Y N 评价内容 7 examine_state varchar 16 0 N N 未审核 审核状态 8 examine_reply varchar 16 0 Y N 审核回复 9 recommend int 10 0 N N 0 智能推荐 10 create_time datetime 19 0 N N CURRENT_TIMESTAMP 创建时间 11 update_time timestamp 19 0 N N CURRENT_TIMESTAMP 更新时间 表slides (轮播图) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 slides_id int 10 0 N Y 轮播图ID 2 title varchar 64 0 Y N 标题 3 content varchar 255 0 Y N 内容 4 url varchar 255 0 Y N 链接 5 img varchar 255 0 Y N 轮播图 6 hits int 10 0 N N 0 点击量 7 create_time timestamp 19 0 N N CURRENT_TIMESTAMP 创建时间 8 update_time timestamp 19 0 N N CURRENT_TIMESTAMP 更新时间 表system_users (系统用户) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 system_users_id int 10 0 N Y 系统用户ID 2 user_name varchar 64 0 Y N 用户姓名 3 user_gender varchar 64 0 Y N 用户性别 4 user_age varchar 64 0 Y N 用户年龄 5 health_qr_code varchar 255 0 Y N 健康二维码 6 examine_state varchar 16 0 N N 已通过 审核状态 7 recommend int 10 0 N N 0 智能推荐 8 user_id int 10 0 N N 0 用户ID 9 create_time datetime 19 0 N N CURRENT_TIMESTAMP 创建时间 10 update_time timestamp 19 0 N N CURRENT_TIMESTAMP 更新时间 表upload (文件上传) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 upload_id int 10 0 N Y 上传ID 2 name varchar 64 0 Y N 文件名 3 path varchar 255 0 Y N 访问路径 4 file varchar 255 0 Y N 文件路径 5 display varchar 255 0 Y N 显示顺序 6 father_id int 10 0 Y N 0 父级ID 7 dir varchar 255 0 Y N 文件夹 8 type varchar 32 0 Y N 文件类型 表user (用户账户用于保存用户登录信息) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 user_id mediumint 8 0 N Y 用户ID[0,8388607]用户获取其他与用户相关的数据 2 state smallint 5 0 N N 1 账户状态[0,10](1可用|2异常|3已冻结|4已注销) 3 user_group varchar 32 0 Y N 所在用户组[0,32767]决定用户身份和权限 4 login_time timestamp 19 0 N N CURRENT_TIMESTAMP 上次登录时间 5 phone varchar 11 0 Y N 手机号码[0,11]用户的手机号码用于找回密码时或登录时 6 phone_state smallint 5 0 N N 0 手机认证[0,1](0未认证|1审核中|2已认证) 7 username varchar 16 0 N N 用户名[0,16]用户登录时所用的账户名称 8 nickname varchar 16 0 Y N 昵称[0,16] 9 password varchar 64 0 N N 密码[0,32]用户登录所需的密码由6-16位数字或英文组成 10 email varchar 64 0 Y N 邮箱[0,64]用户的邮箱用于找回密码时或登录时 11 email_state smallint 5 0 N N 0 邮箱认证[0,1](0未认证|1审核中|2已认证) 12 avatar varchar 255 0 Y N 头像地址[0,255] 13 create_time timestamp 19 0 N N CURRENT_TIMESTAMP 创建时间 表user_group (用户组用于用户前端身份和鉴权) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 group_id mediumint 8 0 N Y 用户组ID[0,8388607] 2 display smallint 5 0 N N 100 显示顺序[0,1000] 3 name varchar 16 0 N N 名称[0,16] 4 description varchar 255 0 Y N 描述[0,255]描述该用户组的特点或权限范围 5 source_table varchar 255 0 Y N 来源表 6 source_field varchar 255 0 Y N 来源字段 7 source_id int 10 0 N N 0 来源ID 8 register smallint 5 0 Y N 0 注册位置: 9 create_time timestamp 19 0 N N CURRENT_TIMESTAMP 创建时间 10 update_time timestamp 19 0 N N CURRENT_TIMESTAMP 更新时间 3.4本章小结 整个牙科诊所管理系统的需求分析主要对系统总体架构以及功能模块的设计通过建立E-R模型和数据库逻辑系统设计完成了数据库系统设计。 4 牙科诊所管理系统详细设计与实现 牙科诊所管理系统的详细设计与实现主要是根据前面的牙科诊所管理系统的需求分析和牙科诊所管理系统的总体设计来设计页面并实现业务逻辑。主要从牙科诊所管理系统界面实现、业务逻辑实现这两部分进行介绍。 4.1用户功能模块 4.1.1 前台首页界面 当进入牙科诊所管理系统的时候系统以上中下的布局进行展示首先映入眼帘的是系统的导航栏下面是轮播图再往下是公告其主界面展示如下图4-1所示。 图4-1 前台首页界面图 4.1.2 用户注册界面 牙科诊所管理系统的用户时可以进行注册登录当用户右上角“注册”按钮的时候当填写上自己的账号密码确认密码昵称邮箱手机号等后再点击“注册”按钮后将会先验证输入的有没有空数据再次验证密码和确认密码是否是一样的最后验证输入的账户名和数据库表中已经注册的账户名是否重复只有都验证没问题后即可用户注册成功。其用用户注册界面展示如下图4-2所示。 图4-2注册界面图 注册关键代码如下所示。 /** * 注册 * return */ PostMapping(register) public MapString, Object signUp(HttpServletRequest request) throws IOException { // 查询用户 MapString, String query new HashMap(); MapString,Object map service.readBody(request.getReader()); query.put(username,String.valueOf(map.get(username))); List list service.selectBaseList(service.select(query, new HashMap())); if (list.size()0){ return error(30000, 用户已存在); } map.put(password,service.encryption(String.valueOf(map.get(password)))); service.insert(map); return success(1); } public MapString,Object readBody(BufferedReader reader){ BufferedReader br null; StringBuilder sb new StringBuilder(); try{ br reader; String str; while ((str br.readLine()) ! null){ sb.append(str); } br.close(); String json sb.toString(); return JSONObject.parseObject(json, Map.class); }catch (IOException e){ e.printStackTrace(); }finally{ if (null ! br){ try{ br.close(); }catch (IOException e){ e.printStackTrace(); } } } return null; } public void insert(MapString,Object body){ E entity JSON.parseObject(JSON.toJSONString(body),eClass); baseMapper.insert(entity); log.info([{}] - 插入操作{},entity); } 4.1.3 用户登录界面 牙科诊所管理系统中的前台上注册后的用户是可以通过自己的账户名和密码进行登录的当用户输入完整的自己的账户名和密码信息并点击“登录”按钮后将会首先验证输入的有没有空数据再次验证输入的账户名密码和数据库中当前保存的用户信息是否一致只有在一致后将会登录成功并自动跳转到牙科诊所管理系统的首页中否则将会提示相应错误信息用户登录界面如下图4-3所示。 图4-3用户登录界面图 登录关键代码如下所示。 /** * 登录 * param data * param httpServletRequest * return */ PostMapping(login) public MapString, Object login(RequestBody MapString, String data, HttpServletRequest httpServletRequest) { log.info([执行登录接口]); String username data.get(username); String email data.get(email); String phone data.get(phone); String password data.get(password); List resultList null; QueryWrapper wrapper new QueryWrapperUser(); MapString, String map new HashMap(); if(username ! null .equals(username) false){ map.put(username, username); resultList service.selectBaseList(service.select(map, new HashMap())); } else if(email ! null .equals(email) false){ map.put(email, email); resultList service.selectBaseList(service.select(map, new HashMap())); } else if(phone ! null .equals(phone) false){ map.put(phone, phone); resultList service.selectBaseList(service.select(map, new HashMap())); }else{ return error(30000, 账号或密码不能为空); } if (resultList null || password null) { return error(30000, 账号或密码不能为空); } //判断是否有这个用户 if (resultList.size()0){ return error(30000,用户不存在); } User byUsername (User) resultList.get(0); MapString, String groupMap new HashMap(); groupMap.put(name,byUsername.getUserGroup()); List groupList userGroupService.selectBaseList(userGroupService.select(groupMap, new HashMap())); if (groupList.size()1){ return error(30000,用户组不存在); } UserGroup userGroup (UserGroup) groupList.get(0); //查询用户审核状态 if (!StringUtils.isEmpty(userGroup.getSourceTable())){ String res service.selectExamineState(userGroup.getSourceTable(),byUsername.getUserId()); if (resnull){ return error(30000,用户不存在); } if (!res.equals(已通过)){ return error(30000,该用户审核未通过); } } //查询用户状态 if (byUsername.getState()!1){ return error(30000,用户非可用状态不能登录); } String md5password service.encryption(password); if (byUsername.getPassword().equals(md5password)) { // 存储Token到数据库 AccessToken accessToken new AccessToken(); accessToken.setToken(UUID.randomUUID().toString().replaceAll(-, )); accessToken.setUser_id(byUsername.getUserId()); tokenService.save(accessToken); // 返回用户信息 JSONObject user JSONObject.parseObject(JSONObject.toJSONString(byUsername)); user.put(token, accessToken.getToken()); JSONObject ret new JSONObject(); ret.put(obj,user); return success(ret); } else { return error(30000, 账号或密码不正确); } } public String select(MapString,String query,MapString,String config){ StringBuffer sql new StringBuffer(select ); sql.append(config.get(FindConfig.FIELD) null || .equals(config.get(FindConfig.FIELD)) ? * : config.get(FindConfig.FIELD)).append( ); sql.append(from ).append().append(table).append().append(toWhereSql(query, 0.equals(config.get(FindConfig.LIKE)))); if (config.get(FindConfig.GROUP_BY) ! null !.equals(config.get(FindConfig.GROUP_BY))){ sql.append(group by ).append(config.get(FindConfig.GROUP_BY)).append( ); } if (config.get(FindConfig.ORDER_BY) ! null !.equals(config.get(FindConfig.ORDER_BY))){ sql.append(order by ).append(config.get(FindConfig.ORDER_BY)).append( ); } if (config.get(FindConfig.PAGE) ! null !.equals(config.get(FindConfig.PAGE))){ int page config.get(FindConfig.PAGE) ! null !.equals(config.get(FindConfig.PAGE)) ? Integer.parseInt(config.get(FindConfig.PAGE)) : 1; int limit config.get(FindConfig.SIZE) ! null !.equals(config.get(FindConfig.SIZE)) ? Integer.parseInt(config.get(FindConfig.SIZE)) : 10; sql.append( limit ).append( (page-1)*limit ).append( , ).append(limit); } log.info([{}] - 查询操作sql: {},table,sql); return sql.toString(); } public List selectBaseList(String select) { ListMapString,Object mapList baseMapper.selectBaseList(select); ListE list new ArrayList(); for (MapString,Object map:mapList) { list.add(JSON.parseObject(JSON.toJSONString(map),eClass)); } return list; } 4.1.4药品详情界面 当访客点击了任意药品后将会进入该款药品的详情界面可以了解到该药品的图片信息、药品信息、价钱信息等同时可以对该药品进行加购立即购买收藏点赞评论药品详情展示页面如图4-5所示。 图4-4 药品详情界面图 4.1.5收货地址界面 当用户点击“收货地址”右后就回去显示出目前现有的地址也可以添加新的地址界面如下图4-5所示。 图4-5收货地址界面图 4.1.6我的订单界面 当用户点击“我的订单”链接后就进入自己购买的订单的界面展示界面如下图4-6所示。 图4-6 我的订单界面图 4.1.7牙科诊所界面 当用户点击“牙科诊所”这一菜单按钮会显示管理员在后台发布的所有的牙科诊所信息支持通过关键词对牙科诊所进行搜索选择需要的牙科诊所点击可以进入到牙科诊所详细的介绍界面在详细界面可以查看到诊所的诊所医生、诊所名称、医生姓名、诊所电话、诊所地址、挂号费用、住院押金等信息同时可以进行预约挂号、住院预约、收藏操作牙科诊所界面如下图4-7所示。 图4-7牙科诊所界面图 4.1.8预约挂号界面 当用户在牙科诊所详情界面想要进行预约挂号点击下方的“预约挂号”按钮就会跳转到预约挂号信息填写界面根据界面提示输入预约挂号信息点击“提交”按钮预约挂号就完成了预约挂号界面如下图4-8所示。 图4-8预约挂号界面图 4.1.9住院预约界面 当用户在牙科诊所详情界面想要进行住院预约点击下方的“住院预约”按钮就会跳转到住院预约信息填写界面根据界面提示输入住院预约信息点击“提交”按钮住院预约就完成了住院预约界面如下图4-9所示。 图4-9住院预约界面图 4.2管理人员功能模块 4.2.1系统公告管理界面 管理员点击“系统公告管理”菜单可以查看到系统中的所有系统公告信息对已经存在的系统公告管理员可以修改也可以添加新的系统公告或者删除系统公告。界面如下图4-10所示。 图4-10系统公告管理界面图 系统公告管理代码如下。 public List selectBaseList(String select) { ListMapString,Object mapList baseMapper.selectBaseList(select); ListE list new ArrayList(); for (MapString,Object map:mapList) { list.add(JSON.parseObject(JSON.toJSONString(map),eClass)); } return list; } 4.2.2 系统用户管理界面 管理员点击“系统用户”这一菜单会显示管理员、牙科医生和系统用户这三个子菜单管理员可以对这三个角色的信息进行增删改查操作。界面如下图4-11所示。 图4-11系统用户管理界面图 4.2.3资源管理界面 管理员点击“资源管理”菜单能够对其下子菜单护牙常识和常识的分类进行增删改查。界面如下图4-12所示。 图4-12资源管理界面图 4.2.4 商城管理界面 牙科诊所管理系统中的管理人员是可以对牙科诊所管理系统内的用户发布的药品商城进行维护和管理的支持增删改查操作。界面如下图4-13所示。 图4-13商城管理界面图 商城管理关键代码如下所示。 RequestMapping(/get_obj) public MapString, Object obj(HttpServletRequest request) { List resultList service.selectBaseList(service.select(service.readQuery(request), service.readConfig(request))); if (resultList.size() 0) { JSONObject jsonObject new JSONObject(); jsonObject.put(obj,resultList.get(0)); return success(jsonObject); } else { return success(null); } } 4.2.5模块管理界面 牙科诊所管理系统中的管理人员在“模块管理”这一菜单下是可以对牙科诊所管理系统内的牙科诊所、挂号预约、检测信息、检测结果、住院预约、住院确认、住院费用、费用类型、满意度评价进行管控的其管理界面如下图4-14所示。 图4-14模块管理界面图 模块管理关键代码如下所示。 RequestMapping(/get_list) public MapString, Object getList(HttpServletRequest request) { MapString, Object map service.selectToPage(service.readQuery(request), service.readConfig(request)); return success(map); } 5系统测试 5.1 系统测试用例 系统测试包括用户登录功能测试、药品展示功能测试、药品添加、药品搜索、密码修改如表5-1、5-2、5-3、5-4、5-5所示 用户登录功能测试 表5-1 用户登录功能测试表 用例名称 用户登录系统 目的 测试用户通过正确的用户名和密码可否登录功能 前提 未登录的情况下 测试流程 1) 进入登录页面 2) 输入正确的用户名和密码 预期结果 用户名和密码正确的时候跳转到登录成功界面反之则显示错误信息提示重新输入 实际结果 实际结果与预期结果一致 药品查看功能测试 表5-2 药品查看功能测试表 用例名称 药品查看 目的 测试药品查看功能 前提 无 测试流程 点击药品 预期结果 可以查看到所有药品 实际结果 实际结果与预期结果一致 管理员添加药品界面测试 表5-3 管理员添加药品界面测试表 用例名称 添加药品测试用例 目的 测试药品添加功能 前提 管理员用户正常登录情况下 测试流程 1管理员点击药品然后点击添加后并填写信息。 2点击进行提交。 预期结果 提交以后页面首页会显示新的药品 实际结果 实际结果与预期结果一致 药品搜索功能测试 表5-4药品搜索功能测试表 用例名称 药品搜索测试 目的 测试药品搜索功能 前提 无 测试流程 1在搜索框填入搜索关键字。 2点击搜索按钮。 预期结果 页面显示包含有搜索关键字的药品 实际结果 实际结果与预期结果一致 密码修改搜索功能测试 表5-5 密码修改功能测试表 用例名称 密码修改测试用例 目的 测试管理员密码修改功能 前提 管理员用户正常登录情况下 测试流程 1管理员密码修改并完成填写。 2点击进行提交。 预期结果 使用新的密码可以登录 实际结果 实际结果与预期结果一致 5.2 系统测试结果 通过编写牙科诊所管理系统的测试用例已经检测完毕用户登录模块、药品展示模块、药品添加模块、药品搜索模块、密码修改模块通过这五大模块为牙科诊所管理系统的后期推广运营提供了强力的技术支撑。 结论 至此牙科诊所管理系统已经结束在开发前做了许多的准备在本系统的设计和开发过程中阅览和学习了许多文献资料从中我也收获了很多宝贵的方法和设计思路对系统的开发也起到了很重要的作用系统的开发技术选用的都是自己比较熟悉的比如Web、Java技术、MYSQL这些技术都是在以前的学习中学到了其中许多的设计思路和方法都是在以前不断地学习中摸索出来的经验其实对于我们来说工作量还是比较大的但是正是由于之前的积累与准备才能顺利的完成这个项目由此看来积累经验跟做好准备是十分重要的事情。 当然在该系统的设计与实现的过程中也离不开老师以及同学们的帮助正是因为他们的指导与帮助我才能够成功的在预期内完成了这个系统。同时在这个过程当中我也收获了很多东西此系统也有需要改进的地方但是由于专业知识的浅薄并不能做到十分完美希望以后有机会可以让其真正的投入到使用之中。 参考文献
[1]张浩.SSM框架在Web应用开发中的设计与实现研究[J].电脑知识与技术,2023,19(08):52-54.DOI:10.14004/j.cnki.ckt.2023.0353.
[2]苏佳旭,白燕,温晓东.基于Web前端与MySQL数据库的自然灾害应急信息共享平台设计与实现[J].电脑知识与技术,2023,19(05):74-77.DOI:10.14004/j.cnki.ckt.2023.0274.
[3]伍德鹏,李佩学.基于SSM框架的高职院校教学办公用品管理信息系统设计研究[J].轻工科技,2023,39(01):99-101.
[4]常婉纶,谈姝辰,屈小娥,田召.基于SSM框架的二级学院教科研信息共享系统的设计与实现[J].电脑知识与技术,2022,18(34):39-41.DOI:10.14004/j.cnki.ckt.2022.2208.
[5]李亚君. 基于SSM框架的B2C电子商城系统的设计与实现[D].合肥工业大学,2022.DOI:10.27101/d.cnki.ghfgu.2022.000313.
[6]张丽景,张文川.基于对比分析法的高职“MySQL数据库”课程设计——以兰州石化职业技术大学为例[J].现代信息科技,2022,6(21):188-191.DOI:10.19850/j.cnki.2096-4706.2022.21.046.
[7]梁倩,文建平. 一种基于SSM框架的云笔记系统[P]. 天津市CN115248676A,2022-10-28.
[8]杨一帆.服务于MySQL数据库的在线监测系统设计[J].自动化技术与应用,2022,41(10):179-182.DOI:10.20033/j.1003-7241.(2022)10-0179-04.
[9]林易康, 基于Java的web应用程序控制管理软件. 湖北省,武汉东湖学院,2021-10-01.
[10]He Xinbin,Bai Yongbin,Yue Lisen,Wang Haixiao,Liu Yi. Design and Implementation of Information System Based on Java Technology Platform[J]. Journal of Physics: Conference Series,2021,2033(1).
[11]Qu Xiaona. Application of Java Technology in Dynamic Web Database Technology[J]. Journal of Physics: Conference Series,2021,1744(4).
[12]吴晓旭.经济背景下牙科诊所信息系统的分析与设计[J].营销界,2020(35):182-184.
[13]Tian Ming Huang. Design and Implementation of App System for Legal Consulting Based on JAVA Technology[J]. Procedia Computer Science,2020,166(C).
[14]方春露,杨文琦,陈滔等. 基于Javaweb技术广东省学生体质争优运动处方数据库和视频库的构建[C]//中国生理学会运动生理学专业委员会,北京体育大学.2018年中国生理学会运动生理学专业委员会会议暨“科技创新与运动生理学”学术研讨会论文集.2018年中国生理学会运动生理学专业委员会会议暨“科技创新与运动生理学”学术研讨会论文集,2018:161-162.
[15]AN.ONYMOU,Cristina.实验场 洛杉矶IN.DENT牙科诊所[J].室内设计与装修,2018(04):12-13.
[16]应丽红,章小雨,应萍,施宁晋,厉雪华,章国宝.基层牙科诊所口腔综合治疗台水路细菌污染状况调查分析[J].中国卫生监督杂志,2016,23(06):547-549.
致 谢
文章能够得以完成这其中离不开我敬爱的老师的帮助虽然没有直接指出问题的所在但也通过言语指点了我并给出了相对应的建议让我能够更加快速地成长在此由衷地表达我的谢意。
首先主要感谢的是我的指导老师是他在我完成我的作品时给了我巨大的肯定这一点给了我巨大信心让我有信心完成这项作品。并且还在我的制作过程中给了我不少的建议让我少走了很多的弯路。为我指出了具体的方向找到了主干的我便沿着主干的枝丫逐渐深入剖析每一个脉络。并且在我的系统的初步完成时也给我指出了我系统存在的不足和缺陷让我深刻认识到了自己的不足。
其次还要感谢为我提供参考资料的同学是他们给了我前人的经验让我得以站在巨人的肩膀上作为我的起点这些资料也给我带来了巨大的帮助。
最后还要感谢我的父母他们给了我最大的支持也充分肯定了我的作品这个给了我极大的鼓舞也奠定了我成功的基础没有这些人对我的帮助也就不会有我今天的成功。对此再次感谢各位的帮助。 免费领取项目源码请关注❤点赞收藏并私信博主谢谢-