23基于java教师科研项目管理系统

背景及意义

目前许多人仍将传统的纸质工具作为信息管理的主要工具,而网络技术的应用只是起到辅助作用。在对网络工具的认知程度上,较为传统的office软件等仍是人们使用的主要工具,而相对全面且专业的信息管理软件仍没有得到大多数人的了解或认可。本选题则旨在通过标签分类管理等方式,实现教研的各种功能,从而达到对科研管理系统的管理。

项目环境

> 前端:html, css, js, vue, jquery等; 
> 后端:java, spring,maven,SSM,Springboot等 ; 
> 开发工具:支持eclipse或idea
> 数据库:mysql7
> 更多内容可查看:http://projecthelp.top

设计

以院系申报科技项目为例:科研管理系统的实现主要包括教师、科研管理人员和系统管理员三个用户角色,由于系统用户角色不同所使用的功能模块相应不同,管理员根据需求对系统功能模块进行维护管理操作。

部分核心代码

import org.springframework.stereotype.Service;
import xyz.shiguangliang.mybatis.dao.UserMapper;

import xyz.shiguangliang.mybatis.domain.User;
import xyz.shiguangliang.service.UserService;
import xyz.shiguangliang.util.query.QueryInfo;

import javax.annotation.Resource;
import java.util.Date;
import java.util.List;
import java.util.Objects;

@Service
public class UserServiceImpl implements UserService {
    @Resource
    private UserMapper userMapper;

    //登录
    @Override
    public User login(String username, String password) {
        User user = userMapper.selectLogin(username,password);
        if (user != null) {
            //登录次数加一
            if (user.getIntimes() !=  null) {
                user.setIntimes(user.getIntimes() + 1);
            }else {
                user.setIntimes(1);
            }
            //更新登录时间
            user.setLastlogin(new Date());
            return user;
        }
        return null;
    }

    //注册
    @Override
    public boolean register(User user) {
        int i = 0;
        //检测用户是否存在
        User user1 = userMapper.selectUsername(user.getUsername());
        if (user1 == null) {
            i = userMapper.insert(user);
        }
        return i > 0;
    }

    //用户列表
    @Override
    public QueryInfo getUserList(String query, Integer pagenum,Integer pagesize) {
        QueryInfo queryInfo = new QueryInfo();
        int start;
        int end;
        if (pagenum == null||pagesize == null){
            pagenum =0;
            pagesize = 3;
        }
        start = (pagenum-1)*pagesize;
        end = pagesize;
        int userSize = userMapper.selectUserListLimitSize(query,start,end);
        List<User> users = userMapper.selectUserListLimit(query,start,end);
        queryInfo.setList(users);
        queryInfo.setTotal(userSize);
        return queryInfo;
    }

    //删除用户
    @Override
    public int deleteUser(Integer tid) {
        return userMapper.deleteByPrimaryKey(tid);
    }

    //通过id查找用户
    @Override
    public User findById(Integer tid) {
        return userMapper.selectByPrimaryKey(tid);
    }



    //更新用户
    @Override
    public int updateUser(User user) {
        if (user.getPassword()==null|| Objects.equals(user.getPassword(), "")){
            user.setPassword(userMapper.selectByPrimaryKey(user.getTid()).getPassword());
        }
        return userMapper.updateByPrimaryKey(user);
    }

    //通过用户名查找用户
    @Override
    public User findByUsername(String username) {
        return userMapper.selectUsername(username);
    }

    //获取用户权限
    @Override
    public int getPower(String username) {
        return userMapper.selectUsername(username).getPower();
    }
}

useMapper.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="xyz.shiguangliang.mybatis.dao.UserMapper">
  <resultMap id="BaseResultMap" type="xyz.shiguangliang.mybatis.domain.User">
    <id column="tid" jdbcType="INTEGER" property="tid" />
    <result column="username" jdbcType="VARCHAR" property="username" />
    <result column="password" jdbcType="VARCHAR" property="password" />
    <result column="teachername" jdbcType="VARCHAR" property="teachername" />
    <result column="dno" jdbcType="INTEGER" property="dno" />
    <result column="power" jdbcType="INTEGER" property="power" />
    <result column="intimes" jdbcType="INTEGER" property="intimes" />
    <result column="lastlogin" jdbcType="TIMESTAMP" property="lastlogin" />
  </resultMap>
  <delete id="deleteByPrimaryKey" parameterType="java.lang.Integer">
    delete from teacher
    where tid = #{tid,jdbcType=INTEGER}
  </delete>
  <insert id="insert" parameterType="xyz.shiguangliang.mybatis.domain.User">
    insert into teacher (tid, username, password, 
      teachername, dno, power, 
      intimes, lastlogin)
    values (#{tid,jdbcType=INTEGER}, #{username,jdbcType=VARCHAR}, #{password,jdbcType=VARCHAR}, 
      #{teachername,jdbcType=VARCHAR}, #{dno,jdbcType=INTEGER}, #{power,jdbcType=INTEGER}, 
      #{intimes,jdbcType=INTEGER}, #{lastlogin,jdbcType=TIMESTAMP})
  </insert>
  <update id="updateByPrimaryKey" parameterType="xyz.shiguangliang.mybatis.domain.User">
    update teacher
    set username = #{username,jdbcType=VARCHAR},
      password = #{password,jdbcType=VARCHAR},
      teachername = #{teachername,jdbcType=VARCHAR},
      dno = #{dno,jdbcType=INTEGER},
      power = #{power,jdbcType=INTEGER},
      intimes = #{intimes,jdbcType=INTEGER},
      lastlogin = #{lastlogin,jdbcType=TIMESTAMP}
    where tid = #{tid,jdbcType=INTEGER}
  </update>
  <select id="selectByPrimaryKey" parameterType="java.lang.Integer" resultMap="BaseResultMap">
    select tid, username, password, teachername, dno, power, intimes, lastlogin
    from teacher
    where tid = #{tid,jdbcType=INTEGER}
  </select>
  <select id="selectAll" resultMap="BaseResultMap">
    select tid, username, password, teachername, dno, power, intimes, lastlogin
    from teacher
  </select>
    <select id="selectLogin" resultType="xyz.shiguangliang.mybatis.domain.User">
        select tid, username, password, teachername, dno, power, intimes, lastlogin
        from teacher
        where username = #{username} and password = #{password}
    </select>
  <select id="selectUsername" resultType="xyz.shiguangliang.mybatis.domain.User">
    select tid, username, password, teachername, dno, power, intimes, lastlogin
        from teacher
        where username = #{username}
  </select>
  <select id="selectUserListLimit" resultType="xyz.shiguangliang.mybatis.domain.User">
    select tid, username, password, teachername, dno, power, intimes, lastlogin
    from teacher
    where
    /*条件判断*/
    <if test="#{query} != null and #{query} != ''">
      /*模糊查询*/
      <bind name="query2" value="'%' + query + '%'"/>
      username like #{query2}
    </if>
    LIMIT #{start},#{end}
  </select>
  <select id="selectUserListLimitSize" resultType="java.lang.Integer">
    select count(*)
    from teacher
    where
    /*条件判断*/
    <if test="#{query} != null and #{query} != ''">
      /*模糊查询*/
      <bind name="query2" value="'%' + query + '%'"/>
      username like #{query2}
    </if>
  </select>
</mapper>

系统模块划分和部分截图

学生角色

  • 首页
    在这里插入图片描述
    展示当前所有项目的信息,还包括当前科技项目的时间阶段,包括项目申报阶段,中期检查阶段和项目结题阶段

  • 学生项目申报
    在这里插入图片描述
    学生根据项目情况,可以进行项目的申报,填写对应的信息和上传对应的文件和附件,提供即可申报一次项目,学生还可以查看自己所有的申报的项目列表:
    在这里插入图片描述

  • 学生项目中期检查
    在这里插入图片描述
    待刚刚申报的项目完成之后,由教师角色进行审核通过之后,等到项目中期阶段,学生就可以登录到项目进行填写中期项目检查申请,同时还可以查看到自己所有项目的中期检查列表:
    在这里插入图片描述

  • 项目结题
    待教师登录系统进行中期检查通过之后,学生完成项目设计,待结题时间阶段,学生可以进行项目结题的申请,学生提交项目结题的材料信息,进行项目结题申报:
    在这里插入图片描述

  • 用户基本设置
    学生可以对自己的个人的基本信息进行修改和密码修改等:
    在这里插入图片描述

教师角色

在这里插入图片描述
教师角色登录到系统中,首页展示项目的所有信息,同时可以对项目的监控,若学生提交项目信息,会有消息提醒代办业务:
在这里插入图片描述

  • 项目审核
    在这里插入图片描述
    教师可以对项目的申报,中期和结题的不同阶段进行审核,不同阶段的项目会在不同的列表中显示进行审核,对不同项目的审核,需要提交不同的审核意见,比如对项目审报的审核,会有下面的审核意见:
    在这里插入图片描述

  • 项目设置
    在这里插入图片描述
    教师可以对此次科研项目时间不同阶段进行设置

  • 管理员模块
    管理员角色就是对教师模块增加用户(包括学生和教师)管理,可以实现增加用户和修改用户

适用场景

在这里插入图片描述

原文链接:https://www.cnblogs.com/projecthelp/p/17374561.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:23基于java教师科研项目管理系统 - Python技术站

(0)
上一篇 2023年5月5日
下一篇 2023年5月5日

相关文章

  • java怎么连接并访问activemq

    要连接并访问ActiveMQ,需要经历以下几个步骤: 获取ActiveMQ连接工厂对象 创建连接对象 创建会话对象 创建消息对象 发送或接收消息 以下是Java连接并访问ActiveMQ的完整攻略: 1. 引入依赖 首先,需要引入ActiveMQ的依赖包。可以在项目的pom.xml中添加以下代码: <dependency> <groupId…

    Java 2023年5月26日
    00
  • Java的Swing编程中使用SwingWorker线程模式及顶层容器

    Java的Swing编程中,使用SwingWorker线程模式以及顶层容器可以实现多线程的UI操作,避免了长时间运行的任务卡住了界面的情况。下面将详细介绍如何使用SwingWorker线程模式及顶层容器进行Swing编程。 一、SwingWorker线程模式 SwingWorker是Java提供的一个工具类,用于在后台线程中执行耗时的任务,并在任务完成后通知…

    Java 2023年5月26日
    00
  • Java Hibernate使用SessionFactory创建Session案例详解

    下面是详细讲解“Java Hibernate使用SessionFactory创建Session案例详解”的攻略,包括了相关的示例代码。 什么是SessionFactory? SessionFactory是Hibernate框架中一个重要的接口,用来创建Session。在使用Hibernate进行开发时,我们通常都会使用SessionFactory来获取一个S…

    Java 2023年5月19日
    00
  • Hibernate映射文件id的generator配置方法

    Hibernate是一种Java对象关系映射框架,可以将Java类与数据库表进行映射,并提供了一系列实用的操作数据库的API。在Hibernate中,映射文件是一个非常重要的概念,其中id的generator是映射文件中的一个核心配置项。本文将针对Hibernate映射文件id的generator配置方法,提供详细的攻略。 什么是id和generator? …

    Java 2023年5月31日
    00
  • C#使用动态规划解决0-1背包问题实例分析

    C#使用动态规划解决0-1背包问题实例分析 1. 什么是0-1背包问题? 0-1背包问题是一种典型的NP完全问题,指的是有一个固定容量的背包,若干个物品,每个物品有自己的价值和重量。将部分物品装进背包,使背包装下的物品总价值最大。其中每个物品要么放入背包中,要么不放入,不能拆分物品进行装载。 2. 解决0-1背包问题的动态规划算法 动态规划算法是一种求解复杂…

    Java 2023年5月19日
    00
  • JQuery+Ajax+Struts2+Hibernate框架整合实现完整的登录注册

    整合框架是我们在Web开发中常用的一种方式,可以实现前端与后端的无缝集成,使得开发流程更加高效和方便。在本文中,我们将讲解如何使用jQuery、Ajax、Struts2和Hibernate框架实现一个完整的登录注册功能。以下是实现步骤。 步骤一:后端框架搭建 创建基础项目 使用Eclipse等IDE创建一个基础的Web项目,包含基本的配置文件和文件夹,例如w…

    Java 2023年5月20日
    00
  • Java Spring AOP详解

    Java Spring AOP详解 什么是 AOP AOP (Aspect-Oriented Programming) 是一种编程思想,它将程序模块化分成维护和开发,可以让我们专注于业务逻辑处理,解决了代码耦合、代码重复等问题。 AOP 的原理就是通过将特性从业务逻辑中分离出来,在运行时动态地将它们与适当的程序节点关联起来。 AOP 的优点 AOP 为项目带…

    Java 2023年5月19日
    00
  • Scala方法与函数使用和定义详解

    Scala方法与函数使用和定义详解 简介 在Scala编程语言中,方法和函数都是非常重要的概念,也是广泛使用的编程语言要素。尽管两者看似非常相似,但是它们在写法和用法上还是存在一定的差异。本篇文章将详细讲解Scala中方法与函数的定义和使用。 方法 在Scala中,方法是指带有名称和参数的代码块,方法可以通过类或对象进行调用。Scala中的方法可以有返回值,…

    Java 2023年5月26日
    00
合作推广
合作推广
分享本页
返回顶部