基于Servlet+JSP的增删改查练手项目

这篇具有很好参考价值的文章主要介绍了基于Servlet+JSP的增删改查练手项目。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

前言

我们每写一步,就测试一步,不要等到所有都写好了再测试,如果都写好了再测试,最后出错的话,会很崩溃,代码量大,调试就不容易,话不多说,开始今天的练手项目。下面的代码,每一步都是按照我自己的步骤,一步一步敲出来,调试出来的,大家第一遍可以跟着敲代码,理解其中的思想,后面自己再根据逻辑敲一遍,敲代码过程中,我所遇到的问题,在文中也会一一说明。
在文章最后给出本次练手项目的源码。

Servlet负责写Java程序,JSP负责展示页面

1.准备页面

首先我们先写几个页面,在没有Java程序的时候,把流程跑通,然后再根据每个功能来写Java程序,思路一定要清晰,在写代码之前,要先想好每一步要干什么。
准备的页面:

  • 欢迎页面 index.jsp
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
  <head>
    <title>主页面</title>
  </head>
  <body>
    <a href="list.jsp">欢迎使用oa系统</a>


  </body>
</html>

  • 新增页面 add.jsp
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>Title</title>
</head>
<body>
<%--新增数据以后,我们点击保存后要回到列表页面--%>
    <h1>新增页面</h1>
    <form action="list.jsp" method="post">
        部门编号:<input type="text" name="deptnum"  ><br>
        部门名称:<input type="text" name="deptname"  ><br>
        部门位置:<input type="text" name="loc"><br>
        <input type="submit" value="保存">
    </form>
</body>
</html>
  • 修改页面 edit.jsp
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>Title</title>
</head>
<body>
<h1>修改页面</h1>
<%--修改页面应该是先返回对应的信息,然后我们点击修改,就可以修改里面的数据--%>
<form action="list.jsp" method="post">
    部门编号:<input type="text" value="10"><br>
    部门名称:<input type="text" value="研发部"><br>
    部门位置:<input type="text" value="杭州"><br>
    <input type="submit" value="修改">

</form>

</body>
</html>

  • 详情页面 detail.jsp
%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>Title</title>
</head>
<body>
<h1>详情页面</h1>
<%--我们可以看到部门的具体信息,点击后退就回到列表页面--%>
部门编号:<input type="text" value="10"><br>
部门名称:<input type="text" value="研发部"><br>
部门位置:<input type="text" value="杭州"><br>
<input type="button" value="后退" onclick="window.history.back()"/>

</body>
</html>
  • 删除页面 modify

2.根据页面来实现功能

我们写程序可以从前端往后端写,也可以由后端往前端写,大家选择一个方向来,我这里以前端往后端来演示。

3.显示部门列表

  • 进入欢迎页面后,我们点击连接应该对应的是一个Java程序,这个Java程序和数据库连接,把对应的数据查询出来,然后通过JSP展示出来,因为查询出来的数据有很多,所以我们可以用一个实体类来对应一张表,类的一个对象就相当于一条记录,数据查出来以后,因为要从JSP页面上展示出来,所以用转发,记得把数据存进去。
  • 注意:之前我们在测试页面的时候,路径都是和jsp有关,当我们编写对应的servlet的时候,记得修改路径。
 
@WebServlet("/dept/list")
public class DeptServlet extends HttpServlet {
    @Override
    protected void service(HttpServletRequest request, HttpServletResponse response)  throws ServletException, IOException {
        //模板方法设计模式
        /**
         * 我们可以获取servlet的路径,根据路径来执行相应的方法
         */
        String servletPath = request.getServletPath();
        if ("/dept/list".equals(servletPath)){
            doList(request,response);
        }


    }

    private void doList(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        /**
         * 使用JDBC连接数据库,查询表中数据
         */
        Connection conn=null;
        PreparedStatement ps=null;
        ResultSet rs=null;
        List<User> list=new ArrayList<>();
        try {
            conn= DBUtils.getConnection();
            String sql="select deptno,dname,loc from dept";
            ps=conn.prepareStatement(sql);
            rs = ps.executeQuery();
            while (rs.next()){
                String deptno = rs.getString("deptno");
                String dname = rs.getString("dname");
                String loc = rs.getString("loc");
                User user=new User(deptno,dname,loc);
                list.add(user);

            }


        } catch (SQLException e) {
            e.printStackTrace();
        } finally {
            DBUtils.close(conn,ps,rs);
        }
        //转发给jsp进行页面展示
        request.setAttribute("list",list);
        request.getRequestDispatcher("/list.jsp").forward(request,response);


    }
}

list.jsp—部门列表页面
因为第一次是为了跑通页面,里面的数据都是写死的,现在要从数据库查出数据,所以要写Java代码

 
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>Title</title>
</head>
<body>
<%--展示部门列表页面,里面有各种数据,点击各种操作就可以进行相应操作--%>
<h1 align="center">部门列表页面</h1>
 <table align="center" border="1px" width="50%">
     <tr>
         <th>序号</th>
         <th>部门编号</th>
         <th>部门名称</th>
         <th>部门位置</th>
         <th>操作</th>
     </tr>
     <%
         List<User> list = (List<User>) request.getAttribute("list");
         int cnt=0;
     %>
     <%
         for(User user:list){
            String deptno = user.getDeptno();
             String dname = user.getDname();
             String loc = user.getLoc();

     %>

     <tr>
         <th><%=++cnt%></th>
         <th><%=deptno%></th>
         <th><%=dname%></th>
         <th><%=loc%></th>
         <th>
             <a href="detail.jsp">详情</a>
             <a href="edit.jsp">修改</a>
             <a href="modify.jsp">删除</a>
             <a href="add.jsp">新增</a>
         </th>
     </tr>
     <%
         }
     %>

 
 </table>


</body>
</html>

程序要注意的地方:
基于Servlet+JSP的增删改查练手项目
欢迎页面的超链接路径记得改成我们要执行的Servlet的映射路径
<a href=<%=request.getContextPath()%>/dept/list>欢迎使用oa系统

接下来看一下成果
基于Servlet+JSP的增删改查练手项目
基于Servlet+JSP的增删改查练手项目
到这里,我们就把查看部门列表的功能完成了,自己动手写的程序很有成就吧,大家还是要自己动手写写,自己写和直接复制,最后的效果是不一样的,自己写的代码,我们经过了思考和调错,也锻炼了自己的逻辑。

4.查看部门详情

点击详情,也需要根据数据库中查的数据返回–%>
<%-- 注意:前端提交数据的格式是http://localhost:8080/myoa01/dept/list?name=value
我们要根据部门编号来返回对应的信息的话,就应该要让后端能够接收到我们要查询哪一个部门的信息–%>
在之前部门列表页面 的超链接要改成下面:
<a href=“<%=request.getContextPath()+”/dept/detail?deptno=“+deptno%>”>详情
这个路径对应一个Servlet

下面这个是部门详情的Servlet代码
当我们在浏览器点击详情,应该能够根据这个位置的部门编号来返回相关的信息,所以写的路径就是一个技巧。
<%=request.getContextPath()+“/dept/detail?deptno=”+deptno%>把部门编号传给后台,我们根据这个参数名来获取值,进而可以查询到相关数据。

/**
     * 部门详情功能,点击详情,根据部门编号返回相应的数据
     * @param request
     * @param response
     */
    private void doDetail(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

        /**
         * 首先获取前端浏览器传过来的部门编号信息
         * 根据这个信息来查询对应的信息
         * 然后返回给详情页面进行展示
         */
        String deptno = request.getParameter("deptno");
        Connection conn=null;
        PreparedStatement ps=null;
        ResultSet rs=null;
        List<User> list=new ArrayList<>();
        try {
            conn=DBUtils.getConnection();
             String sql="select dname,loc from dept where deptno=?";
             ps=conn.prepareStatement(sql);
             ps.setString(1,deptno);
             rs=ps.executeQuery();
             //查到数据,返回
             while (rs.next()){
                 User user=new User();
                 user.setDeptno(deptno);
                 user.setDname(rs.getString(1));
                 user.setLoc(rs.getString(2));
                 list.add(user);

             }
        } catch (SQLException e) {
            e.printStackTrace();
        } finally {
            DBUtils.close(conn,ps,rs);
        }
        //把数据给JSP
//        使用转发,因为需要取数据
        request.setAttribute("list",list);
        request.getRequestDispatcher("/detail.jsp").forward(request,response);


    }

详情页面detail.jsp,可以看到之前写死的数据现在都可以动态获取了,这就是JSP的一个优点,可以动态展示页面。

<%@ page import="com.zyh.oa.javabean.User" %>
<%@ page import="java.util.List" %> 
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>Title</title>
</head>
<body>
<h1>详情页面</h1>
<%--取出servlet中转发的数据--%>
 <%
     List<User> userList=(List<User>) request.getAttribute("list");
     for(User user:userList){
         String deptno = user.getDeptno();
         String dname = user.getDname();
         String loc = user.getLoc();

//<%--我们可以看到部门的具体信息,点击后退就回到列表页面--%>
    部门编号:<%=deptno%> <br>
    部门名称:<%=dname%><br>
    部门位置:<%=loc%><br>


<%
     }
 %>

<input type="button" value="后退" onclick="window.history.back()"/>


</body>
</html>

接下来测试一下,这个功能能不能使用
基于Servlet+JSP的增删改查练手项目
基于Servlet+JSP的增删改查练手项目
然后点击后退
基于Servlet+JSP的增删改查练手项目
再点击详情
基于Servlet+JSP的增删改查练手项目
经过测试,发现功能没有问题,那我们就继续下一个功能模块了。

5.新增部门

当我们在部门列表页面点击新增部门的时候,会跳出一个页面,让我们写新增部门的相关信息,当我们点击保存的时候,应该对应一个Servlet程序,把内容存到数据库中,然后跳转到部门列表页面。

add.jsp

<form action="<%=request.getContextPath()+"/dept/add"%>" method="post">
        部门编号:<input type="text" name="deptno"  ><br>
        部门名称:<input type="text" name="dname"  ><br>
        部门位置:<input type="text" name="loc"><br>
        <input type="submit" value="保存">
    </form>

Servlet根据前端传入的参数来获取数据,进而插入数据库中
保存成功,重定向到部门列表页面

 /**
     * 新增部门
     * @param request
     * @param response
     */
    private void doAdd(HttpServletRequest request, HttpServletResponse response) throws IOException {
        /**
         * 根据获取的参数,来存入数据库中
         */
        String deptno = request.getParameter("deptno");
        String dname = request.getParameter("dname");
        String loc = request.getParameter("loc");
        Connection conn=null;
        PreparedStatement ps=null;
        ResultSet rs=null;
        int cnt=0;
        try {
            conn=DBUtils.getConnection();
            String sql="insert into dept(deptno,dname,loc) values(?,?,?)";
            ps = conn.prepareStatement(sql);
            ps.setString(1,deptno);
            ps.setString(2,dname);
            ps.setString(3,loc);
            cnt = ps.executeUpdate();

        } catch (SQLException e) {
            e.printStackTrace();
        } finally {
            DBUtils.close(conn,ps,rs);
        }
        if (cnt>0){
            //说明保存成功,跳转到部门列表页面
            response.sendRedirect(request.getContextPath()+"/dept/list");

        }

    }

测试:
基于Servlet+JSP的增删改查练手项目
基于Servlet+JSP的增删改查练手项目
基于Servlet+JSP的增删改查练手项目

6.修改部门

点击修改,其实应该把对应的数据查询出来,显示在页面上,然后当我们点击修改的时候,把数据保存到数据库中,然后回到部门列表页面
这里我截取重要代码,首先修改功能的第一步应该和详情的功能是一样的,我们可以根据参数值的不同来决定是执行详情功能还是修改功能

   <a href="<%=request.getContextPath()+"/dept/detail?deptno="+deptno+"&f=detail"%>">详情</a>

<%--    点击修改,其实应该把对应的数据查询出来,显示在页面上,然后当我们点击修改的时候,
把数据保存到数据库中,然后回到部门列表页面--%>
             <a href="<%=request.getContextPath()+"/dept/detail?deptno="+deptno+"&f=edit"%>">修改</a>

然后在edit.jsp这个修改页面展示数据,来给我们修改,修改后再执行一个servlet,修改数据库中的数据

<%@ page import="com.zyh.oa.javabean.User" %>
<%@ page import="java.util.List" %><%--
  Created by IntelliJ IDEA.
  User: 17614
  Date: 2022-03-30
  Time: 19:18
  To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>Title</title>
</head>
<body>
<h1>修改页面</h1>
<%--修改页面应该是先返回对应的信息,然后我们点击修改,就可以修改里面的数据
要先保存到数据库里面,然后再展示出来--%>

<form action="<%=request.getContextPath()+"/dept/save"%>" method="post">
    <%
        List<User> userList=(List<User>) request.getAttribute("list");
        for(User user:userList){
            String deptno = user.getDeptno();
            String dname = user.getDname();
            String loc = user.getLoc();

//<%--我们可以看到部门的具体信息,点击后退就回到列表页面--%>
<%--    部门编号:<%=deptno%> <br>--%>
<%--    部门名称:<%=dname%><br>--%>
<%--    部门位置:<%=loc%><br>--%>
    部门编号:<input type="text" name="deptno" value="<%=deptno%>" readonly><br>
    部门名称:<input type="text" name="dname" value="<%=dname%>" ><br>
    部门位置:<input type="text" name="loc" value="<%=loc%>"><br>

    <%
        }
    %>
<%--    部门编号:<input type="text" value="10"><br>--%>
<%--    部门名称:<input type="text" value="研发部"><br>--%>
<%--    部门位置:<input type="text" value="杭州"><br>--%>
    <input type="submit" value="修改">

</form>

</body>
</html>

修改成功后回到列表页面

  response.sendRedirect(request.getContextPath()+"/dept/list");

基于Servlet+JSP的增删改查练手项目
基于Servlet+JSP的增删改查练手项目
然后修改数据
基于Servlet+JSP的增删改查练手项目

基于Servlet+JSP的增删改查练手项目
最后就是删除功能了

7.删除部门

前端把要删除的部门编号传给后端,后端根据这个来删除

 <a href="<%=request.getContextPath()+"/dept/delete?deptno="+deptno%>">删除</a>

接下来展示一下效果
基于Servlet+JSP的增删改查练手项目
然后点击删除
基于Servlet+JSP的增删改查练手项目
本次的练手小项目先到这里,这个项目还有可以改进的地方,我在下一篇文章会写出来。

链接:https://pan.baidu.com/s/13_copfi8Gqo56MyPaXF18Q?pwd=40xa
提取码:40xa文章来源地址https://www.toymoban.com/news/detail-489083.html

到了这里,关于基于Servlet+JSP的增删改查练手项目的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Java(二):Spring Boot 项目-文件的增删改查下载

    docker运行mysql 设置MySQL时区 添加修改 /mysql/conf.d/xxx.cnf 文件,并重启 MySQL 查看当前MySQL使用的时区 MySQL建库建表 数据表实体类 注意: 规定参数时区 com/example/user/entity/FileTable.java 查询条件实体类 com/example/user/entity/FileTableCondition.java com/example/user/utils/FileUtil.java mapper user/src/mai

    2024年02月09日
    浏览(50)
  • servlet+JSP与SpringBoot+Vue项目交互——servlet请求SpringBoot接口

    servlet+JSP与SpringBoot+Vue项目交互——servlet请求SpringBoot接口 笔者前一段时间开发一个项目,使用的技术框架是servlet+JSP,现阶段开发的项目技术框架为SpringBoot+Vue,笔者现在需要输入servlet+JSP请求SpringBoot接口,获取接口相应,如何实现 1、若读者使用的是 Maven 作为构建工具,您

    2024年02月03日
    浏览(40)
  • day32-EMP项目实战(servlet+jsp)

    1. 1.  创建maven工程,导入依赖,创建service(服务包),dao(持久包),servlet(控制包),entity(实体包)包,jsp(页面) 2.  创建数据库,创建表t_user,t_employee 3.  依据数据库字段创建实体类User,Employee 4.  创建工具类BaseDao,UserDao和其实现类,EmployeeDao和其实现类;重写实

    2024年02月13日
    浏览(43)
  • JSP+Servlet+MySql超市管理系统项目源码

    软件名称:超市管理系统(servlet+jsp) 使用对象:学习或了解过 java 基础课程,开始接触 javaWeb 的学生和软件爱好者 源码链接:超市管理系统: 超市管理系统 Sql文件https://pan.baidu.com/s/1BtMM8erQ9E25fQ1j4eHltQ?pwd=8nmj 该超市管理系统,设置了登录权限验证,所有用户除了访问首页浏览商品

    2024年02月09日
    浏览(44)
  • 一个简单的增删改查Spring boot项目教程(完整过程,附代码)(从搭建数据库到实现增删改查功能),Springboot学习,Springboot项目,

    这里将会介绍怎么去搭建一个简单增删改查的Springboot项目,认真看完我相信你一定能够学会,并且附有完整代码; 首先要进行增删改查肯定是要有供操作的数据库; 这里我是用的SQLyog来搭建的,随便用什么都可以,只要能确保给项目一个配套的数据库就行; 打开IDEA,创建

    2024年02月15日
    浏览(61)
  • 创建nodejs项目并接入mysql,完成用户相关的增删改查的详细操作

    本文为博主原创,转载请注明出处: 在本地创建项目的文件夹名称,如 node_test,并在该文件夹下进行黑窗口执行初始化命令              Express是一个流行的Web应用程序框架,可以帮助我们快速构建Web应用程序和API。Express提供了许多有用的功能,包括路由、中间件、请求响

    2024年02月06日
    浏览(93)
  • 基于javaweb+mysql的jsp+servlet图书图书馆管理系统(java+jsp+layui+bootstrap+servlet+mysql)

    基于javaweb+mysql的jsp+servlet图书图书馆管理系统(java+jsp+layui+bootstrap+servlet+mysql) 运行环境 Java≥8、MySQL≥5.7、Tomcat≥8 开发工具 eclipse/idea/myeclipse/sts等均可配置运行 适用 课程设计,大作业,毕业设计,项目练习,学习演示等 功能说明 基于javaweb+mysql的JSP+Servlet图书图书馆管理系统

    2024年02月04日
    浏览(50)
  • 基于javaweb+mysql的jsp+servlet学生成绩管理系统(管理员、教师、学生)(java+jsp+servlet+javabean+mysql+tomcat)

    基于javaweb+mysql的jsp+servlet学生成绩管理系统(管理员、教师、学生)(java+jsp+servlet+javabean+mysql+tomcat) 运行环境 Java≥8、MySQL≥5.7、Tomcat≥8 开发工具 eclipse/idea/myeclipse/sts等均可配置运行 适用 课程设计,大作业,毕业设计,项目练习,学习演示等 功能说明 管理员:个人信息、课程

    2024年02月02日
    浏览(55)
  • 基于javaweb+mysql的jsp+servlet幼儿园管理系统(java+jsp+easyui+h-ui+servlet+mysql)

    基于javaweb+mysql的jsp+servlet幼儿园管理系统(java+jsp+easyui+h-ui+servlet+mysql) 私信 源码获取及调试交流 运行环境 Java≥8、MySQL≥5.7、Tomcat≥8 开发工具 eclipse/idea/myeclipse/sts等均可配置运行 适用 课程设计,大作业,毕业设计,项目练习,学习演示等 功能说明 基于javaweb的JSP+Servlet幼儿

    2024年01月16日
    浏览(71)
  • 创建javaEE项目(无maven),JSP(九大内置对象)、Servlet(生命周期)了解

    1.创建一个普通的java项目 2.项目根目录右键,添加模板 3.配置tomcat服务器 4.配置项目tomcat依赖         用户通过浏览器发送一个请求,服务器tomcat接收到后,解析web.xml配置文件进行分析执行接口对应的类;         Tomcat服务器支持:支持Servlet规范。而要想让它能找到

    2024年02月05日
    浏览(48)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包