博主主页:猫头鹰源码
博主简介:Java领域优质创作者、博客专家、公司架构师、全网粉丝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&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", "操作失败!");
}
}
以上就是部分功能展示,从整体上来看,本系统功能是十分完整的,界面设计简洁大方,交互友好,数据库设计也很合理,规模适中,代码工整,清晰,适合学习使用。
好了,今天就到这儿吧,小伙伴们点赞、收藏、评论,一键三连走起呀,下期见~~