基于SSM的疫苗预约接种平台

博主主页猫头鹰源码

博主简介:Java领域优质创作者、CSDN博客专家、公司架构师、全网粉丝5万+、专注Java技术领域和毕业设计项目实战

主要内容:毕业设计(Javaweb项目|小程序等)、简历模板、学习资料、面试题库、技术咨询

文末联系获取

项目介绍:

本系统采用SSM框架,数据层采用mybatis-plus,数据库使用mysql,适合选题:疫情、疫苗、预约、预约接种等。

项目功能:

这个系统的用户可以分成三类:管理员,用户,医生。

用户模块

用户在系统的操作模块主要在前端模块包含以下功能:

系统首页、疫苗信息浏览、健康资讯信息浏览、使用者的个人中心

(1)首页:包括系统通知、导航栏(系统首页、疫苗信息浏览、健康资讯信息浏览、使用者的个人中心)、轮播图、疫苗厂商详情简介、注册登记。

(2)疫苗信息浏览:疫苗的预览界面,分页显示疫苗信息,疫苗信息查询,以及疫苗的详细信息查询显示

点击疫苗的按键,可以看到疫苗详细信息,其上显示的疫苗信息(疫苗名称、生产厂商、类别、价格、库存、疫苗生产批号、生产日期、某疫苗的使用剂量、接种疫苗的适用年龄、疫苗图示)并显示可预约的疫苗(未登录跳转到登陆页面进行登录注册)。点击预约某疫苗后进入预约接种确认页面,填写需接种疫苗的预约人信息(用户姓名、用户地址、预约人手机号),用户选择接种的人、以及接种时间。确认预约后随机生成6位数字作为接种码存储在数据库中。

(3)健康资讯信息浏览:健康资讯浏览主页面(显示标题以及资讯图示),页面上显示健康资讯信息,也也有关键词搜索,以查询相关资讯内容,点击之后显示具体健康讯息。

在此网页中,您可以看到健康信息,页面具体展示了健康资讯详细信息(包括图片和内容)、内容发布时间、以及点赞功能(未登陆不能使用该模块、并提示用户注册登录)。

(4)个人中心:本系统页面包含了预约对象的详细信息:接种记录、个人信息、修改用户密码、退出系统。

后台模块

后台模块的操作主要使用者为系统管理员和医生

系统管理员的功能包括以下功能: 

(1)用户管理:管理用户模块以及对用户的增加、删除、修改、查询

(2)疫苗信息管理:显示疫苗名称信息、疫苗厂商、疫苗类别、各种疫苗价格、疫苗库存、疫苗生产批号、疫苗生产日期、疫苗每针剂量、疫苗接种年龄、疫苗图示。每类疫苗的添加、对疫苗相关信息的修改、疫苗信息的删除

(3)资讯信息管理:显示标题、详情、图片、内容发布时间、资讯类别并对显示信息进行可编辑操作(使用富文本)、添加操作(使用富文本)、删除操作

(4)资讯信息分类管理(将资讯进行分类管理)

(5)接种记录查询(只有查看权限)和前端用户查看的内容一致

(6)疫苗厂商管理:修改疫苗厂商的名称、简介、图示进行增删改查

医生的主要功能包括以下功能:

(1)已预约订单显示:接种码、预约人(登录预约用户,显示用户个人的信息)、接种人(显示接种人姓名)、接种人过敏药物、疫苗名称、接种人预约时间

(2)对预约订单进行接种疫苗操作,接种疫苗操作时只能添加接种部位、接种方式、以及接种医生查询接种时的记录信息

系统包含技术:

后端:SSM整合
前端:bootstrap、js、css等
开发工具:eclipse
数据库:mysql 5.7
JDK版本:jdk1.8
服务器:tomcat8

部分截图说明:

系统首页

下面是登录页面

登录后查看预约

 接种人维护

首页下面是疫苗列表

 点击查看疫苗详情

查看厂商列表

 厂商详情

可以根据分类查看资讯列表 

点击查看资讯详情

 公告管理

用户管理,对用户维护

资讯管理,资讯的维护

疫苗管理

部分代码:

spring的配置

<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans"        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"        xmlns:context="http://www.springframework.org/schema/context"        xmlns:aop="http://www.springframework.org/schema/aop"        xmlns:p="http://www.springframework.org/schema/p"        xmlns:tx="http://www.springframework.org/schema/tx"        xsi:schemaLocation="http://www.springframework.org/schema/beans                http://www.springframework.org/schema/beans/spring-beans.xsd                http://www.springframework.org/schema/context                http://www.springframework.org/schema/context/spring-context.xsd                http://www.springframework.org/schema/aop                http://www.springframework.org/schema/aop/spring-aop.xsd                http://www.springframework.org/schema/tx                http://www.springframework.org/schema/tx/spring-tx.xsd">     <!--开启注解-->     <context:component-scan base-package="cn"/>     <!--配置一个dataSource-->     <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource">         <property name="driverClassName" value="com.mysql.jdbc.Driver"/>         <property name="url" value="jdbc:mysql://127.0.0.1:3306/db_yimiao?useUnicode=true&amp;characterEncoding=utf-8"/>         <property name="username" value="root"/>         <property name="password" value="root"/>         <!-- 初始化连接大小 -->         <property name="initialSize" value="0"></property>         <!-- 连接池最大使用连接数量 -->         <property name="maxActive" value="20"></property>         <!-- 连接池最小空闲 -->         <property name="minIdle" value="0" />         <!-- 获取连接最大等待时间 -->         <property name="maxWait" value="60000" />         <property name="validationQuery">             <value>SELECT 1</value>         </property>         <property name="testOnBorrow" value="false" />         <property name="testOnReturn" value="false" />         <property name="testWhileIdle" value="true" />         <!-- 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒 -->         <property name="timeBetweenEvictionRunsMillis" value="60000" />         <!-- 配置一个连接在池中最小生存的时间,单位是毫秒 -->         <property name="minEvictableIdleTimeMillis" value="25200000" />          <!-- 打开removeAbandoned功能 -->         <property name="removeAbandoned" value="true" />         <!-- 1800秒,也就是30分钟 -->         <property name="removeAbandonedTimeout" value="1800" />         <!-- 关闭abanded连接时输出错误日志 -->         <property name="logAbandoned" value="true" />         <!-- 监控数据库 -->         <!-- 配置监控统计拦截的filters -->         <property name="filters" value="stat"/>      </bean>     <!--配置一个sqlSessionFactory-->     <bean id="sqlSessionFactory" class="com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean">         <!--指定一个mybatis配置文件-->         <property name="configLocation" value="classpath:mybatis-config.xml"/>         <property name="dataSource" ref="dataSource"/>         <!--别名-->         <property name="typeAliasesPackage" value="cn.entity"/>         <!--映射-->         <property name="mapperLocations" value="classpath:cn/mapper/*Mapper.xml"/>         <!--配置分页插件-->         <property name="plugins">             <array>                 <!-- 分页插件 -->                 <bean id="paginationInterceptor" class="com.baomidou.mybatisplus.extension.plugins.PaginationInterceptor">                     <property name="dialectType" value="mysql"/>                 </bean>             </array>         </property>     </bean> 	<!-- 验证码 --> 	<bean id="captchaProducer" class="com.google.code.kaptcha.impl.DefaultKaptcha"> 		<property name="config"> 			<bean class="com.google.code.kaptcha.util.Config"> 				<constructor-arg> 					<props> 						<prop key="kaptcha.border">no</prop> 						<prop key="kaptcha.border.color">red</prop> 						<prop key="kaptcha.border.thickness">5</prop> 						<prop key="kaptcha.image.width">140</prop> 						<prop key="kaptcha.image.height">50</prop> 						<prop key="kaptcha.noise.color">0,0,205</prop><!-- 0,0,205 black --> 						<prop key="kaptcha.background.clear.from">178,223,238</prop> <!-- 255,250,205 --> 						<prop key="kaptcha.background.clear.to">240,255,240</prop> 						<prop key="kaptcha.textproducer.font.names">微软雅黑</prop> 						<prop key="kaptcha.textproducer.font.size">30</prop> 						<prop key="kaptcha.textproducer.font.color">72,118,255</prop> <!-- 255,110,180 --> 						<prop key="kaptcha.textproducer.char.space">3</prop> 						<prop key="kaptcha.textproducer.char.string">ABCDEFGHJKMNQRSTUVWXYZ123456789</prop> 						<prop key="kaptcha.textproducer.char.length">4</prop> 					</props> 				</constructor-arg> 			</bean> 		</property> 	</bean>     <!--2、扫描DAO接口所在的包,指定sessionFactory的名称-->     <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">         <property name="basePackage" value="cn.mapper"/>         <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/>     </bean>     <!--transaction-manager事务管理器-->     <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">         <property name="dataSource" ref="dataSource"/>     </bean>     <!--声明式事务-->     <tx:advice id="txAdvice" transaction-manager="transactionManager">         <tx:attributes>             <!--哪些方法用什么事务 propagation事务的传播特性-->             <tx:method name="add*" propagation="REQUIRED"/>             <tx:method name="del*" propagation="REQUIRED"/>             <tx:method name="modify*" propagation="REQUIRED"/>             <tx:method name="update*" propagation="REQUIRED"/>             <tx:method name="*" propagation="SUPPORTS" read-only="true"/>         </tx:attributes>     </tx:advice>     <!--aop-->     <aop:config>         <aop:advisor advice-ref="txAdvice" pointcut="execution(* cn.service..*.*(..))"/>     </aop:config>   </beans>

疫苗操作

@RequestMapping("list") 	public String list(Integer page,String name,HttpSession session,Model model) { 		if(page==null){ 			page=1; 		} 		PageBean pageBean=new PageBean(); 		pageBean.setPageNo(page); 		QueryWrapper<Yimiao> wrapper = new QueryWrapper<Yimiao>(); 		if(!StringUtils.isNullOrEmpty(name)){ 			wrapper.like("name", name); 			model.addAttribute("name",name); 		} 		wrapper.eq("isdel", 0); 		IPage<Yimiao> pageList=new Page<Yimiao>(page,pageBean.getPageSize()); 		pageList = yimiaoService.page(pageList, wrapper); 		List<Yimiao> list=pageList.getRecords(); 		for (Yimiao m : list) { 			if(m.getTid()!=null){ 				Yimiaotype y = yimiaotypeService.getById(m.getTid()); 				m.setYimiaotype(y); 			} 			if(m.getFid()!=null){ 				Firm f  = firmService.getById(m.getFid()); 				m.setFirm(f); 			} 		} 		pageBean.setTotalCount((int)pageList.getTotal()); 		model.addAttribute("pageBean", pageBean); 		model.addAttribute("list", list); 		return "admin/yimiaoList"; 	}  	@RequestMapping("add") 	@ResponseBody 	public ServerResponse add(Yimiao yimiao) { 		yimiao.setIsdel(0); 		boolean flag = yimiaoService.save(yimiao); 		if (flag) { 			return new ServerResponse("0", "操作成功!"); 		} else { 			return new ServerResponse("1", "操作失败!"); 		} 	} 	 	@RequestMapping("update") 	@ResponseBody 	public ServerResponse update(Yimiao yimiao) { 		boolean flag = yimiaoService.updateById(yimiao); 		if (flag) { 			return new ServerResponse("0", "操作成功!"); 		} else { 			return new ServerResponse("1", "操作失败!"); 		} 	}  	@RequestMapping("delete") 	@ResponseBody 	public ServerResponse delete(Yimiao yimiao) { 		yimiao.setIsdel(1); 		boolean flag = yimiaoService.updateById(yimiao); 		if (flag) { 			return new ServerResponse("0", "操作成功!"); 		} else { 			return new ServerResponse("1", "操作失败!"); 		} 	}

以上就是部分功能展示,从整体上来看,本系统功能是十分完整的,界面设计简洁大方,交互友好,数据库设计也很合理,规模适中,代码工整,清晰,适合学习使用。

好了,今天就到这儿吧,小伙伴们点赞、收藏、评论,一键三连走起呀,下期见~~

  • 24
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值