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、停止事…...
MongoDB学习和应用(高效的非关系型数据库)
一丶 MongoDB简介 对于社交类软件的功能,我们需要对它的功能特点进行分析: 数据量会随着用户数增大而增大读多写少价值较低非好友看不到其动态信息地理位置的查询… 针对以上特点进行分析各大存储工具: mysql:关系型数据库&am…...
23-Oracle 23 ai 区块链表(Blockchain Table)
小伙伴有没有在金融强合规的领域中遇见,必须要保持数据不可变,管理员都无法修改和留痕的要求。比如医疗的电子病历中,影像检查检验结果不可篡改行的,药品追溯过程中数据只可插入无法删除的特性需求;登录日志、修改日志…...
java 实现excel文件转pdf | 无水印 | 无限制
文章目录 目录 文章目录 前言 1.项目远程仓库配置 2.pom文件引入相关依赖 3.代码破解 二、Excel转PDF 1.代码实现 2.Aspose.License.xml 授权文件 总结 前言 java处理excel转pdf一直没找到什么好用的免费jar包工具,自己手写的难度,恐怕高级程序员花费一年的事件,也…...
(二)TensorRT-LLM | 模型导出(v0.20.0rc3)
0. 概述 上一节 对安装和使用有个基本介绍。根据这个 issue 的描述,后续 TensorRT-LLM 团队可能更专注于更新和维护 pytorch backend。但 tensorrt backend 作为先前一直开发的工作,其中包含了大量可以学习的地方。本文主要看看它导出模型的部分&#x…...
Python爬虫实战:研究feedparser库相关技术
1. 引言 1.1 研究背景与意义 在当今信息爆炸的时代,互联网上存在着海量的信息资源。RSS(Really Simple Syndication)作为一种标准化的信息聚合技术,被广泛用于网站内容的发布和订阅。通过 RSS,用户可以方便地获取网站更新的内容,而无需频繁访问各个网站。 然而,互联网…...
Auto-Coder使用GPT-4o完成:在用TabPFN这个模型构建一个预测未来3天涨跌的分类任务
通过akshare库,获取股票数据,并生成TabPFN这个模型 可以识别、处理的格式,写一个完整的预处理示例,并构建一个预测未来 3 天股价涨跌的分类任务 用TabPFN这个模型构建一个预测未来 3 天股价涨跌的分类任务,进行预测并输…...
数据链路层的主要功能是什么
数据链路层(OSI模型第2层)的核心功能是在相邻网络节点(如交换机、主机)间提供可靠的数据帧传输服务,主要职责包括: 🔑 核心功能详解: 帧封装与解封装 封装: 将网络层下发…...
从零实现STL哈希容器:unordered_map/unordered_set封装详解
本篇文章是对C学习的STL哈希容器自主实现部分的学习分享 希望也能为你带来些帮助~ 那咱们废话不多说,直接开始吧! 一、源码结构分析 1. SGISTL30实现剖析 // hash_set核心结构 template <class Value, class HashFcn, ...> class hash_set {ty…...
HTML前端开发:JavaScript 常用事件详解
作为前端开发的核心,JavaScript 事件是用户与网页交互的基础。以下是常见事件的详细说明和用法示例: 1. onclick - 点击事件 当元素被单击时触发(左键点击) button.onclick function() {alert("按钮被点击了!&…...
QT: `long long` 类型转换为 `QString` 2025.6.5
在 Qt 中,将 long long 类型转换为 QString 可以通过以下两种常用方法实现: 方法 1:使用 QString::number() 直接调用 QString 的静态方法 number(),将数值转换为字符串: long long value 1234567890123456789LL; …...
