后台管理系统学习过程V2

好的٩(•̤̀ᵕ•̤́๑)ᵒᵏᵎᵎᵎᵎ今天我们继续学习第二章内容。依然是参考这位大佬的博客:

For Azeroth_后台创建,笔记-CSDN博客icon-default.png?t=N7T8https://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数据池怎么实现

数据库连接池之Druid连接池(mysql)-CSDN博客

(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的动力!

  • 26
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值