IDEA+Java+Jsp+Mysql实现Web毕业设计选题系统(上)

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: IDEA+Java+Jsp+Mysql实现Web毕业设计选题系统

一、系统介绍


1.开发环境


开发工具:IDEA2018


JDK版本:Jdk1.8


Mysql版本:8.0.13


2.技术选型


Java+Jsp+Mysql


3.系统功能


1.管理员登录系统,管理学生信息,管理教师信息,管理课题信息,系统维护功能;


2.教师登录系统,修改个人信息,添加课题,查看课题;


3.学生登录系统,修改个人信息,查看选题,选择课题;


4.数据库文件

/*
 Navicat Premium Data Transfer
 Source Server         : MYSQL
 Source Server Type    : MySQL
 Source Server Version : 80013
 Source Host           : localhost:3306
 Source Schema         : jsp_select_topic
 Target Server Type    : MySQL
 Target Server Version : 80013
 File Encoding         : 65001
 Date: 12/04/2022 09:04:43
*/
SET NAMES utf8mb4;
SET FOREIGN_KEY_CHECKS = 0;
-- ----------------------------
-- Table structure for msg
-- ----------------------------
DROP TABLE IF EXISTS `msg`;
CREATE TABLE `msg`  (
  `title` varchar(100) CHARACTER SET gb2312 COLLATE gb2312_chinese_ci NOT NULL,
  `text` varchar(1000) CHARACTER SET gb2312 COLLATE gb2312_chinese_ci NULL DEFAULT NULL,
  PRIMARY KEY (`title`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = gb2312 COLLATE = gb2312_chinese_ci ROW_FORMAT = Dynamic;
-- ----------------------------
-- Records of msg
-- ----------------------------
INSERT INTO `msg` VALUES ('毕业设计选题系统初步完成', '整个系统流程大致为:老师发布课题,管理员审核\r\n\r\n课题,学生选题,学生完成设计');
INSERT INTO `msg` VALUES ('学生相关功能', '请各位学生登录系统,给自己选择一个课题!');
-- ----------------------------
-- Table structure for student_info
-- ----------------------------
DROP TABLE IF EXISTS `student_info`;
CREATE TABLE `student_info`  (
  `sno` varchar(10) CHARACTER SET gbk COLLATE gbk_chinese_ci NOT NULL,
  `sname` varchar(10) CHARACTER SET gbk COLLATE gbk_chinese_ci NOT NULL,
  `ssex` varchar(2) CHARACTER SET gbk COLLATE gbk_chinese_ci NOT NULL,
  `sclass` varchar(10) CHARACTER SET gbk COLLATE gbk_chinese_ci NOT NULL,
  `stel` varchar(11) CHARACTER SET gbk COLLATE gbk_chinese_ci NOT NULL,
  `semail` varchar(50) CHARACTER SET gbk COLLATE gbk_chinese_ci NULL DEFAULT NULL,
  `sgroup` varchar(1) CHARACTER SET gbk COLLATE gbk_chinese_ci NOT NULL,
  `spassword` varchar(10) CHARACTER SET gbk COLLATE gbk_chinese_ci NOT NULL COMMENT '6-10位字符',
  PRIMARY KEY (`sno`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = gbk COLLATE = gbk_chinese_ci ROW_FORMAT = Dynamic;
-- ----------------------------
-- Records of student_info
-- ----------------------------
INSERT INTO `student_info` VALUES ('1001', '张三', '男', '4', '15523457667', '336688@qq.com', '2', '123456');
INSERT INTO `student_info` VALUES ('1002', '李四', '男', '2', '14456789876', '6699334@qq.com', '2', '123456');
INSERT INTO `student_info` VALUES ('1003', '王五', '男', '3', '14456789876', '6699334@qq.com', '3', '123456');
INSERT INTO `student_info` VALUES ('1004', '赵六', '男', '3', '14456789876', '6699334@qq.com', '3', 'admin');
-- ----------------------------
-- Table structure for teacher_info
-- ----------------------------
DROP TABLE IF EXISTS `teacher_info`;
CREATE TABLE `teacher_info`  (
  `tno` varchar(10) CHARACTER SET gbk COLLATE gbk_chinese_ci NOT NULL,
  `tname` varchar(10) CHARACTER SET gbk COLLATE gbk_chinese_ci NOT NULL,
  `tsex` varchar(2) CHARACTER SET gbk COLLATE gbk_chinese_ci NULL DEFAULT NULL,
  `tdept` varchar(20) CHARACTER SET gbk COLLATE gbk_chinese_ci NOT NULL,
  `tdegree` varchar(8) CHARACTER SET gbk COLLATE gbk_chinese_ci NULL DEFAULT NULL,
  `ttitle` varchar(4) CHARACTER SET gbk COLLATE gbk_chinese_ci NULL DEFAULT NULL,
  `tright` bit(1) NOT NULL,
  `ttel` varchar(11) CHARACTER SET gbk COLLATE gbk_chinese_ci NOT NULL,
  `temail` varchar(50) CHARACTER SET gbk COLLATE gbk_chinese_ci NULL DEFAULT NULL,
  `tgroup` varchar(1) CHARACTER SET gbk COLLATE gbk_chinese_ci NOT NULL,
  `tpassword` varchar(10) CHARACTER SET gbk COLLATE gbk_chinese_ci NOT NULL,
  PRIMARY KEY (`tno`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = gbk COLLATE = gbk_chinese_ci ROW_FORMAT = Dynamic;
-- ----------------------------
-- Records of teacher_info
-- ----------------------------
INSERT INTO `teacher_info` VALUES ('101', 'admin', '男', '计算机科学与技术系', '硕士', '教授', b'0', '15315614829', '12345678@qq.com', '4', 'admin');
INSERT INTO `teacher_info` VALUES ('102', '王老师', '男', '计算机科学与技术系', '硕士', '教授', b'1', '15315614829', '1234567844@qq.com', '4', '123456');
INSERT INTO `teacher_info` VALUES ('103', '李老师', '男', '计算机科学与技术系', '硕士', '助教', b'1', '13456789876', '1234567844@qq.com', '4', 'admin');
-- ----------------------------
-- Table structure for topic_info
-- ----------------------------
DROP TABLE IF EXISTS `topic_info`;
CREATE TABLE `topic_info`  (
  `hno` varchar(5) CHARACTER SET gbk COLLATE gbk_chinese_ci NOT NULL,
  `hname` varchar(50) CHARACTER SET gbk COLLATE gbk_chinese_ci NOT NULL,
  `htype` varchar(10) CHARACTER SET gbk COLLATE gbk_chinese_ci NOT NULL,
  `hkind` varchar(10) CHARACTER SET gbk COLLATE gbk_chinese_ci NOT NULL,
  `hsource` varchar(10) CHARACTER SET gbk COLLATE gbk_chinese_ci NOT NULL,
  `hstatus` varchar(5) CHARACTER SET gbk COLLATE gbk_chinese_ci NOT NULL,
  `hcontent` varchar(200) CHARACTER SET gbk COLLATE gbk_chinese_ci NOT NULL,
  `hresult` varchar(50) CHARACTER SET gbk COLLATE gbk_chinese_ci NOT NULL,
  `direction` varchar(200) CHARACTER SET gbk COLLATE gbk_chinese_ci NULL DEFAULT NULL,
  `tno` varchar(10) CHARACTER SET gbk COLLATE gbk_chinese_ci NOT NULL,
  `sno` varchar(10) CHARACTER SET gbk COLLATE gbk_chinese_ci NULL DEFAULT NULL,
  PRIMARY KEY (`hno`) USING BTREE,
  INDEX `FK_topicinfo`(`sno`) USING BTREE,
  INDEX `FK_topicinfo1`(`tno`) USING BTREE,
  CONSTRAINT `FK_topicinfo` FOREIGN KEY (`sno`) REFERENCES `student_info` (`sno`) ON DELETE RESTRICT ON UPDATE RESTRICT,
  CONSTRAINT `FK_topicinfo1` FOREIGN KEY (`tno`) REFERENCES `teacher_info` (`tno`) ON DELETE RESTRICT ON UPDATE RESTRICT
) ENGINE = InnoDB CHARACTER SET = gbk COLLATE = gbk_chinese_ci ROW_FORMAT = Dynamic;
-- ----------------------------
-- Records of topic_info
-- ----------------------------
INSERT INTO `topic_info` VALUES ('10001', '计算机技术体系研究', '毕业设计', '理论研究', '结合科研', 'true', '计算机技术体系研究', 'SCI发表相应论文', '无', '102', '1001');
INSERT INTO `topic_info` VALUES ('10002', '软件工程体系研究', '毕业设计', '软件研究', '结合科研', 'true', '软件工程体系研究', 'SCI发表论文', '无', '102', '1002');
SET FOREIGN_KEY_CHECKS = 1;


5.工程截图


d0ab6292f146474aa3a778cdc9b7a64f.jpg


二、系统展示


1.登录系统


ab000362e12c44529c0aba4463ad3529.jpg


2.管理员-主页面


1666280198e74fabbd3b4ca431b4fb36.jpg


3.管理员-学生管理-查看所有


image.jpeg


4.管理员-学生管理-添加学生


image.jpeg


5.管理员-教师管理-查看所有


6c31f507235141c79546a1efb632d1f4.jpg


6.管理员-教师管理-添加教师


610ebbb4768940adae091170ed90b4ff.jpg


7.管理员-课程管理-课程查询


86a377c10f53404ba147944a4628b9ef.jpg


8.管理员-课程管理-课程审核


a87248288f7547f0bc4b2200dd30a423.jpg


9.管理员-系统维护-添加公告


b7f5314872fb442690f602abb75945c1.jpg


10.管理员-系统维护-查看公告


5064f7ebd21c4ecf9543b8a710110ed7.jpg


11.管理员-系统维护-教师功能开关


92add5be8ded4e9eade2222b56e5c567.jpg


12.管理员-系统维护-学生功能开关


b955101652c2426cb40fc2aecc57c090.jpg


13.教师-主页面


835ac96f43a3465aab29377936274a43.jpg


14.教师-个人中心-修改资料


480a1a08142342adb8c26beb26367529.jpg


15.教师-课题管理-所有课题


bb023a85c16846bea90abdddd0a83879.jpg


16.教师-课题管理-我的课题


c7073f2010f64b0eb015a4ebe5d09cde.jpg


17.教师-课题管理-添加课题


6b1933c29d574a9092024e883eb66706.jpg


18.学生-主页面


7cf16e22d4424a9e85d0f40e95ffdab0.jpg


19.学生-个人中心-修改资料


6781efc5eb9d4fc98d963d2386e2bbb0.jpg


20.学生-个人中心-我的选题


d259d2a0407c499bb6990bd9b4e0d17c.jpg


21.学生-开始选题-选题列表


1d52effca7114d4a84c914d2c3aeb885.jpg


22.学生-开始选题-选题明细


b8142144f8a4469c9801b574254e8f6d.jpg


三、部分代码


StudentManager


学生信息管理类,实现学生信息的增加,查看,删除

package com.sjsq.service;
import com.sjsq.model.Student;
import com.sjsq.util.DB;
import jxl.Cell;
import jxl.Sheet;
import jxl.Workbook;
import jxl.read.biff.BiffException;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.sql.*;
import java.util.ArrayList;
import java.util.List;
public class StudentManager {
    /**
     * 添加新的单个Student信息到数据库中
     * @param stu 存有学生信息的Student对象
     * @return 保存成功返回true否则返回false
     */
    public static boolean save(Student stu) {
        Connection conn = DB.getConn();
        String sql = null;
        boolean b = false;
        sql = "insert into student_info values (?, ?, ?, ?, ?, ?, ?, ?)";
        PreparedStatement pstmt = DB.prepare(conn, sql);//预编译插入语句
        try {
            /*
             * 将stu中保存的信息分别放到数据库中对应表的对应列上
             */
            pstmt.setString(1, stu.getNumber());
            pstmt.setString(2, stu.getName());
            pstmt.setString(3, stu.getSex());
            pstmt.setString(4, stu.getSclass());
            pstmt.setString(5, stu.getPhone());
            pstmt.setString(6, stu.getEmail());
            pstmt.setString(7, stu.getGroup());
            pstmt.setString(8, stu.getPassword());
            pstmt.execute();
            b = true;
        } catch (SQLException e) {
            e.printStackTrace();
        } finally {
            DB.close(pstmt);
            DB.close(conn);
        }
        return b;
    }
    /**
     * 获取所以学生信息
     * @param students 存放所以学生信息
     * @param pageNo 分页时的,当前页号
     * @param pageSize  每页显示学生的个数
     * @return 返回一共有多少页
     */
    public static int getStudents(List<Student> students, int pageNo,
                                  int pageSize) {
        int totalRecords = -1;
        Connection conn = DB.getConn();
        String sql = null;
        sql = "select * from student_info limit " + (pageNo - 1) * pageSize
                + "," + pageSize;
        Statement stmt = DB.getStatement(conn);
        ResultSet rs = DB.getResultSet(stmt, sql);
        Statement stmtCount = DB.getStatement(conn);
        ResultSet rsCount = null;
        rsCount = DB.getResultSet(stmtCount,
                "select count(*) from student_info");
        try {
            rsCount.next();
            totalRecords = rsCount.getInt(1);//得到结果集中一共有多少条记录
            while (rs.next()) {
                Student student = new Student();
                student.setEmail(rs.getString("semail"));
                student.setGroup(rs.getString("sgroup"));
                student.setName(rs.getString("sname"));
                student.setNumber(rs.getString("sno"));
                student.setPassword(rs.getString("spassword"));
                student.setPhone(rs.getString("stel"));
                student.setSclass(rs.getString("sclass"));
                student.setSex(rs.getString("ssex"));
                students.add(student);
            }
        } catch (SQLException e) {
            e.printStackTrace();
        } finally {
            DB.close(rsCount);
            DB.close(stmtCount);
            DB.close(rs);
            DB.close(stmt);
            DB.close(conn);
        }
        return totalRecords;
    }
    /**
     * 按学号删除学生
     * @param id 要删除学生的学号
     * @return 删除成功返回true否则返回false
     */
    public static boolean deleteBySno(String id) {
        boolean b = false;
        Connection conn = DB.getConn();
        String sql = null;
        sql = "delete from student_info where sno = '" + id + "'";
        Statement stmt = DB.getStatement(conn);
        try {
            DB.executeUpdate(stmt, sql);
            b = true;
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            DB.close(stmt);
            DB.close(conn);
        }
        return b;
    }
    /**
     * 检查登录时学号和密码是否真确
     * @param num 学号
     * @param password 密码
     * @return 正确返回true否则返回false
     * @throws UserNotFoundException 抛出学号不存在的异常
     * @throws PasswordNotCorrectException 抛出密码错误的异常
     */
    public static Student check(String num, String password)
            throws UserNotFoundException, PasswordNotCorrectException {
        Student student = null;
        Connection conn = DB.getConn();
        String sql = null;
        sql = "select * from student_info where sno = '" + num + "'";
        Statement stmt = DB.getStatement(conn);
        ResultSet rs = DB.getResultSet(stmt, sql);
        try {
            if (!rs.next()) {
                throw new UserNotFoundException("用户不存在:" + num);
            } else {
                if (!password.equals(rs.getString("spassword"))) {
                    throw new PasswordNotCorrectException("密码不正确!");
                }
            }
            student = new Student();
            student.setEmail(rs.getString("semail"));
            student.setGroup(rs.getString("sgroup"));
            student.setName(rs.getString("sname"));
            student.setNumber(rs.getString("sno"));
            student.setPassword(rs.getString("spassword"));
            student.setPhone(rs.getString("stel"));
            student.setSclass(rs.getString("sclass"));
            student.setSex(rs.getString("ssex"));
        } catch (SQLException e) {
            e.printStackTrace();
        } finally {
            DB.close(rs);
            DB.close(stmt);
            DB.close(conn);
        }
        return student;
    }
    /**
     * 按学号获得学生信息
     * @param num 学号
     * @return 返回该学号的学生对象
     */
    public static Student getBySno(String num) {
        Connection conn = DB.getConn();
        String sql = null;
        sql = "select * from student_info where sno='" + num + "'";
        Statement stmt = DB.getStatement(conn);
        ResultSet rs = DB.getResultSet(stmt, sql);
        Student student = null;
        try {
            if (rs.next()) {
                student = new Student();
                student.setEmail(rs.getString("semail"));
                student.setGroup(rs.getString("sgroup"));
                student.setName(rs.getString("sname"));
                student.setNumber(rs.getString("sno"));
                student.setPassword(rs.getString("spassword"));
                student.setPhone(rs.getString("stel"));
                student.setSclass(rs.getString("sclass"));
                student.setSex(rs.getString("ssex"));
            }
        } catch (SQLException e) {
            e.printStackTrace();
        } finally {
            DB.close(rs);
            DB.close(conn);
        }
        return student;
    }
    /**
     * 更新学生stu的相关信息(学号不能更新)
     * @param stu 存有新信息的学生对象
     * @return 更新成功返回true否则返回false
     */
    public static boolean update(Student stu) {
        Connection conn = DB.getConn();
        String sql = null;
        boolean b = false;
        sql = "update student_info set spassword=?, sgroup=?, sname=?, ssex=?, stel=?, semail=?, sclass=?  where sno = ?";
        PreparedStatement pstmt = DB.prepare(conn, sql);
        try {
            pstmt.setString(1, stu.getPassword());
            pstmt.setString(2, stu.getGroup());
            pstmt.setString(3, stu.getName());
            pstmt.setString(4, stu.getSex());
            pstmt.setString(5, stu.getPhone());
            pstmt.setString(6, stu.getEmail());
            pstmt.setString(7, stu.getSclass());
            pstmt.setString(8, stu.getNumber());
            pstmt.executeUpdate();
            b = true;
        } catch (SQLException e) {
            e.printStackTrace();
        } finally {
            DB.close(pstmt);
            DB.close(conn);
        }
        return b;
    }
    /**
     * 按指定的条件获得所有符合条件的学生信息
     * @param students 存放符合条件的学生信息的List
     * @param pageNo 分页显示时,当前的页号
     * @param pageSize 每页显示学生信息的数量
     * @param sclass 学生所在的班级
     * @param num 学号
     * @param name 学生姓名
     * @return 返回符合条件的学生列表
     */
    public static int query(List<Student> students, int pageNo, int pageSize,
                            String sclass, String num, String name) {
        int totalRecords = -1;
        Connection conn = DB.getConn();
        String sql = null;
        /*
         * 如何有些条件为空的进行如下处理,否则模糊查询时可能会报空指针异常
         */
        if (sclass == null)
            sclass = "";
        if (name == null)
            name = "";
        if (num == null)
            num = "";
        /*
         * 模糊查寻
         */
        sql = "select * from student_info where sclass like '%" + sclass
                + "%' and sname like '%" + name + "%' and sno like '%" + num
                + "%'";
        sql += "limit " + (pageNo - 1) * pageSize + "," + pageSize;
        Statement stmt = DB.getStatement(conn);
        ResultSet rs = DB.getResultSet(stmt, sql);
        Statement stmtCount = DB.getStatement(conn);
        ResultSet rsCount = null;
        rsCount = DB.getResultSet(stmtCount,
                "select count(*) from student_info where sclass like '%"
                        + sclass + "%' and sname like '%" + name
                        + "%' and sno like '%" + num + "%'");
        try {
            rsCount.next();
            totalRecords = rsCount.getInt(1);
            while (rs.next()) {
                Student student = new Student();
                student.setEmail(rs.getString("semail"));
                student.setGroup(rs.getString("sgroup"));
                student.setName(rs.getString("sname"));
                student.setNumber(rs.getString("sno"));
                student.setPassword(rs.getString("spassword"));
                student.setPhone(rs.getString("stel"));
                student.setSclass(rs.getString("sclass"));
                student.setSex(rs.getString("ssex"));
                students.add(student);
            }
        } catch (SQLException e) {
            e.printStackTrace();
        } finally {
            DB.close(rsCount);
            DB.close(stmtCount);
            DB.close(rs);
            DB.close(stmt);
            DB.close(conn);
        }
        return totalRecords;
    }
    /**
     * 批量导入excel表中学生的信息到数据库中(用到组件jxl.jar)
     * @param file excel表所在的相对路径或绝对路径(包括文件完整的名字)
     * @return 返回那些学号在数据库中已经存在的学号
     */
    public static List<String> adds(String file) {
        Connection conn = DB.getConn();
        List<String> snumber = new ArrayList<String>();
        Workbook info;//定义工作簿
        String sql = "insert into student_info values (?, ?, ?, ?, ?, ?, ?, ?)";
        try {
            info = Workbook.getWorkbook(new FileInputStream(file));
            Sheet   sheet   =   info.getSheet(0);//获得工作薄中表单对象
            int   size   =   sheet.getRows(); //获得表单的行数
            for(int   i   =   1;i   <   size;i++){
                Cell c = sheet.getCell(0,i);//获得表单的i行0列的单元格即学号
                /*
                 * 查看学号是否已经存在
                 */
                if(StudentManager.getBySno(c.getContents().trim())!=null) {
                    snumber.add(c.getContents().trim());
                    continue;
                }
                PreparedStatement pstmt = DB.prepare(conn, sql);
                for(int j=0; j<8; j++) {
                    c   =   sheet.getCell(j,i);
                    pstmt.setString(j+1, c.getContents().trim());
                }
                pstmt.execute();
            }
        } catch (BiffException e) {
            e.printStackTrace();
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        } catch (IndexOutOfBoundsException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        } catch (SQLException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        return snumber;
    }
}
相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
2月前
|
消息中间件 Java Kafka
Java 事件驱动架构设计实战与 Kafka 生态系统组件实操全流程指南
本指南详解Java事件驱动架构与Kafka生态实操,涵盖环境搭建、事件模型定义、生产者与消费者实现、事件测试及高级特性,助你快速构建高可扩展分布式系统。
157 7
|
19天前
|
NoSQL Java 关系型数据库
超全 Java 学习路线,帮你系统掌握编程的超详细 Java 学习路线
本文为超全Java学习路线,涵盖基础语法、面向对象编程、数据结构与算法、多线程、JVM原理、主流框架(如Spring Boot)、数据库(MySQL、Redis)及项目实战等内容,助力从零基础到企业级开发高手的进阶之路。
113 1
|
13天前
|
安全 Cloud Native Java
Java 模块化系统(JPMS)技术详解与实践指南
本文档全面介绍 Java 平台模块系统(JPMS)的核心概念、架构设计和实践应用。作为 Java 9 引入的最重要特性之一,JPMS 为 Java 应用程序提供了强大的模块化支持,解决了长期存在的 JAR 地狱问题,并改善了应用的安全性和可维护性。本文将深入探讨模块声明、模块路径、访问控制、服务绑定等核心机制,帮助开发者构建更加健壮和可维护的 Java 应用。
88 0
|
2月前
|
Java 数据库 前端开发
分享44个java系统,总有一款适合您
分享44个微信小程序,总有一款适合您
40 0
|
12月前
|
Java 容器
【学习笔记】Jsp与Servlet技术
【学习笔记】Jsp与Servlet技术
242 0
|
SQL Java 数据库
jsp中使用Servlet查询SQLSERVER数据库中的表的信息,并且打印在屏幕上
该博客文章介绍了在JSP应用中使用Servlet查询SQL Server数据库的表信息,并通过JavaBean封装图书信息,将查询结果展示在Web页面上的方法。
jsp中使用Servlet查询SQLSERVER数据库中的表的信息,并且打印在屏幕上
|
供应链 前端开发 Java
JSP+servlet+mybatis+layui服装库存管理系统(大三上学期课程设计)
这篇文章通过一个服装库存管理系统的实例,展示了在Spring Boot项目中使用Ajax、JSON、layui、MVC架构和iframe等技术,涵盖了注册登录、权限管理、用户管理、库存管理等功能,并提供了系统运行环境和技术要求的详细说明。
JSP+servlet+mybatis+layui服装库存管理系统(大三上学期课程设计)
|
自然语言处理 前端开发 Java
Servlet与JSP:Java Web开发的基石技术详解
【6月更文挑战第23天】Java Web的Servlet与JSP是动态网页的核心。Servlet是服务器端的Java应用,处理HTTP请求并响应;JSP则是结合HTML与Java代码的页面,用于动态内容生成。Servlet通过生命周期方法如`init()`、`service()`和`destroy()`工作,而JSP在执行时编译成Servlet。两者在MVC架构中分工,Servlet处理逻辑,JSP展示数据。尽管有Spring MVC等框架,Servlet和JSP仍是理解Web开发基础的关键。
262 12
|
前端开发 安全 Java
在Java服务器端开发的浩瀚宇宙中,Servlet与JSP犹如两颗璀璨的明星,它们联袂登场,共同编织出动态网站的绚丽篇章。
在Java服务器端开发的浩瀚宇宙中,Servlet与JSP犹如两颗璀璨的明星,它们联袂登场,共同编织出动态网站的绚丽篇章。
113 1
|
存储 Java 关系型数据库
基于Servlet和JSP的Java Web应用开发指南
【6月更文挑战第23天】构建Java Web应用,Servlet与JSP携手打造在线图书管理系统,涵盖需求分析、设计、编码到测试。通过实例展示了Servlet如何处理用户登录(如`LoginServlet`),JSP负责页面展示(如`login.jsp`和`bookList.jsp`)。应用基于MySQL数据库,包含用户和图书表。登录失败显示错误信息,成功后展示图书列表。部署到Tomcat服务器测试功能。此基础教程为深入Java Web开发奠定了基础。
267 10