首先创建一个空项目!!!注意是空项目!!!
点击 文件->新建->新模块 ,新建一个名称为 servlet02 的模块(注意该模块的生成位置应该在我们刚刚新建的空项目下面!!!)
之后右键点击新模块 servlet02,选择 “添加框架支持”
勾选 “web 应用程序” ,之后直接点击完成即可自动生成 webapp 框架;
文件 -> 项目结构
模块 -> servlet02 -> 依赖 -> 点击加号,并选择第一个项目
找到 tomcat 根目录下的 lib 文件夹,选择 jsp-api.jar
和 servlet-api.jar
两个包并导入!
前往 maven 中心仓库,搜索 mysql-connector;
或者直接前往此地址:https://mvnrepository.com/artifact/mysql/mysql-connector-java
因为我使用的是 mysql5.7 版本,所以我们找到仓库内的 5.1.x 中最新的那一个版本,下载其 jar 包就好了(5.1.x 版本兼容 5.7)
下载完毕后直接把该 jar 包,粘贴到 tomcat 根目录下的 lib 文件夹里面!
下面就是标准的 JDBC 操作了,请您直接看注释,一个个解释太累了
package com.zhiyiyi.javaweb.servlet;
import jakarta.servlet.*;
import java.io.IOException;
import java.io.PrintWriter;
import java.sql.*;
public class StudentServlet implements Servlet {
@Override
public void init(ServletConfig servletConfig) throws ServletException {
}
@Override
public ServletConfig getServletConfig() {
return null;
}
@Override
public void service(ServletRequest request, ServletResponse response) throws ServletException, IOException {
// 设置请求头类型
response.setContentType("text/html");
// 设置输出
PrintWriter printWriter = response.getWriter();
// 为三件套分配内存空间
Connection conn = null;
PreparedStatement ps = null;
ResultSet rs = null;
try {
// 反射获取jdbc驱动
Class.forName("com.mysql.jdbc.Driver");
// 传入你的mysql数据库名称、用户名、密码
String url = "jdbc:mysql://localhost:3306/jakarta";
String user = "root";
String password = "123456";
// 链接数据库
conn = DriverManager.getConnection(url, user, password);
// 编写查询语句并执行,使用resultset取回查询结果
String sql = "select no, name from std1";
ps = conn.prepareStatement(sql);
rs = ps.executeQuery();
// 打印从数据库中取回的结果
while (rs.next()) {
String no = rs.getString("no");
String name = rs.getString("name");
printWriter.println(no + " " + name + "
");
}
// 一些错误处理
} catch (ClassNotFoundException | SQLException e) {
throw new RuntimeException(e);
} 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();
}
}
}
}
@Override
public String getServletInfo() {
return null;
}
@Override
public void destroy() {
}
}
我们生成的 webapp 模板默认是自带一个 index.jsp 的,目前用不到,先删掉;
在同样的位置新建一个 student.html 文件,输入以下代码;
这里使用了一个链接指向了我们刚刚编写的 servlet;
<html>
<head>
<meta charset="UTF-8" />
<title>student servlettitle>
head>
<body>
<a href="/crm/servlet/student">student lista>
body>
html>
点击 idea 右上角绿色小三角左边的下拉列表,选择“添加配置”
弹出窗口点击加号 -> tomcat 服务器 -> 本地
然后按照下图所示填充内容
注意:由于我的电脑端口被占用,所以我修改了 http 端口为 10086,事实上这一项我们保持默认不用管就可以了!
再次进入“部署”栏目,点击加号添加工件,然后设置应用程序上下文为/crm 即可;
这里的 /crm
对应我们之前的 student.html
链接里的/crm
/crm 表示项目的目录
一切配置完毕,点击绿色按钮开始构建 tomcat 服务器;
此时因为我们勾选了服务器一启动就打开浏览器的选项,但我们发现刚刚打开的浏览器 404 报错;
别着急,只是路径对不上,我们将 url 改为我们设置的 herf 路径即可访问到 mysql 提取的数据了!!!