从零开始搭建java web springboot Eclipse MyBatis jsp mysql开发环境

文章目录

  • 1 第一步软件安装
    • 1.1 下载并安装Eclipse
    • 1.2 下载并安装Java
    • 1.3 下载并安装Apache Maven
    • 1.4 下载并安装MySQL
  • 2 创建所需要的表和数据
  • 3 创建Maven 工程、修改jdk
  • 4 通过pom.xml获取所需要的jar包
  • 5 安装Eclipse的MyBatis插件
  • 6 创建文件夹以及jsp文件
  • 7 创建下面各种java类文件、xml、properties文件
    • 7.1 com.study.WebAppMainApplication.java
    • 7.2 com.study.action.AMC01LoginAction .java
    • 7.3 com.study.controller.amc01.AMC01Controller .java
    • 7.4 com.study.controller.amc01.AMC01Form .java
    • 7.5 com.study.dto.AMC01InputDto .java
    • 7.6 com.study.dto.AMC01OutputDto .java
    • 7.7 com.study.dto.AMC01LoginUserInfoDto .java
    • 7.8 com.study.entity.S001Entity .java
    • 7.9 com.study.repository.AMC01Repository .java
    • 7.10 com.study.service.AMC01Service .java
    • 7.11 AMC01Repository.xml
    • 7.12 application.properties
  • 8 启动web应用

从百度云盘下载本博客的代码,https://pan.baidu.com/s/1ztOr7FnypSv-0FX_5EMIlw,提取码:soft

1 第一步软件安装

1.1 下载并安装Eclipse

前往 Eclipse下载并安装的博客 https://blog.csdn.net/u011159350/article/details/113704086
本博客使用的Eclipse版本是Version: 2022-12 (4.26.0),Build id: 20221201-1913
其他版本也行

1.2 下载并安装Java

前往 Java下载并安装的博客 https://blog.csdn.net/u011159350/article/details/113703862
本博客使用的Java版本是15.0.1
其他Java也行

1.3 下载并安装Apache Maven

前往 Apache Maven下载并安装的博客 https://blog.csdn.net/u011159350/article/details/103796714

1.4 下载并安装MySQL

前往 MySQL下载并安装的博客 https://blog.csdn.net/u011159350/article/details/113619926

2 创建所需要的表和数据

打开MySQL附带的软件MySQL WorkBench
在这里插入图片描述在这里插入图片描述
在这里插入图片描述

下面是上面图片里要执行的SQL内容

CREATE TABLE `mydb`.`s001` (`LOGIN_USERID` VARCHAR(20) NOT NULL COMMENT '登陆用户ID',`LOGIN_PASSWORD` VARCHAR(20) NOT NULL COMMENT '登陆密码',`USER_NAME` VARCHAR(50) NULL COMMENT '用户名表示用',`EMAIL` VARCHAR(30) NULL COMMENT '邮件地址',`BIRTH_YMD` VARCHAR(8) NULL COMMENT '出生年月日',`TELPHONE_NUMBER` VARCHAR(11) NULL COMMENT '电话号码',PRIMARY KEY (`LOGIN_USERID`))
COMMENT = '用户情报表';

在这里插入图片描述

在这里插入图片描述
在下图添加数据,然后点击Apply按钮
在这里插入图片描述
在这里插入图片描述
点击finish,就添加成功数据了。
在这里插入图片描述

3 创建Maven 工程、修改jdk

在这里插入图片描述
在这里插入图片描述
Group Id:com.study
Artifact Id:StudySpringBoot
在这里插入图片描述
下面的步骤是设置jdk,因为我是设定过后重新截图,所以会看起来设定后没有变化。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
选择 J2SE-15(jdk-15.0.1)
在这里插入图片描述

4 通过pom.xml获取所需要的jar包

双击打开下面的pom.xml文件
在这里插入图片描述

把pom.xml里的内容全部删除,然后下面的文件复制到pom.xml文件中

<?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><artifactId>study</artifactId><groupId>com.study</groupId><version>0.0.1-SNAPSHOT</version><parent><!-- 依赖管理,引入以后在声明其它dependency的时候就不需要version --><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>1.5.9.RELEASE</version><relativePath /></parent><properties><!-- 声明项目配置依赖编码格式为 utf-8 --><project.build.sourceEncoding>UTF-8</project.build.sourceEncoding><project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding><!-- java jdk 版本声明 可变更 根据自己配置去匹配 --><java.version>15.0</java.version><maven.compiler.source>1.8</maven.compiler.source><maven.compiler.target>1.8</maven.compiler.target><fastjson.version>1.2.24</fastjson.version></properties><dependencies><!-- 对web开发的支持,包含了spring webmvc和tomcat等web开发的特性 --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><!-- spring boot核心,包括自动配置支持,日志和YAML --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId></dependency><!-- 使用jsp引擎,springboot内置tomcat没有此依赖 --><dependency><groupId>org.apache.tomcat.embed</groupId><artifactId>tomcat-embed-jasper</artifactId></dependency><!--        <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-jdbc</artifactId></dependency>--><dependency><groupId>org.mybatis.spring.boot</groupId><artifactId>mybatis-spring-boot-starter</artifactId><version>1.3.1</version></dependency><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId></dependency></dependencies><build><plugins><!-- 如果我们要直接Main启动spring,那么以下plugin必须要添加,否则是无法启动的。 --><!-- 如果使用maven的spring-boot:run的话就不需要此配置 --><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin><!-- mybatis generator 自动生成代码插件 --><plugin><groupId>org.mybatis.generator</groupId><artifactId>mybatis-generator-maven-plugin</artifactId><version>1.3.1</version><configuration><configurationFile>${basedir}/src/main/resources/generator/generatorConfig.xml</configurationFile><overwrite>true</overwrite><verbose>true</verbose></configuration></plugin></plugins></build>
</project>

在这里插入图片描述

5 安装Eclipse的MyBatis插件

按照下图的操作,进入Eclipse商店
在这里插入图片描述
输入MyBatis,然后检索
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

6 创建文件夹以及jsp文件

在这里插入图片描述
webapp/WEB-INF/jsp/amc01.jsp的内容如下

<%@ page language="java" contentType="text/html; charset=UTF-8"pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head><base href="http://localhost:8090/myweb/" /><meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <title>个人网站管理系统</title><link rel="shortcut icon" href="images/favicon.ico" type="image/x-icon" />
</head>
<body><form action="amc01/login" name="amc01from" method="post"><label for="login_userid">登陆用户名</label><input type="text" class="form-control" id="login_userid" name="login_userid" placeholder="Username"><br><label for="login_password">登陆密码</label><input type="password" class="form-control" id="login_password" name="login_password" placeholder="Password"><button type="submit" class="btn btn-default">Submit</button></form>
</body>
</html>

webapp/WEB-INF/jsp/amc02.jsp的内容如下

<%@ page language="java" contentType="text/html; charset=UTF-8"pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head><base href="http://localhost:8090/myweb/" /><meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <title>个人网站管理系统</title><link rel="shortcut icon" href="images/favicon.ico" type="image/x-icon" />
</head>
<body>账号登录失败!<br><a href="amc01">重新登录</a>
</body>
</html>

webapp/WEB-INF/jsp/index.jsp的内容如下
下面的标签没有起作用,使得两个If标签内的值都表示了出来。等研究明白了在来修改。

<%@ page language="java" contentType="text/html; charset=UTF-8"pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head><base href="http://localhost:8090/myweb/" /><meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <title>个人网站管理系统</title><link rel="shortcut icon" href="images/favicon.ico" type="image/x-icon" />
</head>
<body><c:if test=”${userinfo.user_name!=''}”>你的昵称是  ${userinfo.user_name}<br>你的邮件是  ${userinfo.email}<br>你的生日是  ${userinfo.birth_ymd}<br>你的电话号码是  ${userinfo.telphone_number}<br></c:if><c:if test=”${userinfo.user_name==''}”><a href="amc01">登录</a></c:if>
</body>
</html>

7 创建下面各种java类文件、xml、properties文件

在这里插入图片描述

7.1 com.study.WebAppMainApplication.java

创建包:com.study,然后在该包下面创建WebAppMainApplication.java的内容如下,这是启动整个web应用的程序

package com.study;import org.springframework.boot.SpringApplication;					
import org.springframework.boot.autoconfigure.SpringBootApplication;/*** 启动类**/
@SpringBootApplication						
public class WebAppMainApplication {/*** Web启动主方法* @param args*/public static void main(String[] args) {					// TODO Auto-generated method stub			SpringApplication.run(WebAppMainApplication.class, args);}
}

7.2 com.study.action.AMC01LoginAction .java

创建包:com.study.action,然后在该包下面创建AMC01LoginAction .java的内容如下,这是Service类调用的程序,负责实现更加具体的业务逻辑,service类通过调用各种Action类,实现一个完整的复杂的业务逻辑。

package com.study.action;public class AMC01LoginAction {}

7.3 com.study.controller.amc01.AMC01Controller .java

创建包:com.study.controller.amc01,然后在该包下面创建AMC01Controller .java的内容如下,这是点击jsp画面后,第一个跳转到的程序

package com.study.controller.amc01;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.ModelAttribute;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;import com.study.dto.AMC01InputDto;
import com.study.dto.AMC01OutputDto;
import com.study.service.AMC01Service;@Controller
public class AMC01Controller {/** 画面初始化事件 */private static final String EVT_INIT= "/";/** 画面跳转事件 */private static final String EVT_AMC01 = "amc01";/** 画面登录事件 */private static final String EVT_LOGIN = "amc01/login";@Autowiredprivate AMC01Service amc01Service;/*** 画面的初始化事件* @param m* @return*/@RequestMapping(EVT_INIT)public String init(Model m) {AMC01Form amc01from = new AMC01Form();m.addAttribute("userinfo", amc01from);// 视图重定向index.jspreturn "index";}/*** 跳转到amc01.jsp* @return*/@RequestMapping(EVT_AMC01)public String Amc01Jsp() {// 视图重定向amc01.jspreturn "amc01";}/*** 画面的登录事件* @param m* @param scmform* @return*/@RequestMapping(value = EVT_LOGIN, method = RequestMethod.POST)public String login(Model m, @ModelAttribute("amc01from") AMC01Form amc01from) {AMC01InputDto amc01InputDto = new AMC01InputDto();amc01InputDto.setLogin_userid(amc01from.getLogin_userid());amc01InputDto.setLogin_password(amc01from.getLogin_password());AMC01OutputDto amc01OutputDto = amc01Service.excute(amc01InputDto);if(amc01OutputDto.getUser_name() == null) {// 登录失败return "amc02";}else {// 登录成功跳转AMC01Form userinfo = new AMC01Form();userinfo.setUser_name(amc01OutputDto.getUser_name());userinfo.setEmail(amc01OutputDto.getEmail());userinfo.setBirth_ymd(amc01OutputDto.getBirth_ymd());userinfo.setTelphone_number(amc01OutputDto.getTelphone_number());m.addAttribute("userinfo", userinfo);// 视图重定向index.jspreturn "index";}}}

7.4 com.study.controller.amc01.AMC01Form .java

创建包:com.study.controller.amc01,然后在该包下面创建AMC01Form .java的内容如下,从Jsp向controller类传入值和从controller类向Jsp传出值的时候,需要把值存在这个form类里

package com.study.controller.amc01;public class AMC01Form {/*** 登陆用户ID*/private String login_userid;/*** 登陆密码*/private String login_password;/*** 用户名表示用*/private String user_name;/*** 邮件地址*/private String email;/*** 出生年月日*/private String birth_ymd;/*** 电话号码*/private String telphone_number;/*** 取得登陆用户ID* @return 登陆用户ID*/public String getLogin_userid() {return login_userid;}/*** 设定登陆用户ID* @param login_userid 登陆用户ID*/public void setLogin_userid(String login_userid) {this.login_userid = login_userid;}/*** 取得登陆密码* @return 登陆密码*/public String getLogin_password() {return login_password;}/*** 设定登陆密码* @param login_password 登陆密码*/public void setLogin_password(String login_password) {this.login_password = login_password;}/*** 取得用户名表示用* @return 用户名表示用*/public String getUser_name() {return user_name;}/*** 设定用户名表示用* @param user_name 用户名表示用*/public void setUser_name(String user_name) {this.user_name = user_name;}/*** 取得邮件地址* @return 邮件地址*/public String getEmail() {return email;}/*** 设定邮件地址* @param email 邮件地址*/public void setEmail(String email) {this.email = email;}/*** 取得出生年月日* @return 出生年月日*/public String getBirth_ymd() {return birth_ymd;}/*** 设定出生年月日* @param birth_ymd 出生年月日*/public void setBirth_ymd(String birth_ymd) {this.birth_ymd = birth_ymd;}/*** 取得电话号码* @return 电话号码*/public String getTelphone_number() {return telphone_number;}/*** 设定电话号码* @param telphone_number 电话号码*/public void setTelphone_number(String telphone_number) {this.telphone_number = telphone_number;}}

7.5 com.study.dto.AMC01InputDto .java

创建包:com.study.dto,然后在该包下面创建AMC01InputDto .java的内容如下,从controller类向service类传入值的时候、需要这个类保存值,一般命名为XXXInputDto

package com.study.dto;public class AMC01InputDto {/*** 登陆用户ID*/private String login_userid;/*** 登陆密码*/private String login_password;/*** 取得登陆用户ID* @return 登陆用户ID*/public String getLogin_userid() {return login_userid;}/*** 设定登陆用户ID* @param login_userid 登陆用户ID*/public void setLogin_userid(String login_userid) {this.login_userid = login_userid;}/*** 取得登陆密码* @return 登陆密码*/public String getLogin_password() {return login_password;}/*** 设定登陆密码* @param login_password 登陆密码*/public void setLogin_password(String login_password) {this.login_password = login_password;}
}

7.6 com.study.dto.AMC01OutputDto .java

创建包:com.study.dto,然后在该包下面创建AMC01OutputDto .java的内容如下,从service类向controller类传出值的时候、需要这个类保存值,一般命名为XXXOutputDto

package com.study.dto;public class AMC01OutputDto {/*** 用户名表示用*/private String user_name;/*** 邮件地址*/private String email;/*** 出生年月日*/private String birth_ymd;/*** 电话号码*/private String telphone_number;/*** 取得用户名表示用* @return 用户名表示用*/public String getUser_name() {return user_name;}/*** 设定用户名表示用* @param user_name 用户名表示用*/public void setUser_name(String user_name) {this.user_name = user_name;}/*** 取得邮件地址* @return 邮件地址*/public String getEmail() {return email;}/*** 设定邮件地址* @param email 邮件地址*/public void setEmail(String email) {this.email = email;}/*** 取得出生年月日* @return 出生年月日*/public String getBirth_ymd() {return birth_ymd;}/*** 设定出生年月日* @param birth_ymd 出生年月日*/public void setBirth_ymd(String birth_ymd) {this.birth_ymd = birth_ymd;}/*** 取得电话号码* @return 电话号码*/public String getTelphone_number() {return telphone_number;}/*** 设定电话号码* @param telphone_number 电话号码*/public void setTelphone_number(String telphone_number) {this.telphone_number = telphone_number;}}

7.7 com.study.dto.AMC01LoginUserInfoDto .java

创建包:com.study.dto,然后在该包下面创建AMC01LoginUserInfoDto .java的内容如下,这是普通的dto类,这里我用来存储repository类从db中检索后返回来的值

package com.study.dto;public class AMC01LoginUserInfoDto {/*** 用户名表示用*/private String user_name;/*** 邮件地址*/private String email;/*** 出生年月日*/private String birth_ymd;/*** 电话号码*/private String telphone_number;/*** 取得用户名表示用* @return 用户名表示用*/public String getUser_name() {return user_name;}/*** 设定用户名表示用* @param user_name 用户名表示用*/public void setUser_name(String user_name) {this.user_name = user_name;}/*** 取得邮件地址* @return 邮件地址*/public String getEmail() {return email;}/*** 设定邮件地址* @param email 邮件地址*/public void setEmail(String email) {this.email = email;}/*** 取得出生年月日* @return 出生年月日*/public String getBirth_ymd() {return birth_ymd;}/*** 设定出生年月日* @param birth_ymd 出生年月日*/public void setBirth_ymd(String birth_ymd) {this.birth_ymd = birth_ymd;}/*** 取得电话号码* @return 电话号码*/public String getTelphone_number() {return telphone_number;}/*** 设定电话号码* @param telphone_number 电话号码*/public void setTelphone_number(String telphone_number) {this.telphone_number = telphone_number;}}

7.8 com.study.entity.S001Entity .java

创建包:com.study.entity,然后在该包下面创建S001Entity .java的内容如下,这是数据库实体类,对应着数据库里S001表,主要用于SQL检索的时候,本博客中没有用到这个类。

package com.study.entity;public class S001Entity {/*** 登陆用户ID*/private String login_userid;/*** 登陆密码*/private String login_password;/*** 用户名表示用*/private String user_name;/*** 邮件地址*/private String email;/*** 出生年月日*/private String birth_ymd;/*** 电话号码*/private String telphone_number;/*** 取得登陆用户ID* @return 登陆用户ID*/public String getLogin_userid() {return login_userid;}/*** 设定登陆用户ID* @param login_userid 登陆用户ID*/public void setLogin_userid(String login_userid) {this.login_userid = login_userid;}/*** 取得登陆密码* @return 登陆密码*/public String getLogin_password() {return login_password;}/*** 设定登陆密码* @param login_password 登陆密码*/public void setLogin_password(String login_password) {this.login_password = login_password;}/*** 取得用户名表示用* @return 用户名表示用*/public String getUser_name() {return user_name;}/*** 设定用户名表示用* @param user_name 用户名表示用*/public void setUser_name(String user_name) {this.user_name = user_name;}/*** 取得邮件地址* @return 邮件地址*/public String getEmail() {return email;}/*** 设定邮件地址* @param email 邮件地址*/public void setEmail(String email) {this.email = email;}/*** 取得出生年月日* @return 出生年月日*/public String getBirth_ymd() {return birth_ymd;}/*** 设定出生年月日* @param birth_ymd 出生年月日*/public void setBirth_ymd(String birth_ymd) {this.birth_ymd = birth_ymd;}/*** 取得电话号码* @return 电话号码*/public String getTelphone_number() {return telphone_number;}/*** 设定电话号码* @param telphone_number 电话号码*/public void setTelphone_number(String telphone_number) {this.telphone_number = telphone_number;}}

7.9 com.study.repository.AMC01Repository .java

创建包:com.study.repository,然后在该包下面创建AMC01Repository .java的内容如下,这是和AMC01Repository.xml文件相对应的类,调用这个类后,就能调用到AMC01Repository.xml,然后就能实现对数据库的增删改查。
关于怎么传入参数的博客:https://blog.csdn.net/qq_38254897/article/details/84961223

package com.study.repository;import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;import com.study.dto.AMC01LoginUserInfoDto;@Mapper
public interface AMC01Repository {/*** 检索登陆用户的信息* @param login_userid 登陆用户ID* @param login_password 登陆密码* @return 登陆用户的信息*/public AMC01LoginUserInfoDto selectUserInfo(@Param("login_userid") String login_userid,@Param("login_password") String login_password);
}

7.10 com.study.service.AMC01Service .java

创建包:com.study.service,然后在该包下面创建AMC01Service .java的内容如下,这是controller类直接调用的程序,负责实现一段完整的业务逻辑。

package com.study.service;import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;import com.study.dto.AMC01InputDto;
import com.study.dto.AMC01LoginUserInfoDto;
import com.study.dto.AMC01OutputDto;
import com.study.repository.AMC01Repository;@Service
public class AMC01Service {@Autowiredprivate AMC01Repository amc01Repository;public AMC01OutputDto excute(AMC01InputDto amc01InputDto) {AMC01LoginUserInfoDto amc01LoginUserInfoDto = amc01Repository.selectUserInfo(amc01InputDto.getLogin_userid(), amc01InputDto.getLogin_password());AMC01OutputDto amc01OutputDto = new AMC01OutputDto();if(amc01LoginUserInfoDto != null) {amc01OutputDto.setUser_name(amc01LoginUserInfoDto.getUser_name());amc01OutputDto.setEmail(amc01LoginUserInfoDto.getEmail());amc01OutputDto.setBirth_ymd(amc01LoginUserInfoDto.getBirth_ymd());amc01OutputDto.setTelphone_number(amc01LoginUserInfoDto.getTelphone_number());}return amc01OutputDto;}
}

7.11 AMC01Repository.xml

在这里插入图片描述

在src/main/resources文件夹下,创建文件夹com/study/repository,不是包,然后创建AMC01Repository.xml。这里负责检索用户信息,这个文件可以写很多SQL,不限制写一个,可以写所有增删改查。

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.study.repository.AMC01Repository"><selectid="selectUserInfo" resultType="com.study.dto.AMC01LoginUserInfoDto">SELECT  USER_NAME,EMAIL,BIRTH_YMD,TELPHONE_NUMBERFROM S001WHERE LOGIN_USERID=#{login_userid}AND LOGIN_PASSWORD=#{login_password}</select>
</mapper>

7.12 application.properties

在src/main/resources文件夹下,创建文件application.properties
在这里插入图片描述
内容如下

spring.mvc.view.prefix=/WEB-INF/jsp/
spring.mvc.view.suffix=.jsp
spring.datasource.url=jdbc:mysql://127.0.0.1:3306/mydb?serverTimezone=Asia/Shanghai&characterEncoding=utf8
spring.datasource.username=root
spring.datasource.password=123456
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.jpa.properties.hibernate.hbm2dd1.auto=update
spring.jpa.show-sql=true
mybatis.mapper-locations: classpath:com/study/repository/*.xml
mybatis.type-aliases-package: com.study.dto
logging.level.org.lzq.tide.mapper=debug
server.context-path=/myweb
server.port=8090

8 启动web应用

打开WebAppMainApplication.java,鼠标右键单击,参照下图选择
在这里插入图片描述
我这里启动失败了,报了错误
参照下面这个博客,解决了我的问题:
java.sql.SQLException: Unable to load authentication plugin ‘caching_sha2_password‘.解决方法

上面博客的命令如下:
ALTER USER ‘root’@‘localhost’ IDENTIFIED BY ‘password’ PASSWORD EXPIRE NEVER; #修改加密规则
ALTER USER ‘root’@‘localhost’ IDENTIFIED WITH mysql_native_password BY ‘password’; #更新一下用户的密码
FLUSH PRIVILEGES; #刷新权限
再重置下密码:alter user ‘root’@‘localhost’ identified by ‘123456’;

再次启动获得成功
在这里插入图片描述
打开网页浏览器,访问:http://localhost:8090/myweb/
在这里插入图片描述
点击上面图片的登陆链接,跳转到下面的页面,输入
登陆用户名:5001
登陆密码:abc
点击submit按钮
在这里插入图片描述
成功跳转,成功获取用户信息
在这里插入图片描述
再次点击登陆链接,输入错误的用户名,点击submit按钮
在这里插入图片描述
提示登陆失败
在这里插入图片描述
点击重新登陆,正常跳转
在这里插入图片描述
经过上面的测试,说明实现了自己想要的功能。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/85659.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MySQL集群高可用架构之MHA

MHA 一、MHA概述1.1 为什么要用MHA&#xff1f;1.2 什么是 MHA&#xff1f;1.3 MHA 的组成1.4 MHA 的特点1.5 故障切换备选主库的算法1.5 MHA工作原理 二、MySQL MHA高可用实例2.1 架构搭建部分1&#xff09;所有节点服务器安装MySQL2&#xff09;主从节点服务器添加域名映射3&…

爬虫获取接口数据

上一讲讲的是获取静态网页数据的教程&#xff0c;适用于我们要爬取的数据在网页源代码中出现&#xff0c;但是还是有很多的数据是源代码中没有的&#xff0c;需要通过接口访问服务器来获得&#xff0c;下面我就来讲讲如何爬取这类数据。 以巨潮资讯网爬取比亚迪企业年报为例。…

人工智能的前世今生与未来

人工智能的前世今生与未来 一、 什么是人工智能二、人工智能的前世三、人工智能的今生四、人工智能的未来 一、 什么是人工智能 人工智能&#xff08;Artificial Intelligence&#xff0c;简称AI&#xff09;是指一种模拟人类智能行为的科学与技术。 人工智能通过计算机系统进…

美团2024届秋招笔试第一场编程[汇总](上课口胡一下)

一.小美的好矩阵 口胡&#xff1a;模拟题&#xff0c;数据和题意灰常清楚。 俩层循环枚举每个3&#xfe61;3的小矩阵&#xff0c;然后枚举每个小矩阵&#xff0c;12个if判断俩俩相邻的字符是否相等。这里有个技巧&#xff1a;拿出中间的字符&#xff0c;这样就能使用一个偏移…

【操作系统笔记十五】操作系统面试问题总结

1. 进程和线程的区别&#xff1f; 调度&#xff1a;进程是资源管理和分配的基本单位&#xff0c;线程是 CPU 调度程序执行的基本单位。切换&#xff1a;线程切换比进程切换要快得多&#xff0c;进程切换需要进行CPU上下文切换&#xff0c;而线程不需要。拥有资源&#xff1a; …

记录:移动设备软件开发(Android项目组织结构)

目录 Android项目管理结构ui管理ViewGroupUI控制 使用Android Studio开发Android应用简单、方便&#xff0c;除了创建Android项目&#xff0c;开发者只需要做两件事情&#xff1a;使用activity_main.xml文件定义用户界面&#xff1a;打开Java源代码编写业务实现。但对于一个喜欢…

Vue3+Ts+Vite项目(第十五篇)——tailwindcss安装及使用详解,css原子化如何实现

文章目录 一、装包二、初始化2.1 终端执行如下命令2.2 postcss.config.js 文件中2.3 tailwind.config.js 文件中 三、样式文件3.1 新建 tailwind.css 文件3.2 main.ts 中引入 四、使用4.1 写入类名即可4.2 简单讲解 五、插件5.1 安装 Tailwind CSS IntelliSense5.2 使用效果 六…

MySQL数据库入门到精通2--基础篇(函数,约束,多表查询,事务)

3. 函数 函数 是指一段可以直接被另一段程序调用的程序或代码。MySQL中的函数主要分为以下四类&#xff1a; 字符串函数、数值函数、日期函数、流程函数。 3.1 字符串函数 MySQL中内置了很多字符串函数&#xff0c;常用的几个如下&#xff1a; 演示如下&#xff1a; A. con…

uniapp——实现base64格式二维码图片生成+保存二维码图片——基础积累

最近在做二维码推广功能&#xff0c;自从2020年下半年到今天&#xff0c;大概有三年没有用过uniapp了&#xff0c;而且我之前用uniapp开发的程序还比较少&#xff0c;因此很多功能都浪费了很多时间去查资料&#xff0c;现在把功能记录一下。 这里写目录标题 效果图1.base64生成…

主动写入流对@ResponseBody注解的影响 | 京东云技术团队

问题回溯 2023年Q2某日运营反馈一个问题&#xff0c;商品系统商家中心某批量工具模板无法下载&#xff0c;导致功能无法使用&#xff08;因为模板是动态变化的&#xff09; 商家中心报错&#xff08;JSON串&#xff09;&#xff1a; {"code":-1,"msg":&…

【湖科大教书匠】计算机网络随堂笔记第1章(计算机网络概述)

目录 1.1、计算机网络在信息时代的作用 我国互联网发展状况 1.2、因特网概述 1、网络、互连网&#xff08;互联网&#xff09;和因特网 2、因特网发展的三个阶段 因特网服务提供者ISP(Internet Service Provider) 基于ISP的三层结构的因特网 3、因特网的标准化工作 4、因特网的…

在React中,什么是组件的状态(state)?如何更新组件的状态?

聚沙成塔每天进步一点点 ⭐ 专栏简介⭐ 创建和初始化状态⭐ 更新状态⭐ 注意事项⭐ 写在最后 ⭐ 专栏简介 前端入门之旅&#xff1a;探索Web开发的奇妙世界 欢迎来到前端入门之旅&#xff01;感兴趣的可以订阅本专栏哦&#xff01;这个专栏是为那些对Web开发感兴趣、刚刚踏入前…

力扣刷题笔记28——验证回文串/isalnum/逆序string

上一篇&#xff1a;力扣刷题笔记26——最小的k个数/快速排序学习/快排与冒泡的时间复杂度 文章目录 题目&#xff1a;我的方法&#xff1a;isalnum函数逆序string 题目&#xff1a; 如果在将所有大写字符转换为小写字符、并移除所有非字母数字字符之后&#xff0c;短语正着读和…

智能金融决策策略,规则引擎在大数据金融行业的实战案例

在金融风控场景中&#xff0c;规则引擎是一个核心风险管理的利器&#xff0c;它预先设定一系列规则设定&#xff0c;用于便捷的评估和处理各种交易、客户行为或其他需要自动化决策、计算、推理判断的情况。 以下是一个详细的示例&#xff0c;说明规则引擎在金融风控中的使用。 …

conda创建虚拟环境安装aix360

目录 创建虚拟环境查看已有虚拟环境进入所创建的虚拟环境查看已安装的程序查看已安装的python模块配置镜像pipconda 安装aix360将环境添加到jupyter删除虚拟环境 创建虚拟环境 conda create -n aix360 python3.9查看已有虚拟环境 conda env list进入所创建的虚拟环境 activa…

【教程】视频汇聚/视频监控管理平台EasyCVR录像存储功能如何优化?具体步骤是什么?

视频云存储/安防监控EasyCVR视频汇聚平台基于云边端智能协同&#xff0c;支持海量视频的轻量化接入与汇聚、转码与处理、全网智能分发、视频集中存储等。视频监控系统EasyCVR拓展性强&#xff0c;视频能力丰富&#xff0c;具体可实现视频监控直播、视频轮播、视频录像、云存储、…

uniapp 实现不同用户展示不同的tabbar(底部导航栏)

一、背景 最近在做一个uniapp开发的小程序遇到一个需求&#xff0c;希望不同用户登录后展示不同的tabbar页面&#xff0c;但是uniapp项目中的pages.json是只有一个list数组的&#xff0c;并且是不能写成动态效果&#xff0c;为了实现这个需求&#xff0c;便自定义了tabbar组件 …

面向面试知识--MySQL数据库与索引

面向面试知识–MySQL数据库与索引 优化难点与面试点 什么是MySQL索引&#xff1f; 索引的MySQL官方定义&#xff1a;索引是帮助MySQL快速获取数据的数据结构。 动力节点原文&#xff1a; MysQL官方对于索引的定义:索引是帮助MySQL高效获取数据的数据结构。 MysQL在存储数据之…

前后端分离的大数据毕设项目之基于Spark+springboot+vue的共享单车数据存储系统的设计与实现

博主介绍&#xff1a;✌全网粉丝10W,前互联网大厂软件研发、集结硕博英豪成立工作室。专注于计算机相关专业毕业设计项目实战6年之久&#xff0c;选择我们就是选择放心、选择安心毕业✌ &#x1f345;由于篇幅限制&#xff0c;想要获取完整文章或者源码&#xff0c;或者代做&am…

【数据结构】—交换排序之快速排序究极详解,手把手带你从简单的冒泡排序升级到排序的难点{快速排序}(含C语言实现)

食用指南&#xff1a;本文在有C基础的情况下食用更佳 &#x1f525;这就不得不推荐此专栏了&#xff1a;C语言 ♈️今日夜电波&#xff1a;靴の花火—ヨルシカ 0:28━━━━━━️&#x1f49f;──────── 5:03 …