今天为大家分享一个java语言编写的web版本的学生管理系统,目前系统功能已经很全面,后续会进一步完善。整个系统界面漂亮,有完整得源码,希望大家可以喜欢。喜欢的帮忙点赞和关注。一起编程、一起进步

开发环境

开发语言为Java,开发环境Eclipse或者IDEA都可以。数据库采用:MySQL。

本项目是基于MVC的JSP技术进行的Web应用程序开发,其中

  • JSP技术为表示层,包括EL表达式、JSP动作、JSTL标准标签技术
  • Servlet为控制层技术
  • JavaBean为开发模型层
  • 采用MVC设计模式对各个模块进行开发
  • 数据库采用mysql数据库
  • 采用Tomcat作为Web服务器
  • 火狐浏览器,360浏览器,Chrome浏览器,IE浏览器做为本次程序的运行浏览器

系统框架

利用SP+JAVABEAN+SERVLET框架开发。MySQL数据库,简单web模式,启动tomcat后,在浏览器中输入http://127.0.0.1:8080/studentmanage

主要功能

1 开发背景

随着高校的扩招,需要处理的学生信息日趋加大,不仅花费大量的教师资源,处理的效率还十分低下。为提高学生管理的管理水平,优化资源,尽可能降低管理成本成为学生管理的新课题,学生管理系统是从学生管理现状出发,根据学生管理的新要求进行开发设计的,它解决了学生管理数据信息量大,修改不方便,对一系列数据进行分析时花费时间长等问题,帮助学生管理人员有效管理学生信息,成为管理高校中必不可少的管理工具

2 主要模块

系统中分两类系统管理员和普通学生。系统管理员能对系统中的学生进行查询,增加,删除,修改,分页显示。系统功能模块如下图2-1所示




java 内容管理系统代码 javaweb简单管理系统源码_信息管理系统


3 主要实现原理

采用的是jsp+JavaBean+Servlet设计模式,这个模式的图如下


java 内容管理系统代码 javaweb简单管理系统源码_学生管理系统_02


4 数据库设计

系统中存在两个表,分别是系统管理员表和普通用户表,他们的结构分别如下学生表t_student


字段名称

数据类型

长度

是否允许空

是否为主键

字段描述

id

INT

11

ID

username

VARCHAR

255

用户名

xuehao

VARCHAR

255

学号

sex

VARCHAR

255

性别

age

VARCHAR

255

年龄

zhuanye

VARCHAR

255

专业

banji

INT

11

班级

tel

VARCHAR

255

电话


管理员表t_admin


字段名称

数据类型

长度

是否允许空

是否为主键

字段描述

userId

INT

11

ID

userName

VARCHAR

255

用户名

userPw

VARCHAR

255

密码


实现效果

1 管理登录

管理员输入用户名和密码,校验通过后,进入后台主界面;校验失败则进入提示用户名或者密码错。


java 内容管理系统代码 javaweb简单管理系统源码_课程设计_03


2 学生添加

管理员添加学生的时候,需要输入学号,姓名,性别,年龄,专业,电话,年龄等信息,校验通过后,跳转到学生管理界面;校验失败则进入提示相应的原因。


java 内容管理系统代码 javaweb简单管理系统源码_课程设计_04


3 学生修改

管理员在学生管理界面,选择一种学生信息进行修改,修改学生的时候,需要输入学号,姓名,性别,年龄,专业,电话,年龄等信息,校验通过后,跳转到学生管理界面;校验失败则进入提示相应的原因。


java 内容管理系统代码 javaweb简单管理系统源码_信息管理系统_05


4 分页查询学生信息

当查询学生信息的时候,符合条件的学生记录数据有多条的时候,分页技术是一个难点,分页技术的主要实现步骤有以下几个步骤。

1 根据符合的条件到数据库中查询,利用count(*)函数统计出符合条件的函数

2 根据每页5条件,根据总记录数,计算出符合条件的页面数量。计算公式为

(int) Math.ceil(totalrecord/5.0);

3 把查询出来的list记录传递到页面的前台进行显示


java 内容管理系统代码 javaweb简单管理系统源码_学生管理系统_06


关键代码

public Double getTotalCnt(String username,String xuehao) throws Exception {        
        Double returncnt=0.0;
        String sql=" select * from t_user where 1=1 ";
        if(username!=null&&!username.equalsIgnoreCase("")&&!username.equalsIgnoreCase("null")){
            sql+=" and username like '%"+username.trim()+"%'  ";
        }
        
        if(xuehao!=null&&!xuehao.equalsIgnoreCase("")&&!xuehao.equalsIgnoreCase("null")){
            sql+=" and xuehao like '%"+username.trim()+"%'  ";
        }
        Object[] params = {};
        DB mydb = new DB();
        try {
            mydb.doPstm(sql, params);
            ResultSet rs = mydb.getRs();
            while (rs.next()) {
                returncnt=returncnt+1.0;
            }
            rs.close();
        } catch (Exception e) {
            e.printStackTrace();
        }
        mydb.closed();
        return returncnt;
    }