首页 > 其他分享 >不使用spring boot等框架搭建servlet

不使用spring boot等框架搭建servlet

时间:2023-03-19 18:33:03浏览次数:34  
标签:jdbc String tomcat rs spring boot null servlet public

使用JavaSE搭建javaweb项目

访问数据库,比并将数据库的内容打印到浏览器页面上。 只用javaSE,tomcat,jdbc 工具

  • jdk1.8
  • tomcat 8.5
  • MySQL 5.7
  • mysql jar 5.1.48

第一步:创建空项目

image.png image.png 取名,finish

第二步:创建Java项目

image.png 我这里的Java版本是1.8,其他的什么都不要点,点击next image.png 取名,finish,点击ok,这样就创建好了一个java项目

第三步:创建javaEE框架

image.png 右键项目名,选择add framework support image.png 选择web application,ok image.png 它会自动给我们生成和tomcat一样的框架。

这里只实现一个简单的功能,就之创建一个javaClass。在src下创建一个类,我这里是先建了包。

安装tomcat依赖

在以上步骤,只是生成框架,但与tomcat相关的东西,还有没配置,所以下面配置tomcat

第四步:导入tomcat依赖

导入tomcat依赖.png

找到你电脑上tomcat文件夹下的lib文件

tomcat下的lib文件.png 找到jsp-api和servlet-api,都导入 找到jsp与servletjar.png 导入完成后这边会有显示 导入完成后这边会有显示.png

第五步:创建类 实现功能

这里就实现一个简单网页显示数据库信息的功能 image.png

要实现tomcat中Servlet的方法

package com.denchan.java.servlet;

import javax.servlet.*;
import java.io.IOException;

public class personInfo implements Servlet {
    @Override
    public void init(ServletConfig servletConfig) throws ServletException {
        
    }

    @Override
    public ServletConfig getServletConfig() {
        return null;
    }

    @Override
    public void service(ServletRequest servletRequest, ServletResponse servletResponse) throws ServletException, IOException {

    }

    @Override
    public String getServletInfo() {
        return null;
    }

    @Override
    public void destroy() {

    }
}

这里只重写service方法,实现简单效果

注意

如果你的tomcat是10以上的版本,则导入的jar包名是jakarta,因为换人了,捐给eclipse基金会了

第六步:数据库内容准备

在test中有张test_tb1的表,表中有内容 数据库表.png

将这三行内容打印在浏览器中

第七步:在service方法中写jdbc

jdbc注意点

如果你的jdbc版本较高,可能在注册驱动时会出现问题,需要加cj

//Class.forName("com.mysql.jdbc.Driver");
Class.forName("com.mysql.cj.jdbc.Driver");

下面代码中,service方法中的两个参数我做了个修改,imort就自己点吧,最后会上一个完整的代码

public void service(ServletRequest servletRequest, ServletResponse servletResponse) throws ServletException, IOException{}

// 修改后的,我将request和response两个参数做了修改
public void service(ServletRequest request, ServletResponse response) throws ServletException, IOException{}
// 以下代码在service方法中
//设置响应的类型
        response.setContentType("text/html;charset=UTF-8");
        PrintWriter out = response.getWriter();
        //code
        //jdbc
        Connection conn = null;
        PreparedStatement ps = null;
        ResultSet rs = null;
        try {
            // 注册驱动
            Class.forName("com.mysql.jdbc.Driver");
            // 获取链接
            String url = "jdbc:mysql://localhost:3306/test";
            String user = "root";
            String password = "1234";
            conn = DriverManager.getConnection(url, user, password);
            // 获取预编译的数据库操作对象
            String sql = "select * from test_tb1";
            ps = conn.prepareStatement(sql);
            // 执行SQL
            rs = ps.executeQuery();
            // 处理结果集
            while(rs.next()) {
                String id = rs.getString("id");
                String name = rs.getString("name");
                String age = rs.getString("age");
                String sex = rs.getString("sex");
                out.print(id + "," + name + "," + age + "," + sex + "<br>");
            }
        } catch (ClassNotFoundException | SQLException e) {
            e.printStackTrace();
        } finally {
            if (rs != null) {
                try {
                    rs.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }

            if (ps != null) {
                try {
                    ps.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }

            if (conn != null) {
                try {
                    conn.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }
        }

第八步:以上Java程序写完了,该对web.xml处理映射

xml映射.png

    <servlet>
        <servlet-name>personInfo</servlet-name>
        <servlet-class>com.denchan.java.servlet.personInfo</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>personInfo</servlet-name>
        <url-pattern>/info</url-pattern>
    </servlet-mapping>

这是一套的,如果还有其他要实现的,需要再写一套servlet和servlet-mapping

第九步:编写前端页面

实现的功能和映射都完成了,下面就是开始写前端代码,这里就只写一个a链接 html编写.png 需要注意的是,html文件要写在web文件夹的下面,它和WEB-INF,jsp文件是同级的,写错位置会导致出错。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>info</title>
</head>
<body>
    <!--这里做点说明
        /info是前面xml中的映射,当用户到这个页面时,会有一个click字样,当用户点击后,
        会先找<servlet-mapping>中的<servlet-name>personInfo</servlet-name>
        在到<servlet>中找到与之同名的<servlet-name>personInfo</servlet-name>
        就能找到是哪个类该运行了-->
    <!--  这里的/pro是项目名,在后面有用,这里可以随便取名,但一定要以"/"开始 -->
    <a rel="nofollow" href="/pro/info">click</a>
</body>
</html>

第十步:导入MySQL的驱动包到WEB-INF中的lib文件夹中,一开始是没有lib的,需要自己创建

MySQL驱动.png

第十一步:添加配置,要服务器运行起来

点击小榔头旁边的add 点击add添加配置.png

选择tomcat server.png

28items.png

config server.png

deployment.png

出现catlina.png

在deployment中还需做一项配置,往下拉 dizhi.png 这个/pro要与你在html中写的<a>标签中的项目名一致

以上,配置都完成了,点击debug,run也行

出现以下两行就说明成功了 出现successfully.png 输入网址 前端.png 结果 点击click出现结果.png

标签:jdbc,String,tomcat,rs,spring,boot,null,servlet,public
From: https://blog.51cto.com/u_15093262/6131306

相关文章

  • SpringBoot集成Swagger错误总结
    错误展示rorstartingApplicationContext.Todisplaytheconditionsreportre-runyourapplicationwith'debug'enabled.2023-03-1915:37:55.307ERROR12980---......
  • WebDataBinder、ServletRequestDataBinder、WebBindingInitializer
    前言上篇文章聊了​​DataBinder​​,这篇文章继续聊聊实际应用中的数据绑定主菜:​​WebDataBinder​​。在上文的基础上,我们先来看看​​DataBinder​​它的继承树:从继承......
  • Spring三级缓存与解决循环依赖
    一、什么是循环依赖、一级缓存A、B两个Service相互依赖,类似于死锁,我们来看AServiceBean的生命周期  我们要填充bService时,在单例池找不到B,就会先去创建B。但是创建B......
  • Spring框架学习
    只有到找工作的时候才想得起来写博客的warobot是屑...以下内容整理自w3school: Spring三层架构web表现层service业务层dao持久层 Spring的优良特性......
  • Bootstrap教程
    Bootstrap教程一、简介概述Bootstrap是一套现成的CSS样式集合(做得还是很友好的)。是两个推特的员工干出来的。Bootstrap是最受欢迎的HTML、CSS和JS框架,用于开发......
  • 第五天(SpringBoot基础第二篇)
    一、关于starterstater参赛人、发令员SpringBoot中的starter只是把我们某一模块,比如web开发时所需要的所有JAR包打包好给我们而已。不过它的厉害之处在于,能自动把......
  • 第四天(springBoot基础第一篇)
    springBoot基础1.什么是springBoot(概念及其特点)1.概念(1)介绍官网地址: https://spring.io/SpringBoot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spring应......
  • 【MyBatis框架】mybatis和spring整合
    spring和mybatis整合1.整合思路需要spring通过单例方式管理SqlSessionFactory。spring和mybatis整合生成代理对象,使用SqlSessionFactory创建Sql......
  • 【spring框架】spring之HibernateTemplate
    HibernateTemplate是spring对hibernate使用的一个简单封装:i.设计模式TemplateMethod模板方法ii.Callback回调(钩子函数)一般我们写save方法都......
  • 【spring框架】spring之packagesToScan
    spring的spring.jar的jar包内,在org.springframework.orm.hibernate3.annotation下,有一个AnnotationSessionFactoryBean类,其中有一个属性叫做"packages......