摘要
智能网上问诊系统作为医疗健康领域的重要应用之一,为患者提供了便捷的医疗服务途径。本研究旨在基于Springboot框架设计和实现一套智能网上问诊系统,结合医疗专业知识,实现患者与医生之间的在线咨询和诊疗服务。
通过对Springboot框架的灵活运用和医疗领域的深度整合,本系统实现了用户注册登录、在线咨询问诊、医生排班管理等功能模块的设计与开发。同时,引入智能推荐算法和医疗知识图谱,提升系统的智能化水平,为用户提供更精准、高效的医疗服务体验。
本研究的成果将为医疗健康领域的信息化建设和医患沟通提供新思路和技术支持,促进医疗资源的优化配置和医疗服务的智能化升级。基于Springboot的智能网上问诊系统的设计与实现将为医疗行业的数字化转型和智能化发展注入新的活力和动力。
关键词:SpringBoot;智能网上问诊系统;MySQL
Design and implementation of intelligent online consultation system based on springboot
As one of the important applications in the medical and health field, intelligent online consultation system provides patients with convenient medical services. This study aims to design and implement a set of intelligent online consultation system based on Springboot framework, combining medical professional knowledge to realize online consultation and diagnosis and treatment services between patients and doctors.
Through the flexible application of Springboot framework and the deep integration of medical field, the system realizes the design and development of functional modules such as user registration and login, online consultation and consultation, and doctor scheduling management. At the same time, intelligent recommendation algorithm and medical knowledge graph are introduced to improve the intelligence level of the system and provide users with more accurate and efficient medical service experience.
The results of this research will provide new ideas and technical support for the information construction and doctor-patient communication in the medical and health field, and promote the optimal allocation of medical resources and the intelligent upgrade of medical services. The design and implementation of the intelligent online consultation system based on Springboot will inject new vitality and impetus into the digital transformation and intelligent development of the medical industry.
Key words: SpringBoot; Intelligent online consultation system; MySQL
目录
基于springboot的智能网上问诊系统的设计与实现
摘要
Design and implementation of intelligent online consultation system based on springboot
Abstract
1 绪论
1.1 研究背景
1.2研究意义
1.3研究现状
2 智能网上问诊系统需求分析
2.1 可行性分析
2.1.1 技术可行性分析
2.1.2 经济可行性分析
2.1.3 操作可行性分析
2.2系统性能需求分析
2.3 系统功能需求分析
2.4 非功能性需求分析
2.5 总体功能设计
3 智能网上问诊系统概要设计
3.1系统功能结构设计
3.2系统数据库设计
3.2.1数据库概念结构设计
3.2.2数据库逻辑结构设计
4 智能网上问诊系统详细设计与实现
4.1管理员功能模块
4.1.1 医生信息管理界面
4.1.2系统管理界面
4.1.3资源管理界面
4.2普通用户功能模块
4.2.1注册界面
4.2.1登录界面
4.2.2医院咨讯界面
4.2.3医生信息界面
4.2.4 个人中心界面
4.3医生用户功能模块
4.3.1医院咨讯
4.3.2医生信息
4.3.3个人中心
5系统的测试
5.1测试的目的
5.2 系统测试用例
5.3 系统测试结果
6 结论
参考文献
致谢
1 绪论
随着互联网技术的不断发展和医疗健康需求的增长,传统医疗模式已经难以满足人们日益多样化的医疗服务需求。因此,构建智能网上问诊系统成为了提升医疗服务效率和质量的重要途径之一。基于Springboot框架的应用设计与实现,将为现代医疗健康领域的信息化建设提供新的可能性。
传统医疗系统存在着医疗资源不均衡、医患沟通不畅等问题,而智能网上问诊系统的引入能够弥补部分医疗服务的空缺,提高医疗资源的利用效率。通过结合Springboot的快速开发特性和智能算法的运用,可以有效地优化医疗服务流程,实现医患间的即时在线交流,为患者提供更便捷、精准的医疗服务体验。
在数字化时代,智能网上问诊系统的设计与实现不仅有助于医患之间信息的便捷传递,还能够提高医疗服务的智能化水平,为医疗卫生行业的信息化发展和医疗资源的合理配置带来积极影响。因此,研究基于Springboot的智能网上问诊系统的设计与实现具有重要的现实意义和发展前景。
1.2研究意义
研究基于Springboot的智能网上问诊系统的设计与实现具有重要的实践意义。该系统的建立将为医患双方提供便捷的在线咨询和诊疗服务,弥补传统医疗体系中医疗资源分配不均和患者就医难的问题,提高医疗服务的效率和质量。
智能网上问诊系统的设计与实现还有助于推动医疗健康领域的信息化进程,促进医疗服务的智能化升级和数字化转型。通过结合Springboot框架的快速开发特性和智能算法的运用,可以实现医患间的实时互动和信息共享,为患者提供更便捷、个性化的医疗服务体验。
此外,基于Springboot的智能网上问诊系统的研究将为医疗行业的现代化发展和医患关系的优化提供新的思路和技术支持。通过智能化的问诊系统,可以提升医患沟通的效率和质量,促进医疗资源的合理配置,推动医疗健康服务向更智能、便捷的方向发展。
1.3研究现状
目前,基于Springboot的智能网上问诊系统的研究逐渐受到关注,但整体研究仍处于起步阶段。部分学者在医疗健康领域探索Springboot框架在问诊系统中的应用,但在智能化算法与医疗服务的结合以及系统功能的优化等方面仍有待深入研究。
已有的部分研究致力于探讨如何利用Springboot框架构建智能网上问诊系统,以提升医患交流的效率和质量。然而,现有系统在智能化程度、用户体验设计和医疗信息安全等方面仍存在一定挑战,需要进一步完善和优化。
随着医疗信息化的发展和人工智能技术的不断进步,基于Springboot的智能网上问诊系统的研究将迎来更多发展机遇与挑战。未来的研究可在算法优化、系统智能化、医患互动体验等方面加强探讨,推动智能医疗服务模式的不断创新与提升。
2 智能网上问诊系统需求分析
2.1 可行性分析
系统可行行分析是对系统对系统可行性进行一个探讨。在探讨系统的可行性上我们主要从技术上的可行性和经济上的可行性以及操作层面的可行性上进行分析,如果三个层面度通过,我们则认为系统是比较可行的。
2.1.1 技术可行性分析
智能网上问诊系统设计与实现是一个基于Web的交易、管理平台,我们在实现这个系统所采用的技术方案是基于JAVA语言,采用的是比较流行的SpringBoot框架以及MYSQL数据库,在大学的学习中这两门课程都已经学过,而且自己也用这些技术开发过小的项目,在平时的课程设计以及作业也经常用到JAVA、SpringBoot和MYSQL,在技术上实现自己的自主开发是可行的。
2.1.2 经济可行性分析
开发本智能网上问诊系统的技术都是可以从网上直接免费下载,不用花一分钱,而且系统的源代码都是自己进行设计开发的,不需要成本,如果后期想要进行运营,只要把配置到服务器上,花费服务器的租赁费用,在使用中可以进行增加广告收益,因此在经济方面是可性的。
2.1.3 操作可行性分析
2.2系统性能需求分析
智能网上问诊系统的性能性需求分析主要是分析本系统的安全性怎么样(是否会泄露用户个人信息),可靠性怎么样(用户操作的时候是不是能够根据实际操作显示信息),性能怎么样(运行是否操作流畅),可拓展性怎么样(功能能否继续拓展)等。具体可以表示在如下2.1表格中:
安全性 | 主要指智能网上问诊系统数据库的安装,数据库的使用和密码的设定必须合乎规范。 |
可靠性 | 可靠性是指智能网上问诊系统能够按照用户的指示进行操作,经过测试,可靠性90%以上。 |
性能 | 性能是影响智能网上问诊系统占据市场的必要条件,所以性能最好要佳才好。 |
可扩展性 | 比如数据库预留多个属性,比如接口的使用等确保了系统的非功能性需求。 |
易用性 | 用户只要跟着智能网上问诊系统的页面展示内容进行操作,就可以了。 |
可维护性 | 智能网上问诊系统开发的可维护性是非常重要的,经过测试,可维护性没有问题 |
2.3 系统功能需求分析
本智能网上问诊系统的设计主要是针对患者用户、医生用户和管理员。功能如下
患者用户:
(1)注册登录:用户填写注册信息注册账号后,需要管理员在后台进行审核才能登录系统。
(2)公告信息:患者用户点击可查看网站公告、关于我们、联系方式和网站介绍。
(3)医院咨讯:用户点击看查看医院咨讯,同时可对咨讯文章进行点赞、收藏和评论。(4)医生信息:用户点击可通过搜索医生姓名和科室名称进行查看医生信息列表,同时可进行点赞、收藏、评论、预约问诊和在线咨询操作。点击“在线咨询”可填写咨询信息,摆阔咨询标题、咨询类型和咨询内容;点击“预约问诊”可填写问诊信息,包括预约时间、预约说明、历史病例和诊疗记录。
(5)个人中心:用户点击头像可查看“个人中心”,包括个人首页、在线咨询、预约问诊、诊断信息、处方信息和收藏。
医生用户:
(1)登录:医生用户的账号是由管理员在后台添加生成的,可直接输入账号密码进行登录系统。
(2)公告信息:医生用户点击可查看网站公告、关于我们、联系方式和网站介绍。
(3)医院咨讯:医生用户点击看查看医院咨讯,同时可对咨讯文章进行点赞、收藏和评论。
(4)医生信息:医生用户点击可通过搜索医生姓名和科室名称进行查看医生信息列表,同时可进行点赞、收藏和评论
(5)个人中心:医生用户点击头像可查看“个人中心”,包括个人首页、医生信息、在线咨询、预约问诊、诊断信息、处方信息、医生排班和收藏。点击“在线咨询”可对患者的咨询信息进行回复;点击“预约问诊”,可对患者的预约信息进行审核回复;点击“诊断信息”,可填写患者诊断信息,包括就诊时间、就诊内容、诊断疾病和诊断内容。点击“处方信息”可填写患者处方信息,包括处方名称、处方费用、药品种类、药品清单、药品用法和药品剂量。
管理员:
(1)登录:管理员的账号是在数据列表中直接设置生成的,不需要进行注册,可直接输入账号密码登录,同时可对管理员资料进行增删改查。
(2)系统用户:管理员点击可查看管理员、患者用户和医生用户;同时可对系统用户进行增删改查。
(3)医生信息管理:管理员点击可查看医生信息列表和医生信息添加;点击“医生信息添加”,选择医生用户,输入医生工号、医生姓名、科室名称、医生职称、挂号费用、专业领域,上传医生图片,输入就诊时间、专业背景、从业履历和个人介绍,点击“提交”按钮进行添加。点击“医生排班”按钮,可填写医生排班信息,包括排班月份、上传排班表格,输入工作时间、修脚时间、加班时间和排班情况。
(4)在线咨询管理:管理员点击可查看在线咨询列表。
(5)预约问诊管理:管理员点击可查看预约问诊列表。
(6)诊断信息管理:管理员点击可查看诊断信息列表。
(7)处方信息管理:管理员点击可查看处方信息列表。
(8)医生排班管理:管理员点击可查看医生排班列表。
(9)系统管理:管理员点击可查看轮播图管理,如需添加新的轮播图,点击右侧“添加”按钮,上传图片,输入标题,点击“确认”按钮进行添加;同时可对轮播图进行增删改查。
(10)公告信息管理:当管理点击“公告信息管理”时,可查看公告信息;如需添加新的公告信息,点击右侧“添加”按钮,输入标题和正文,点击“确认”按钮进行添加。
(11)资源管理:管理员点击可查看医院咨讯和咨讯分类;如需添加新的咨讯,点击“新增”按钮,上传封面图,输入标题,选择分类,输入标签、描述和正文,点击“确认”按钮进行添加。同时可对咨讯进行增删改查。
2.4 非功能性需求分析
系统的非功能需求方面主要是从系统的安全性、存储性、可靠性、易学性、稳定性等方面进行分析:
(1)安全性:系统的安全问题是开发者首先要考虑的,如果系统存在安全隐患,可能使得用户个人信息被泄露,给用户带来困扰,造成损失。
(2)储存性:因为用户使用的关于智能网上问诊系统,会员用户多,而且登录后要查询各种有关信息,那就需要一个强大的数据库来进行数据的存储,对数据库的要求是非常严格的,本系统选用的是MYSQL数据库,MYSQL的运行速度很快,执行命令的速度也非常快,而且体积小。
(3)易学性:系统的开发面向对象学历不尽相同,所有在开发的时候要考虑系统操作应该简单,不需要进行任何学习、培训,只能上网的用户就可以操作。
(5)稳定性:系统在运行方面要很稳定,系统的界面、字体要清楚,没有失真现象,给用户以良好的体验。
(6)可拓展性:本智能网上问诊系统的功能还有待完善,因此系统要有很好的拓展性,方便后期功能更新维护。
2.5 总体功能设计
本智能网上问诊系统分为患者用户、医生用户和管理员三种用户,智能网上问诊系统的总体用例图如图2-2所示。
图2-2智能网上问诊系统功能总体用例图
3 智能网上问诊系统概要设计
3.1系统功能结构设计
系统在结构上的设计至关重要,要考虑周全,设计全面,一个完善的结构体系,能够满足用户在使用时的各种需求,这样会让提高程序的使用率,保证程序被长久的利用。在设计智能网上问诊系统的结构时,也列入重点,采用模块化的方法来进行设计,即首先将大模块确定下来,再慢慢的将大模块进行补充完善,向下分支出小模块,一起共同组成的系统的结构体系,下图是该智能网上问诊系统的结构设计图,直观明了的可以看出本项目程序的功能。
智能网上问诊系统功能结构图如图3-1所示。
图3-1 智能网上问诊系统功能结构图
3.2系统数据库设计
数据库设计一般包括需求分析、概念模型设计、数据库表建立三大过程,其中需求分析前面章节已经阐述,概念模型设计有概念模型和逻辑结构设计两部分。
3.2.1数据库概念结构设计
在数据库概念模型设计的时候,一般都采用E-R实体图进行展示,在实体图中可以展示出数据库表中的所有字段名称。下面是整个智能网上问诊系统中主要的数据库表总E-R实体关系图。
图3-2 系统总E-R关系图
3.2.2数据库逻辑结构设计
在数据库表中我们会看到系统的表名、主键、外键等信息,我们通过数据库表的主键、外键把每个表关联起来,然后在界面中展示,本智能网上问诊系统的主要的数据库表如下:
表access_token (登陆访问时长)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | token_id | int | 10 | 0 | N | Y | 临时访问牌ID | |
2 | token | varchar | 64 | 0 | Y | N | 临时访问牌 | |
3 | info | text | 65535 | 0 | Y | N | ||
4 | maxage | int | 10 | 0 | N | N | 2 | 最大寿命:默认2小时 |
5 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
6 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间: |
7 | user_id | int | 10 | 0 | N | N | 0 | 用户编号: |
表appointment_consultation (预约问诊)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | appointment_consultation_id | int | 10 | 0 | N | Y | 预约问诊ID | |
2 | doctor_user | int | 10 | 0 | Y | N | 0 | 医生用户 |
3 | doctor_no | varchar | 64 | 0 | Y | N | 医生工号 | |
4 | doctors_name | varchar | 64 | 0 | Y | N | 医生姓名 | |
5 | department_name | varchar | 64 | 0 | Y | N | 科室名称 | |
6 | doctors_title | varchar | 64 | 0 | Y | N | 医生职称 | |
7 | registration_fees | varchar | 64 | 0 | Y | N | 挂号费用 | |
8 | patient_users | int | 10 | 0 | Y | N | 0 | 患者用户 |
9 | patient_name | varchar | 64 | 0 | Y | N | 患者姓名 | |
10 | patient_gender | varchar | 64 | 0 | Y | N | 患者性别 | |
11 | patient_age | varchar | 64 | 0 | Y | N | 患者年龄 | |
12 | appointment_time | datetime | 19 | 0 | Y | N | 预约时间 | |
13 | appointment_instructions | text | 65535 | 0 | Y | N | 预约说明 | |
14 | historical_cases | text | 65535 | 0 | Y | N | 历史病例 | |
15 | diagnosis_and_treatment_records | 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 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
21 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
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 | 文章描述 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
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 | 更新时间: |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
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 | 更新时间: |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
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 | 更新时间: |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
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: |
表diagnostic_information (诊断信息)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | diagnostic_information_id | int | 10 | 0 | N | Y | 诊断信息ID | |
2 | doctor_user | int | 10 | 0 | Y | N | 0 | 医生用户 |
3 | doctor_no | varchar | 64 | 0 | Y | N | 医生工号 | |
4 | doctors_name | varchar | 64 | 0 | Y | N | 医生姓名 | |
5 | department_name | varchar | 64 | 0 | Y | N | 科室名称 | |
6 | doctors_title | varchar | 64 | 0 | Y | N | 医生职称 | |
7 | registration_fees | varchar | 64 | 0 | Y | N | 挂号费用 | |
8 | patient_users | int | 10 | 0 | Y | N | 0 | 患者用户 |
9 | patient_name | varchar | 64 | 0 | Y | N | 患者姓名 | |
10 | patient_gender | varchar | 64 | 0 | Y | N | 患者性别 | |
11 | patient_age | varchar | 64 | 0 | Y | N | 患者年龄 | |
12 | appointment_time | datetime | 19 | 0 | Y | N | 预约时间 | |
13 | visit_time | datetime | 19 | 0 | Y | N | 就诊时间 | |
14 | visit_content | text | 65535 | 0 | Y | N | 就诊内容 | |
15 | diagnose | varchar | 64 | 0 | Y | N | 诊断疾病 | |
16 | diagnostic_content | text | 65535 | 0 | Y | N | 诊断内容 | |
17 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
18 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | doctor_information_id | int | 10 | 0 | N | Y | 医生信息ID | |
2 | doctor_user | int | 10 | 0 | Y | N | 0 | 医生用户 |
3 | doctor_no | varchar | 64 | 0 | Y | N | 医生工号 | |
4 | doctors_name | varchar | 64 | 0 | Y | N | 医生姓名 | |
5 | department_name | varchar | 64 | 0 | Y | N | 科室名称 | |
6 | doctors_title | varchar | 64 | 0 | Y | N | 医生职称 | |
7 | doctors_photo | varchar | 255 | 0 | Y | N | 医生照片 | |
8 | registration_fees | varchar | 64 | 0 | Y | N | 挂号费用 | |
9 | areas_of_expertise | text | 65535 | 0 | Y | N | 专长领域 | |
10 | visit_time | text | 65535 | 0 | Y | N | 就诊时间 | |
11 | professional_background | text | 65535 | 0 | Y | N | 专业背景 | |
12 | career_history | text | 65535 | 0 | Y | N | 从业履历 | |
13 | personal_introduction | text | 65535 | 0 | Y | N | 个人介绍 | |
14 | hits | int | 10 | 0 | N | N | 0 | 点击数 |
15 | praise_len | 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 | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | doctor_scheduling_id | int | 10 | 0 | N | Y | 医生排班ID | |
2 | doctor_user | int | 10 | 0 | Y | N | 0 | 医生用户 |
3 | doctor_no | varchar | 64 | 0 | Y | N | 医生工号 | |
4 | doctors_name | varchar | 64 | 0 | Y | N | 医生姓名 | |
5 | department_name | varchar | 64 | 0 | Y | N | 科室名称 | |
6 | doctors_title | varchar | 64 | 0 | Y | N | 医生职称 | |
7 | scheduling_month | varchar | 64 | 0 | Y | N | 排班月份 | |
8 | schedule_table | varchar | 255 | 0 | Y | N | 排班表格 | |
9 | working_hours | text | 65535 | 0 | Y | N | 工作时间 | |
10 | vacation_time | text | 65535 | 0 | Y | N | 休假时间 | |
11 | overtime_hours | text | 65535 | 0 | Y | N | 加班时间 | |
12 | scheduling_situation | text | 65535 | 0 | Y | N | 排班情况 | |
13 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
14 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | doctor_users_id | int | 10 | 0 | N | Y | 医生用户ID | |
2 | doctor_no | varchar | 64 | 0 | N | N | 医生工号 | |
3 | doctors_name | varchar | 64 | 0 | Y | N | 医生姓名 | |
4 | examine_state | varchar | 16 | 0 | N | N | 已通过 | 审核状态 |
5 | user_id | int | 10 | 0 | N | N | 0 | 用户ID |
6 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
7 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
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: |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
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 | 更新时间: |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | online_consultation_id | int | 10 | 0 | N | Y | 在线咨询ID | |
2 | doctor_user | int | 10 | 0 | Y | N | 0 | 医生用户 |
3 | doctor_no | varchar | 64 | 0 | Y | N | 医生工号 | |
4 | doctors_name | varchar | 64 | 0 | Y | N | 医生姓名 | |
5 | department_name | varchar | 64 | 0 | Y | N | 科室名称 | |
6 | doctors_title | varchar | 64 | 0 | Y | N | 医生职称 | |
7 | patient_users | int | 10 | 0 | Y | N | 0 | 患者用户 |
8 | patient_name | varchar | 64 | 0 | Y | N | 患者姓名 | |
9 | patient_gender | varchar | 64 | 0 | Y | N | 患者性别 | |
10 | consultation_title | varchar | 64 | 0 | Y | N | 咨询标题 | |
11 | consultation_type | varchar | 64 | 0 | Y | N | 咨询类型 | |
12 | consultation_content | text | 65535 | 0 | Y | N | 咨询内容 | |
13 | reply_content | text | 65535 | 0 | Y | N | 回复内容 | |
14 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
15 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | patient_users_id | int | 10 | 0 | N | Y | 患者用户ID | |
2 | patient_name | varchar | 64 | 0 | Y | N | 患者姓名 | |
3 | patient_gender | varchar | 64 | 0 | Y | N | 患者性别 | |
4 | examine_state | varchar | 16 | 0 | N | N | 未审核 | 审核状态 |
5 | user_id | int | 10 | 0 | N | N | 0 | 用户ID |
6 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
7 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
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已取消 |
表prescription_information (处方信息)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | prescription_information_id | int | 10 | 0 | N | Y | 处方信息ID | |
2 | doctor_user | int | 10 | 0 | Y | N | 0 | 医生用户 |
3 | doctor_no | varchar | 64 | 0 | Y | N | 医生工号 | |
4 | doctors_name | varchar | 64 | 0 | Y | N | 医生姓名 | |
5 | department_name | varchar | 64 | 0 | Y | N | 科室名称 | |
6 | doctors_title | varchar | 64 | 0 | Y | N | 医生职称 | |
7 | registration_fees | varchar | 64 | 0 | Y | N | 挂号费用 | |
8 | patient_users | int | 10 | 0 | Y | N | 0 | 患者用户 |
9 | patient_name | varchar | 64 | 0 | Y | N | 患者姓名 | |
10 | patient_gender | varchar | 64 | 0 | Y | N | 患者性别 | |
11 | patient_age | varchar | 64 | 0 | Y | N | 患者年龄 | |
12 | visit_time | datetime | 19 | 0 | Y | N | 就诊时间 | |
13 | diagnose | varchar | 64 | 0 | Y | N | 诊断疾病 | |
14 | prescription_name | varchar | 64 | 0 | Y | N | 处方名称 | |
15 | prescription_fees | varchar | 64 | 0 | Y | N | 处方费用 | |
16 | types_of_drugs | varchar | 64 | 0 | Y | N | 药品种类 | |
17 | drug_list | text | 65535 | 0 | Y | N | 药品清单 | |
18 | drug_usage | text | 65535 | 0 | Y | N | 药品用法 | |
19 | drug_dosage | text | 65535 | 0 | Y | N | 药品剂量 | |
20 | pay_state | varchar | 16 | 0 | N | N | 未支付 | 支付状态 |
21 | pay_type | varchar | 16 | 0 | Y | N | 支付类型: 微信、支付宝、网银 | |
22 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
23 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
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 | 更新时间: |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
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 | 文件类型 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
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 | | 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 | open_id | varchar | 255 | 0 | Y | N | 针对获取用户信息字段 | |
14 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
15 | vip_level | varchar | 255 | 0 | Y | N | 会员等级 | |
16 | vip_discount | double | 11 | 2 | Y | N | 0.00 | 会员折扣 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
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 | 更新时间: |
4 智能网上问诊系统详细设计与实现
4.1管理员功能模块
4.1.1 医生信息管理界面
医生信息管理:管理员点击可查看医生信息列表和医生信息添加;点击“医生信息添加”,选择医生用户,输入医生工号、医生姓名、科室名称、医生职称、挂号费用、专业领域,上传医生图片,输入就诊时间、专业背景、从业履历和个人介绍,点击“提交”按钮进行添加。点击“医生排班”按钮,可填写医生排班信息,包括排班月份、上传排班表格,输入工作时间、修脚时间、加班时间和排班情况。界面展示如下图所示。
图4-1 医生信息添加界面图
图4-2 医生排班添加界面图
4.1.2系统管理界面
系统管理:管理员点击可查看轮播图管理,如需添加新的轮播图,点击右侧“添加”按钮,上传图片,输入标题,点击“确认”按钮进行添加;同时可对轮播图进行增删改查。展示如下图所示。
图4-3 系统管理界面图
4.1.3资源管理界面
资源管理:管理员点击可查看医院咨讯和咨讯分类;如需添加新的咨讯,点击“新增”按钮,上传封面图,输入标题,选择分类,输入标签、描述和正文,点击“确认”按钮进行添加。同时可对咨讯进行增删改查。界面如下图所示。
图4-4 资源管理界面图
4.2普通用户功能模块
4.2.1注册界面
当用户想要进行用户相关信息的查询管理的时候,就必须进行登录,如果没有账号的话,在登录界面,点击“注册”按钮就会跳转到注册的界面,根据提示填写好注册信息,添加提交,注册的信息在数据库中就添加完成了,然后再输入填写好的账号和密码进行登录,其主界面展示如下图所示。
图4-5 登录界面图
注册关键代码如下:
/**
* 注册
* @param user
* @return
*/
@PostMapping("register")
public Map<String, Object> signUp(@RequestBody User user) {
// 查询用户
Map<String, String> query = new HashMap<>();
Map<String,Object> map = JSON.parseObject(JSON.toJSONString(user));
query.put("username",user.getUsername());
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);
}
4.2.1登录界面
用户注册并登录系统,可对个人信息进行增删改查,比如个人资料、头像和密码修改。界面如下图4-5所示。
图4-6 登录界面图
登录关键代码如下所示。
/**
* 登录
* @param data
* @param httpServletRequest
* @return
*/
@PostMapping("login")
public Map<String, Object> login(@RequestBody Map<String, 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;
Map<String, 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);
Map<String, 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 (res==null){
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());
Duration duration = Duration.ofSeconds(7200L);
redisTemplate.opsForValue().set(accessToken.getToken(), accessToken,duration);
// 返回用户信息
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, "账号或密码不正确");
}
}
4.2.2医院咨讯界面
医院咨讯:用户点击看查看医院咨讯,同时可对咨讯文章进行点赞、收藏和评论。界面如下图所示。
图4-7 医院咨讯界面图
4.2.3医生信息界面
医生信息:用户点击可通过搜索医生姓名和科室名称进行查看医生信息列表,同时可进行点赞、收藏、评论、预约问诊和在线咨询操作。点击“在线咨询”可填写咨询信息,摆阔咨询标题、咨询类型和咨询内容;点击“预约问诊”可填写问诊信息,包括预约时间、预约说明、历史病例和诊疗记录。界面如下图所示。
图4-8 医生信息界面图
图4-9在线咨询界面图
图4-10 预约问诊界面图
4.2.4 个人中心界面
个人中心:用户点击头像可查看“个人中心”,包括跟人首页、在线咨询、预约问诊、诊断信息、处方信息和收藏。界面如下图所示。
图4-11 个人中心界面图
4.3医生用户功能模块
4.3.1医院咨讯
医院咨讯:医生用户点击看查看医院咨讯,同时可对咨讯文章进行点赞、收藏和评论。界面如下图所示。
图4-12 医院咨讯界面图
4.3.2医生信息
医生信息:医生用户点击可通过搜索医生姓名和科室名称进行查看医生信息列表,同时可进行点赞、收藏和评论界面如下图所示。
图4-13 医生信息界面图
4.3.3个人中心
个人中心:用户点击头像可查看“个人中心”,包括个人首页、医生信息、在线咨询、预约问诊、诊断信息、处方信息、医生排班和收藏。点击“在线咨询”可对患者的咨询信息进行回复;点击“预约问诊”,可对患者的预约信息进行审核回复;点击“诊断信息”,可填写患者诊断信息,包括就诊时间、就诊内容、诊断疾病和诊断内容。点击“处方信息”可填写患者处方信息,包括处方名称、处方费用、药品种类、药品清单、药品用法和药品剂量。
图4-13 个人中心界面图
图4-13 诊断信息界面图
图4-13 处方信息界面图
5系统的测试
5.1测试的目的
一个系统测试的目的就是检验系统在真正的工作环境、条件下是不是能够正常运行,各种功能能不能符合设计的要求,通过测试发现系统当中存在的一些潜在的错误,然后对系统进行改进,使得系统最终以完美的形式展现给用户,提高用户使用过程中的体验度,真正达到项目的实际使用目的。
5.2 系统测试用例
系统测试包括:管理员登录功能测试、医院咨讯查看功能测试、医生信息添加功能测试,如表5-1、5-2、5-3所示:
表5-1 管理员登录功能测试表
测试名称 | 测试功能 | 操作过程 | 预期结果 | 测试结果 |
登录模块测试 | 登录成功的情况 | 管理员可以通过浏览器进入到智能网上问诊系统后台登录界面,输入用户名:admin和密码admin后,点击“登录”按钮。 | 成功登录到管理员管理的界面 | 正确 |
登录模块测试 | 登录失败的情况 | 管理员可以通过浏览器进入到智能网上问诊系统后台登录界面,输入用户名:admin和密码111后,点击“登录”按钮。 | 系统提示“用户名和密码不匹配” | 正确 |
医院咨讯查看功能测试:
表5-2 医院咨讯查看功能测试表
测试名称 | 测试功能 | 操作过程 | 预期结果 | 测试结果 |
医院咨讯查看功能测试 | 查询成功的情况 | 用户在系统首页点击“医院咨讯”,能够查看医院咨讯列表详情 | 查询成功 | 正确 |
医生信息添加界面测试:
表5-3 医生信息添加界面测试表
测试名称 | 测试功能 | 操作过程 | 预期结果 | 测试结果 |
医生信息添加模块测试 | 医生信息添加成功的情况 | 在“医生信息管理”菜单中点击“积分商城添加”按钮,点击“添加”,输入添加信息,输入正确的信息后,点击“提交”按钮。 | 提示添加成功 | 正确 |
医生信息添加模块测试 | 医生信息添加失败的情况 | 在“医生信息管理”菜单中点击“医生信息添加”按钮,点击“添加”,输入添加信息,不输入医生姓名后,点击“提交”按钮。 | 提示添加失败 | 正确 |
5.3 系统测试结果
在本章节对智能网上问诊系统进行了黑白盒测试,并对系统中的部分功能进行了用例分析,能够发现系统还是比较稳定的,系统的所有功能基本可以实现,通过测试可以看出在系统的运行过程中,其功能完整,对于输入的错误信息,能够把错误信息提示出来,方便用户操作的时候发现自己输入的信息哪里有错误,进而进行改正,而且系统界面都设有导航栏,操作非常便捷,不需要对使用者进行任何培训。
6 结论
经过了几个月的努力,本智能网上问诊系统终于完成了,虽然在校期间也开发过一些小型的系统,但是都是在老师的讲解以及辅助下完成的,没有经历过开发之前的需求分析、系统分析,都是直接从系统设计开始的,因此本次开发的智能网上问诊系统对我意义重大。
在开发系统最初,首先对本智能网上问诊系统的需求进行调研,了解对于观看用户来说,开发的系统需要实现哪些功能才能满足使用者的需求,对需求进行分析;其次选择自己比较熟悉的JAVA语言,MYSQL数据库,使用SpringBoot框架来设计开发,通过知网库、学校图书馆等地方查阅、学习这些技术,掌握编程的思想和方法,然后就是对系统进行分析,从系统开发的可行性、系统实现的功能、系统应该具备的性能以及系统的操作流程方面,对系统进行全方位的分析,确定系统的最终功能,从而对系统的功能和数据库进行设计,最后就是系统的实现以及对实现的功能的测试,确保系统能够稳定的运行。
在开发的过程中暴露出了自己的很多问题,比如前期的准备还是不够充分,不能完全掌握其操作流程;在开发过程中对JAVA的编程掌握的还不够熟练以及对系统的环境配置上还存在很多问题,经常会导致项目在运行的时候出现错误。学无止境,通过一边查阅资料一边向导师请教,慢慢的解决了这些问题,在以后的学习、工作者我会更加严谨,通过本项目的开发,我将会受益终生!
参考文献
[1]陈雨,杨滨,邓嵘.感知价值视角下移动医疗问诊系统设计评价与优化[J/OL].图书馆论坛:1-11[2024-04-19].http://kns.cnki.net/kcms/detail/44.1306.G2.20231031.1037.002.html.
[2]唐华,胡为,刘伟,等.基于知识图谱的中医医案智能问诊系统设计与实现[J].现代计算机,2023,29(19):98-101.
[3]杨滨阳.社区家庭医生在线问诊系统设计与实现[J].信息系统工程,2023(07):4-7.
[4]陈小强,胡翰,陈燕军.基于深度学习的智能问诊系统设计与实现[J].电脑编程技巧与维护,2023(05):119-122.DOI:10.16184/j.cnki.comprg.2023.05.025.
[5]姚心婧. 智能问诊系统用户体验影响因素组态分析[D].华中师范大学,2023.DOI:10.27159/d.cnki.ghzsu.2023.000726.
[6]吴燎. 基于任务型对话的中医辅助问诊系统研究与实现[D].电子科技大学,2023.DOI:10.27005/d.cnki.gdzku.2023.003659.
[7]徐海燕.JAVA编程在计算机应用软件中的应用特征与技术[J].电子技术与软件工程,2023(03):29-32.
[8]李梦翔,许扬,陈磊.在线智能预问诊系统构建与应用研究[J].医学信息学杂志,2022,43(11):73-77+88.
[9]阚文.基于Spring Boot框架的智慧医疗问诊系统的设计与实现[J].信息与电脑(理论版),2022,34(21):33-36.
[10]屈巍,段盼君,刘岩,等.基于物联网的智能问诊与药品售卖系统[J].电脑编程技巧与维护,2022(08):128-130.DOI:10.16184/j.cnki.comprg.2022.08.011.
[11]许亮业,王懿鸣,杜隽.智能预问诊系统的设计及应用[J].微型电脑应用,2022,38(05):182-185.
[12]刘巧. 基于智能问诊的药品推荐系统的研究与实现[D].西南大学,2023.DOI:10.27684/d.cnki.gxndx.2022.001368.
[13]王曼维,杨荻,李岩,等.基于SpringBoot框架的智慧医疗问诊系统设计与实现[J].中国医学装备,2022,19(03):133-136.
[14]周寅,张振方,周振涛,等.基于Java Web的智慧医疗问诊管理系统的设计与应用[J].中国医学装备,2021,18(08):132-135.
[15]李杨辉. 基于知识指导的智能问诊研究与实现[D].华南理工大学,2023.DOI:10.27151/d.cnki.ghnlu.2021.002042.
[16]徐霄玲,郑建立,邵奕琛,等.基于带权知识图谱的智能预问诊系统的研究[J].智能计算机与应用,2020,10(12):204-208.
[17]刘坤. 基于移动互联网的农村医药问诊服务平台的研究[D].河北科技师范学院,2021.DOI:10.27741/d.cnki.ghbkj.2020.000198.
[18]张克东. 医疗问诊服务设计研究[D].合肥工业大学,2021.DOI:10.27101/d.cnki.ghfgu.2020.001380.
[19]李星彦. 基于电子病历的辅助问诊系统的设计与实现[D].北京邮电大学,2021.DOI:10.26969/d.cnki.gbydu.2020.001879.
[20]韩梦宁. 基于Web智能预问诊系统的设计与实现[D].北京邮电大学,2021.DOI:10.26969/d.cnki.gbydu.2020.002593.
致谢
“致谢”意味着论文的结束,也意味着自己的毕业设计顺利完成,同时也代表了自己的大学生涯即将结束,我即将要离开自己敬爱的老师和亲爱的同学们,在这里我首先要感谢的就是所有的老师,“春满江山绿满园,桃李争春露笑颜,东西南北春常在,唯有师恩留心间”,他们无论在我的学业还是在我的生活上付出了所有,对我谆谆教诲;其次我要感谢我的指导老师,他在我的整个毕业设计当中起着引导作用,每当我有困难的时候,他总会第一时间帮助我,引导我进行解决问题,而不是直接告诉我答案,“授人以鱼不如授人以渔”,指导老师的这种做法让我受益终生,同时我也从指导老师身上学习到了许多的开发技巧以及检验,这对我今后的开发起着十分重要的作用;再次,我需要感谢我的同学、室友,他们不仅仅在毕业设计上给我许多帮助意见,在大学同窗四年,他们给过我的帮助太多了,我对他们有太多的不舍,无法用言语表示,我相信在以后的人生道路上只要想到他们,我心里就会很温暖,这种友情是任何感情替代不了的;最后我还要感谢家人,感谢自己,感谢家人对我的支持,感谢自己在学业上的坚持,我相信我以后的道路会越来越好。
免费领取项目源码,请关注❥点赞收藏并私信博主,谢谢~