好的٩(•̤̀ᵕ•̤́๑)ᵒᵏᵎᵎᵎᵎ今天我们继续学习第二章内容。依然是参考这位大佬的博客:
For Azeroth_后台创建,笔记-CSDN博客https://blog.csdn.net/qq_47376720?type=blog
3 完善maven包
在原po的文章中,他将主要的配置已经提供给大家了,并且需要注意版本与自己的相对应,这里我具体讲一下各个包的作用,方便更好的理解:
junit-jupiter:用于测试的框架,包含断言(assertion),测试类等。
javabean与javabeanutils:【Java 进阶篇】Java BeanUtils 使用详解_beanutils maven-CSDN博客
JDBC:用于链接数据库
Druid:阿里巴巴开发的JDBC组件库,方便使用。
注意,这里添加的时候我建议大家一个一个添加,不要一次写全了,防止出现某些意想不到的错误。
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>org.xjtu</groupId>
<artifactId>WinterInternV2</artifactId>
<version>1.0-SNAPSHOT</version>
<properties>
<maven.compiler.source>8</maven.compiler.source>
<maven.compiler.target>8</maven.compiler.target>
</properties>
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>3.8.1</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>4.0.0</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-mxj-db-files</artifactId>
<version>5.0.12</version>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.0.9</version>
</dependency>
<dependency>
<groupId>com.alexkasko.springjdbc</groupId>
<artifactId>springjdbc-iterable</artifactId>
<version>1.0.3</version>
</dependency>
<dependency>
<groupId>org.junit.jupiter</groupId>
<artifactId>junit-jupiter</artifactId>
<version>RELEASE</version>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>org.testng</groupId>
<artifactId>testng</artifactId>
<version>RELEASE</version>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>commons-beanutils</groupId>
<artifactId>commons-beanutils</artifactId>
<version>1.8.0</version>
</dependency>
</dependencies>
</project>
两个junit不影响使用
4 Druid导入
依照原教程使用即可,我在这里也没遇到什么问题,注意一定要在resources中创建
使用file创建即可,写上后缀
5 JDBC配置文件
同样如原教程导入,原教程没给出此时的结构列表,为了防止大家出现错误,我将我的放上来做个参考。值得注意的是,原po的文件名写错了,大家根据自己创建的名字进行更改即可:
当我们获取到了数据库中的内容时,我们需要将他们封装成类,并在里面附上get set方法,这正是我们前文中提到的______?
那么我们先以登录为设计功能,来试一试。
5.1 创建Users类与数据库
按照原教程代码
确定了功能,那么接下来我们就需要建立数据库啦,这里我使用的是SQL Workbench 8.0 用其他的也可以
注意 如果你使用的不是3306端口或者用户名/密码不对,则要修改之前Druid1.properties中的内容
5.2 代码本地化
我建立的数据库与表名:
修改教程中的代码:
Users类:
注意名字和下面的方法什么的都要改,下面给出我的完整代码:
package domain;
public class Users {
private Integer userid;
private String userphone;
private String username;
private Integer userage;
public Integer getUserid() {
return userid;
}
public void setUserid(Integer userid) {
this.userid = userid;
}
public String getUserphone() {
return userphone;
}
public void setUserphone(String userphone) {
this.userphone = userphone;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public Integer getUserage() {
return userage;
}
public void setUserage(Integer userage) {
this.userage = userage;
}
@Override
public String toString() {
return "doMain{" +
"userid=" + userid +
", userphone='" + userphone + '\'' +
", username='" + username + '\'' +
", userage=" + userage +
'}';
}
}
同理,Druid资源文件也需要更改:
需要注意端口号,数据库名,账号,密码
driverClassName=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/winterintern
username=root #数据库用户名
password=123 #数据库密码
# 初始化连接数量
initialSize=5
# 最大连接数
maxActive=10
# 最大超时时间
maxWait=3000
你可能产生的疑问:
(1)我的数据库URL是什么:
(2)Druid数据池怎么实现
(3)数据库账号密码不记得了
一般来说,只要你没更改过账号,一般都是root
假设真的不记得了,请参考:
Mysql8.0以上重置初始密码的方法_mysql8.0密码重置-CSDN博客
6 来点HTML
既然想要在网页端看到它,而且满足我们后面的展示、美化需求,那么HTML是必不可少的
在这里我们来写一个登录的小界面,跟教程差不多,不在此处赘述。
7 Servlet沟通万物
最后我们需要一个servlet来实现post和get功能,他们承担起了传输的工作:
package com;
import domain.Users;
import org.springframework.jdbc.core.BeanPropertyRowMapper;
import org.springframework.jdbc.core.JdbcTemplate;
import utils.JDBCutils;
import javax.servlet.RequestDispatcher;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.PrintWriter;
import java.util.Enumeration;
import java.util.List;
/**
* 登陆案例,使用JDBCTemplate技术
*/
@WebServlet("/demo1")
public class ServletDemo1 extends HttpServlet {
private final JdbcTemplate template = new JdbcTemplate(JDBCutils.getdatasourse());
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
System.out.println("doGet成功运行");
String account = req.getParameter("account"); // 从 request 中获取名为 account 的参数的值
String password = req.getParameter("password"); // 从 request 中获取名为 password 的参数的值
System.out.println("account:" + account + "\npassword:" + password); // 打印出来看一看
/**
* 连接数据库,进行登陆操作
*/
String result = "数据库读取异常!";
if (account.isEmpty()){
result = "用户名为空!";
}else if (password.isEmpty()){
result = "密码为空!";
}else{
String sql12 = "select * from users";
// List<Users> list = template.query(sql12, new BeanPropertyRowMapper<Users>(Users.class));
// for (Users users : list) {
// System.out.println(users.getUsername()+" "+users.getUserage());
// if(users.getUsername().equals(account)&&users.getUserphone().equals(password)){
// result = "已经连接数据库,并且匹配数据成功";
// break;
// }
// result = "输入用户账号密码不正确,请重试";
// }
}
resp.setContentType("text/html;charset=utf-8"); // 设置响应报文的编码格式
PrintWriter pw = resp.getWriter(); // 获取 response 的输出流
pw.println(result); // 通过输出流把业务逻辑的结果输出
pw.flush();
/**
* 使用一个一个函数获取表单信息和数据,主要获取表单数据
*/
resp.setContentType("text/html;charset=UTF-8");
String name = req.getParameter("account");
PrintWriter out = resp.getWriter();
String title = "使用 GET 方法读取表单数据";
// 处理中文
String docType = "<!DOCTYPE html> \n";
out.println(docType +
"<html>\n" +
"<head><title>" + title + "</title></head>\n" +
"<body bgcolor=\"#f0f0f0\">\n" +
"<h1 align=\"center\">" + title + "</h1>\n" +
"<ul>\n" +
" <li><b>用户名</b>:"
+ name + "\n" +
" <li><b>密码</b>:"
+ req.getParameter("password") + "\n" +
" <li><b>请求方法</b>:"
+ req.getMethod()+ "\n" +
" <li><b>Servlet路径</b>:"
+ req.getServletPath()+ "\n" +
" <li><b>URI路径</b>:"
+ req.getRequestURI() + "\n" +
" <li><b>URL路径</b>:"
+ req.getRequestURL() + "\n" +
" <li><b>URL实现协议和版本</b>:"
+ req.getProtocol() + "\n" +
" <li><b>客户机的IP地址</b>:"
+ req.getRemoteAddr() + "\n" +
"</ul>\n" +
"</body></html>");
/**
* 使用req.getHeaderNames方法来获取表头数据和信息
*/
Enumeration<String> headerNames = req.getHeaderNames();
resp.setContentType("text/html;charset=UTF-8");
PrintWriter out1 = resp.getWriter();
String title1 = "使用 GET 方法读取表头数据";
String docType1 = "<!DOCTYPE html> \n";
out1.println(docType1 +
"<html>\n" +
"<head><title>" + title1 + "</title></head>\n" +
"<body bgcolor=\"#f0f0f0\">\n" +
"<h1 align=\"center\">" + title1 + "</h1>\n" +
"<ul>\n"+
" <li><b>用户名</b>:"
+ req.getParameter("account") + "\n" +
" <li><b>密码</b>:"
+ req.getParameter("password") + "\n"
);
while (headerNames.hasMoreElements()) { //返回了一个枚举类型,然后用类似迭代器的方法输出
out1.println(
" <li><b>"+headerNames.nextElement()+"</b>:"
+ req.getHeader(headerNames.nextElement()) + "\n"
);
}
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
}
}
如果依赖没导进Artifacts
当我尝试运行的时候,噔噔咚,报错找不到template
Caused by: java.lang.NoClassDefFoundError: Lorg/springframework/jdbc/core/JdbcTemplate;
经过我一番排查,发现尽管我使用maven导入了这些依赖到IDEA的外部依赖库,他实际上并没有在工件中起到作用
我们需要打开File-Project Structure-Artifacts建一个libs文件夹在WEB-INF下面
选中libs文件夹,点加号,添加Library Files
在这里手动添加Library Files,全部添加,然后apply,ok,再次运行
8 尝试登录
提示连接错误,且报了500错误
一般出现Access denied都是提示需要授权,参照这个教程最下面进行授权
Mysql8.0的windows安装_windows mysql8.0 anzhaung-CSDN博客
再次登录仍然报错,但是我另一个项目可以登陆
鱼是根据这个报错user检查代码,猜猜我发现了什么:
删掉多余的东西后,我再次运行,报了一个不一样的错误
查询,得知druid与sql连接两个包版本号不匹配,将druid版本号改为1.2.5,刷新maven
记得刷新完成后要在artifacts里手动将新的依赖导入,删掉旧的druid
再次登录尝试,发现链接数据库成功
至此第二节也结束了,如果您觉得还不错的话,不妨留下一个关注和免费的赞,你的支持就是我接着挠头debug的动力!