0
点赞
收藏
分享

微信扫一扫

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


博主主页:猫头鹰源码

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

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

文末联系获取

项目介绍:

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

项目功能:

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

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

用户模块

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

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

(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

部分截图说明:

系统首页

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

下面是登录页面

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

登录后查看预约

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

 接种人维护

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


首页下面是疫苗列表

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

 点击查看疫苗详情

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

查看厂商列表

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

 厂商详情

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

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

基于SSM的疫苗预约接种平台_开发语言_10

点击查看资讯详情

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

 公告管理

基于SSM的疫苗预约接种平台_开发语言_12

用户管理,对用户维护

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

资讯管理,资讯的维护

基于SSM的疫苗预约接种平台_开发语言_14

疫苗管理

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

部分代码:

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&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", "操作失败!");
		}
	}

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

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

举报

相关推荐

新冠疫苗接种须知

【011】疫苗接种管理系统

0 条评论