当前位置: 首页 > news >正文

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();}
}

一、显示所有专业信息

  1. 在src下新建servlet包;
  2. 在该包下新建Servlet,命名ShowAllStudentsServlet,该Servlet用来查询所有学生信息,并使用session保存所有学生信息,保存之后跳转到showAllStudents.jsp文件;
  3. 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>

增加新学号功能实现

  1. 新建Servlet,命名AddStudentServlet,AddStudentServlet文件获取所输入的学生信息,使用JDBC将信息添加到数据表java2022,添加完成跳转到ShowAllStudentsServlet
  2. 用户点击“添加新学号”链接,页面跳转到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功能实现

  1. 用户点击“编辑”链接,跳转到FindStudentByNumServlet文件
  2. 新建Servlet,命名FindStudentByNumServlet,该文件查询指定Num的学生信息,并将信息保存到session中,页面重定向到updateStudent.jsp
  3. updateStudent.jsp文件获取session中保存的学生信息,显示并可修改指定Num的学生信息,点击提交按钮,跳转到UpdateStudentServlet文件
  4. 新建Servlet,命名UpdateStudentServlet,该文件获取updateStudent.jsp文件中所输入的学生信息,根据Num修改学生姓名
  5. 修改完成跳转到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删除学生信息功能实现

  1. 用户点击“删除”链接,页面跳转到DeleteStudentServlet 文件
  2. 新建Servlet,命名DeleteStudentServlet,在该文件中获取学号num,根据学号num删除学生信息
  3. 删除完成跳转到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…...

美国高速公路信号灯控制项目的大致逻辑和步骤 智慧公路设计

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

数字电源专用IC,国产C2000, QX320F280049

一、特性参数 1、独立双核&#xff0c;32位CPU&#xff0c;单核主频400MHz 2、IEEE 754 单精度浮点单元 &#xff08;FPU&#xff09; 3、三角函数单元 &#xff08;TMU&#xff09; 4、1MB 的 FLASH &#xff08;ECC保护&#xff09; 5、1MB 的 SRAM &#xff08;ECC保护&…...

第六章 ARM汇编语言程序设计【嵌入式系统】

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

详细讲讲Java线程的状态

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

企业月结快递管理教程

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

cm cdp告警 Swap Memory Usage Suppress...

原因&#xff1a;服务器没有关swap&#xff0c;服务使用了swap 在cdp集群中&#xff0c;一般要关掉swap&#xff0c;如果没有关。可以使用 下面命令设置程序尽可能不使用swap&#xff0c;使用swap会影响性能 修改后&#xff0c;重启服务就不会使用swap了 sysctl -w vm.swappi…...

3.8——友元

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

C++ OOP Feature Conclusion (更新中)

目录 1.类与对象 1.1 基本概念&#xff08;继承、封装、抽象、多态&#xff09; 1.2类的声明 1.3成员函数&#xff08;对象所占空间取决于数据成员&#xff0c;和成员函数无关&#xff09; 1.4数据成员&#xff08;不能在类中初始化&#xff09; 1.5构造与析构函数&#xff08…...

【HTTP】Cookie、Session、Token以及Cookie优化

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

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名学生的课

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

自定义maven插件,在项目中命令启动springboot并加载当前项目资源

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

Linux系统【Centos7】更新内核更新软件详细教程

更新内核&#xff1a; 1. 打开终端&#xff0c;输入命令 sudo yum update&#xff0c;等待更新完成。 2. 重启系统&#xff0c;输入命令 sudo reboot。 3. 在 GRUB 引导界面&#xff0c;选择最新的内核版本&#xff0c;按下回车键进入系统。 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软件哪个好&#xff1f;该如何选择&#xff1f; 首先我们需要明确一下什么是好的CRM系统&#xff0c;优质的CRM系统应该具备以下优势&#xff1a; 1&#xff09;提高销售效率&#xff1a;通过CRM系统&#xff0c;销售人员可以跟踪客户互动历史和交易记录&#xff0c;了解客…...

蓝桥杯第22天(Python)(疯狂刷题第5天)

题型&#xff1a; 1.思维题/杂题&#xff1a;数学公式&#xff0c;分析题意&#xff0c;找规律 2.BFS/DFS&#xff1a;广搜&#xff08;递归实现&#xff09;&#xff0c;深搜&#xff08;deque实现&#xff09; 3.简单数论&#xff1a;模&#xff0c;素数&#xff08;只需要…...

软件测试面试常问的问题有哪些?

互联发展是很快的&#xff0c;每年都会有新语言的诞生。 我干测试已经三年了&#xff0c;主要负责web功能测试&#xff0c;java编写接口自动化&#xff0c;APP功能测试&#xff0c;APP 接口自动化&#xff08;也是用的java&#xff09;&#xff0c;面过得测试也差不多30个&…...

js之文件信息读取篇高级基础

文章目录js之文件信息读取&#xff08;FileReader&#xff09;获取文件相关信息的两种方式js原生拖拽事件js之文件信息读取&#xff08;FileReader&#xff09; 首先这里面会讲一些知识点 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的一些小知识

目录 一&#xff0c;#define的声明格式&#xff1a; 二&#xff0c;#define宏的作用是为了完成替换 #define的替换规则&#xff1a; 三&#xff0c;#define使用时常犯的错误 四&#xff0c;宏与函数的比较 4.1&#xff0c;什么时候使用宏&#xff1f; 4.1&#xff0c;…...

rabbitmq普通集群与镜像集群搭建

1.准备三台centos7主机&#xff0c;并关闭防火墙与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 优点 原理简单&#xff0c;易于学习。用户信息存储在服务端&#xff0c;可以快速封禁某个用户。 缺点 占用服务端内存&#xff0c;硬件成本高。多进程&#xff0c;多服务器时&#xff0c;不好同步-需要使用第三方缓存&a…...

基于TPU-MLIR实现UNet模型部署-决赛答辩02

队伍&#xff1a;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&#xff0c;分模块开发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

周报汇总地址&#xff1a;嵌入式周报 - uCOS & uCGUI & emWin & embOS & TouchGFX & ThreadX - 硬汉嵌入式论坛 - Powered by Discuz! 视频版&#xff1a; https://www.bilibili.com/video/BV1F24y157QE 《安富莱嵌入式周报》第308期&#xff1a;开源带软…...

代码随想录算法训练营第五十六天 | 583. 两个字符串的删除操作、72. 编辑距离、编辑距离总结

583. 两个字符串的删除操作 动规五部曲 1、确定dp数组&#xff08;dp table&#xff09;以及下标的含义 dp[i][j]&#xff1a;以i-1为结尾的字符串word1&#xff0c;和以j-1位结尾的字符串word2&#xff0c;想要达到相等&#xff0c;所需要删除元素的最少次数。 2、确定递推…...

Sip协议

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

RandomAccessFile类 断点续传

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

SpringCloud微服务技术栈的注册中心Eureka

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