Servlet练习
练习准备
编写Student和StudentDao
package beans;public class Student{private String num;private String name;public Student(){}public String getNum() {return num;}public String getName() {return name;}public void setNum(String num) {this.num = num;}public void setName(String name) {this.name = name;}
}
package dao;import beans.Student;import java.sql.*;
import java.util.ArrayList;public class StudentDao{private Connection conn = null;public void initConnection() throws Exception {//连接mysqlClass.forName("com.mysql.cj.jdbc.Driver");conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/javaee", "root", "123456");}//返回所有学生public ArrayList<Student> getAllStudents() throws Exception{ArrayList<Student> all = new ArrayList<Student>();initConnection();String sql = "select * from java2022";Statement st = conn.createStatement();ResultSet rs = st.executeQuery(sql);while(rs.next()){Student stu = new Student();stu.setNum(rs.getString("num"));stu.setName(rs.getString("name"));all.add(stu);}closeConnection();return all;}//添加学生public void addStudent(String num , String name) throws Exception {initConnection();String sql1 = "select * from java2022 where num =?";PreparedStatement ps1 = conn.prepareStatement(sql1);ps1.setString(1, num);ResultSet rs = ps1.executeQuery();if (!rs.next()){String sql = "insert into java2022(num,name) value(?,?)";PreparedStatement ps = conn.prepareStatement(sql);ps.setString(1, num);ps.setString(2, name);ps.executeUpdate();}closeConnection();}//查找学生public Student findStudent(String num) throws Exception {initConnection();String sql = "select * from java2022 where num=?";PreparedStatement ps = conn.prepareStatement(sql);ps.setString(1, num);ResultSet rs = ps.executeQuery();Student student = new Student();if(rs.next()){student.setNum(rs.getString("num"));student.setName(rs.getString("name"));}closeConnection();return student;}//修改学生public void updateStudent(String num, String name) throws Exception {initConnection();String sql = "update java2022 set name=? where num=?";PreparedStatement ps = conn.prepareStatement(sql);ps.setString(1, name);ps.setString(2, num);ps.executeUpdate();closeConnection();}//删除学生public void deleteStudent(String num) throws Exception {initConnection();String sql = "delete from java2022 where num=?";PreparedStatement ps = conn.prepareStatement(sql);ps.setString(1, num);ps.executeUpdate();closeConnection();}public void closeConnection() throws SQLException {conn.close();}
}
一、显示所有专业信息
- 在src下新建servlet包;
- 在该包下新建Servlet,命名ShowAllStudentsServlet,该Servlet用来查询所有学生信息,并使用session保存所有学生信息,保存之后跳转到showAllStudents.jsp文件;
- showAllStudents.jsp文件用于获取并显示所有学生信息
package servlet;import beans.Student;
import dao.StudentDao;
import jakarta.servlet.annotation.WebServlet;
import jakarta.servlet.http.HttpServlet;
import jakarta.servlet.http.HttpServletRequest;
import jakarta.servlet.http.HttpServletResponse;
import jakarta.servlet.http.HttpSession;import java.io.IOException;
import java.util.ArrayList;@WebServlet(name = "showAllStudentServlet1", value = "/showAllStudentServlet1")
public class ShowAllStudentServlet1 extends HttpServlet {protected void service(HttpServletRequest request, HttpServletResponse reponse) throws IOException {HttpSession session = request.getSession();StudentDao studentDao = new StudentDao();try {ArrayList<Student> students = studentDao.getAllStudents();session.setAttribute("students", students);} catch (Exception e) {throw new RuntimeException(e);}reponse.sendRedirect("showAllStudents1.jsp");}}
<%@ page import="beans.Student" %>
<%@ page import="java.util.ArrayList" %>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head><title>显示所有学生信息</title>
</head>
<body>
<a href="addNum1.jsp">添加学号 > </a>
<table border="1"><tr><td>学号num</td><td>姓名name</td><td>编辑</td></tr><%ArrayList<Student> students = (ArrayList) session.getAttribute("students");if(students == null){students = new ArrayList<>();session.setAttribute("students", students);}else {//for(Student student : students){student.getNum()}for(int i=0; i<students.size(); i++) {out.println("<tr>");out.println("<td>"+students.get(i).getNum()+"</td>");out.println("<td>"+students.get(i).getName()+"</td>");out.println("<td>");out.println("<a href='findStudentByNumServlet1?num="+students.get(i).getNum()+"'>修改</a>");out.println("<a href='deleteStudentServlet1?num="+students.get(i).getNum()+"'>删除</a>");out.println("</td>");out.println("</tr>");}}%>
</table>
</body>
</html>
二、增加新学号功能实现
- 新建Servlet,命名AddStudentServlet,AddStudentServlet文件获取所输入的学生信息,使用JDBC将信息添加到数据表java2022,添加完成跳转到ShowAllStudentsServlet
- 用户点击“添加新学号”链接,页面跳转到addNum.jsp页面,在该页面中输入学生信息,点击确认按钮,跳转到AddStudentServlet,完成新专业的添加
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head><title>添加学号</title>
</head>
<body>
<form action="addStudentServlet1" method="post">学号:<input type="text" name="num"><br>姓名:<input type="text" name="name"><br><input type="submit" value="添加">
</form>
</body>
</html>
package servlet;import dao.StudentDao;
import jakarta.servlet.annotation.WebServlet;
import jakarta.servlet.http.HttpServlet;
import jakarta.servlet.http.HttpServletRequest;
import jakarta.servlet.http.HttpServletResponse;import java.io.IOException;
import java.sql.*;@WebServlet(name = "addStudentServlet1", value = "/addStudentServlet1")
public class AddStudentServlet1 extends HttpServlet {protected void service(HttpServletRequest request, HttpServletResponse response) throws IOException {String num = request.getParameter("num");String name = request.getParameter("name");StudentDao studentDao = new StudentDao();try {studentDao.addStudent(num, name);} catch (Exception e) {throw new RuntimeException(e);}response.sendRedirect("showAllStudentServlet1");}
}
三、根据学号num修改学生姓名name功能实现
- 用户点击“编辑”链接,跳转到FindStudentByNumServlet文件
- 新建Servlet,命名FindStudentByNumServlet,该文件查询指定Num的学生信息,并将信息保存到session中,页面重定向到updateStudent.jsp
- updateStudent.jsp文件获取session中保存的学生信息,显示并可修改指定Num的学生信息,点击提交按钮,跳转到UpdateStudentServlet文件
- 新建Servlet,命名UpdateStudentServlet,该文件获取updateStudent.jsp文件中所输入的学生信息,根据Num修改学生姓名
- 修改完成跳转到ShowAllStudentsServlet
package servlet;import beans.Student;
import dao.StudentDao;
import jakarta.servlet.annotation.WebServlet;
import jakarta.servlet.http.HttpServlet;
import jakarta.servlet.http.HttpServletRequest;
import jakarta.servlet.http.HttpServletResponse;
import jakarta.servlet.http.HttpSession;import java.io.IOException;@WebServlet(name = "findStudentByNumServlet1", value = "/findStudentByNumServlet1")
public class FindStudentByNumServlet1 extends HttpServlet {protected void service(HttpServletRequest request, HttpServletResponse response) throws IOException {String num = request.getParameter("num");HttpSession session = request.getSession();StudentDao studentDao = new StudentDao();try {Student student = studentDao.findStudent(num);session.setAttribute("student", student);} catch (Exception e) {throw new RuntimeException(e);}response.sendRedirect("updateStudent1.jsp");}
}
<%@ page import="beans.Student" %>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head><title>修改信息</title>
</head>
<body>
<%Student student = (Student) session.getAttribute("student");String num = student.getNum();String name = student.getName();
%>
<form action="updateStudentServlet1">学号:<input type="text" name="num" value="<%=num%>" readonly><br>姓名:<input type="text" name="name" value="<%=name%>"><br><input type="submit" value="修改">
</form>
</body>
</html>
package servlet;import dao.StudentDao;
import jakarta.servlet.annotation.WebServlet;
import jakarta.servlet.http.HttpServlet;
import jakarta.servlet.http.HttpServletRequest;
import jakarta.servlet.http.HttpServletResponse;import java.io.IOException;@WebServlet(name = "updateStudentServlet1", value = "/updateStudentServlet1")
public class UpdateStudentServlet1 extends HttpServlet {protected void service(HttpServletRequest request, HttpServletResponse response) throws IOException {String num = request.getParameter("num");String name = request.getParameter("name");StudentDao studentDao = new StudentDao();try {studentDao.updateStudent(num, name);} catch (Exception e) {throw new RuntimeException(e);}response.sendRedirect("showAllStudentServlet1");}
}
四、根据学号num删除学生信息功能实现
- 用户点击“删除”链接,页面跳转到DeleteStudentServlet 文件
- 新建Servlet,命名DeleteStudentServlet,在该文件中获取学号num,根据学号num删除学生信息
- 删除完成跳转到ShowAllStudentsServlet
package servlet;import dao.StudentDao;
import jakarta.servlet.annotation.WebServlet;
import jakarta.servlet.http.HttpServlet;
import jakarta.servlet.http.HttpServletRequest;
import jakarta.servlet.http.HttpServletResponse;import java.io.IOException;@WebServlet(name = "deleteStudentServlet1", value = "/deleteStudentServlet1")
public class DeleteStudentServlet1 extends HttpServlet {protected void service(HttpServletRequest request, HttpServletResponse response) throws IOException {String num = request.getParameter("num");StudentDao studentDao = new StudentDao();try {studentDao.deleteStudent(num);} catch (Exception e) {throw new RuntimeException(e);}response.sendRedirect("showAllStudentServlet1");}
}
相关文章:

Servlet练习
练习准备 编写Student和StudentDao package beans;public class Student{private String num;private String name;public Student(){}public String getNum() {return num;}public String getName() {return name;}public void setNum(String num) {this.num num;}public v…...

美国高速公路信号灯控制项目的大致逻辑和步骤 智慧公路设计
美国高速公路信号灯控制项目的大致逻辑和步骤: 美国那边先提供一个关于具体做什么需求、那边的设备(信号灯)有什么参数,什么接口,分别是什么属性等等的详细设计文档,开发人员拿到这个文档以后把它看懂&…...

数字电源专用IC,国产C2000, QX320F280049
一、特性参数 1、独立双核,32位CPU,单核主频400MHz 2、IEEE 754 单精度浮点单元 (FPU) 3、三角函数单元 (TMU) 4、1MB 的 FLASH (ECC保护) 5、1MB 的 SRAM (ECC保护&…...

第六章 ARM汇编语言程序设计【嵌入式系统】
第六章 ARM汇编语言程序设计【嵌入式系统】前言推荐第六章 ARM汇编语言程序设计6.1 概述6.2 ARM汇编语言指示符6.3 ARM编程举例6.4 ARM过程调用6.5 典型举例6.6 内嵌汇编C与汇编相互调用最后前言 以下内容源自《【嵌入式系统】》 仅供学习交流使用 推荐 无 第六章 ARM汇编语…...

详细讲讲Java线程的状态
TERMINATED状态 是什么状态? 在Java线程的生命周期中,TERMINATED状态是线程的最终状态,表示线程已经执行完毕并已经退出。当一个线程完成了它的工作,或者因为异常而提前结束时,它会进入TERMINATED状态。此时线程不再执…...

企业月结快递管理教程
回答这个问题的之前,我们先来看看什么是企业月结快递管理...... 经济的发展,技术的进步,电商行业的加持之下,这几年快递行业的发展有目共睹。不仅是我们的生活离不开快递,很多企业的运作多多少少也离不开“快递”二字…...

cm cdp告警 Swap Memory Usage Suppress...
原因:服务器没有关swap,服务使用了swap 在cdp集群中,一般要关掉swap,如果没有关。可以使用 下面命令设置程序尽可能不使用swap,使用swap会影响性能 修改后,重启服务就不会使用swap了 sysctl -w vm.swappi…...

3.8——友元
类的主要特点之一是信息隐藏和封装,即类的私有成员和保护成员只能在定义的范围内使用,也就是说私有成员和保护成员只能通过类的成员函数来访问。但是,有时候我们在类外也需要访问私有成员数据或保护成员数据怎么办。这时我们就要通过友元函数…...

C++ OOP Feature Conclusion (更新中)
目录 1.类与对象 1.1 基本概念(继承、封装、抽象、多态) 1.2类的声明 1.3成员函数(对象所占空间取决于数据成员,和成员函数无关) 1.4数据成员(不能在类中初始化) 1.5构造与析构函数(…...

【HTTP】Cookie、Session、Token以及Cookie优化
Cookie、Session、TokenCookie优化Cookie、Session、Token 在开始介绍Cookie安全之前,我们先来了解一下实现授权的方式。 在登录功能中,为了记住登录成功后的信息,在客户端,我们通常会使用Cookie来记录,但是…...

npm之报错:Error: EACCES: permission denied, access ‘/usr/local/lib/node_modules‘
1.报错 363 error [Error: EACCES: permission denied, rename ‘/usr/local/lib/node_modules/tldr’ -> ‘/usr/local/lib/node_modules/.tldr-8nq4AGAt’] { 363 error errno: -13, 363 error code: ‘EACCES’, 363 error syscall: ‘rename’, 363 error path: ‘/usr/…...

「SQL面试题库」 No_30 超过5名学生的课
🍅 1、专栏介绍 「SQL面试题库」是由 不是西红柿 发起,全员免费参与的SQL学习活动。我每天发布1道SQL面试真题,从简单到困难,涵盖所有SQL知识点,我敢保证只要做完这100道题,不仅能轻松搞定面试࿰…...

自定义maven插件,在项目中命令启动springboot并加载当前项目资源
背景 最近在制定团队内公用的基础框架,基于单应用多module的架构思路,使用maven管理项目依赖,在项目中定义了一个springboot模块,该模块依赖具体的业务实现模块,启动后通过扫描路径下的类加载服务,业务开发…...

Linux系统【Centos7】更新内核更新软件详细教程
更新内核: 1. 打开终端,输入命令 sudo yum update,等待更新完成。 2. 重启系统,输入命令 sudo reboot。 3. 在 GRUB 引导界面,选择最新的内核版本,按下回车键进入系统。 4. 在终端中输入命令 uname -r&…...

C++ 中new/delete与malloc/free详解
文章目录前言一、new/delete1. 序言2. 使用方法2.1. new 和 delete 基本语法2.2. new 和 delete 的底层实现原理3. 底层原理3.1. operator new 和 operator delete3.2. new 和 delete 的底层实现原理4. 注意事项5. 总结二、malloc/free1. 序言2. 使用方法2.1. malloc 和 free 基…...

crm软件哪个好?该如何选择?
crm软件哪个好?该如何选择? 首先我们需要明确一下什么是好的CRM系统,优质的CRM系统应该具备以下优势: 1)提高销售效率:通过CRM系统,销售人员可以跟踪客户互动历史和交易记录,了解客…...

蓝桥杯第22天(Python)(疯狂刷题第5天)
题型: 1.思维题/杂题:数学公式,分析题意,找规律 2.BFS/DFS:广搜(递归实现),深搜(deque实现) 3.简单数论:模,素数(只需要…...

软件测试面试常问的问题有哪些?
互联发展是很快的,每年都会有新语言的诞生。 我干测试已经三年了,主要负责web功能测试,java编写接口自动化,APP功能测试,APP 接口自动化(也是用的java),面过得测试也差不多30个&…...

js之文件信息读取篇高级基础
文章目录js之文件信息读取(FileReader)获取文件相关信息的两种方式js原生拖拽事件js之文件信息读取(FileReader) 首先这里面会讲一些知识点 bolb 对象FileReader对象 let blob new Blob([heewwekgewgwer], { type: text/plain …...

SQL Server的死锁说明
死锁指南一、了解死锁二、检测并结束死锁2.1、可能死锁的资源三、处理死锁四、最大限度地减少死锁4.1、以相同的顺序访问对象4.2、避免事务中的用户交互4.3、保持交易简短且在一个批次中4.4、使用较低的隔离级别4.5、使用基于行版本控制的隔离级别4.6、使用绑定连接4.7、停止事…...

关于#define的一些小知识
目录 一,#define的声明格式: 二,#define宏的作用是为了完成替换 #define的替换规则: 三,#define使用时常犯的错误 四,宏与函数的比较 4.1,什么时候使用宏? 4.1,…...

rabbitmq普通集群与镜像集群搭建
1.准备三台centos7主机,并关闭防火墙与selinux 2.安装rabbitmq环境必备的Erlang(以下所有操作三台主机均需要执行) 执行以下命令下载配置erlang yum源 curl -s https://packagecloud.io/install/repositories/rabbitmq/erlang/script.rpm.sh | sudo bash使用yum命…...

session和jwt哪个更好
session和jwtsession优点缺点jwt优点缺点总结session 优点 原理简单,易于学习。用户信息存储在服务端,可以快速封禁某个用户。 缺点 占用服务端内存,硬件成本高。多进程,多服务器时,不好同步-需要使用第三方缓存&a…...

基于TPU-MLIR实现UNet模型部署-决赛答辩02
队伍:AP0200023 目录 初赛 一、 模型导出优化 1.1 直接倒出原始模型并转换 1.2 导出模型前处理 1.2.1 导出Resize 1.2.2 导出归一化 1.3导出模型后处理 1.3.1导出 Resize 与 1.3.2导出 ArgMaxout 1.3.3导出特征转RGB 复赛 一、 确定baseline 二、优化模…...

Maven高级-分模块开发依赖管理
Maven高级-分模块开发&依赖管理1,分模块开发1.1 分模块开发设计1.2 分模块开发实现1.2.1 环境准备1.2.2 抽取domain层步骤1:创建新模块步骤2:项目中创建domain包步骤3:删除原项目中的domain包步骤4:建立依赖关系步骤5:编译maven_02_ssm项目步骤6:将项目安装本地…...

《安富莱嵌入式周报》第308期:开源带软硬件安全认证的PLC设计,开源功率计,可靠PID实现,PR2机器人设计文件全开源,智能手表设计WASP-OS
周报汇总地址:嵌入式周报 - uCOS & uCGUI & emWin & embOS & TouchGFX & ThreadX - 硬汉嵌入式论坛 - Powered by Discuz! 视频版: https://www.bilibili.com/video/BV1F24y157QE 《安富莱嵌入式周报》第308期:开源带软…...

代码随想录算法训练营第五十六天 | 583. 两个字符串的删除操作、72. 编辑距离、编辑距离总结
583. 两个字符串的删除操作 动规五部曲 1、确定dp数组(dp table)以及下标的含义 dp[i][j]:以i-1为结尾的字符串word1,和以j-1位结尾的字符串word2,想要达到相等,所需要删除元素的最少次数。 2、确定递推…...

Sip协议
简介 SIP(Session Initiation Protocol,会话初始协议)是一个用于建立、更改和终止多媒体会话的应用 层控制协议,其中的会话可以是 IP 电话、多媒体会话或多媒体会议。SIP 是 IETF 多媒体数据和控 制体系结构的核心协议࿰…...

RandomAccessFile类 断点续传
文章目录学习链接RandomAccessFile构造方法实现的接口DataOutputDataInputAutoCloseable重要的方法多线程读写同一个文件(多线程复制文件)代码1代码2断点续传FileUtils学习链接 RandomAccessFile详解 Java IO——RandomAccessFile类详解 java多线程-断点…...

SpringCloud微服务技术栈的注册中心Eureka
文章目录SpringCloud微服务技术栈的注册中心Eureka简介Eureka特点操作步骤环境准备创建Eureka Server注册服务提供方调用服务消费方总结SpringCloud微服务技术栈的注册中心Eureka 简介 在微服务架构中,服务的数量庞大,而且每个服务可能会有多个实例。此…...