Java Web之MySQL在项目中的使用

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 尴尬:access denied for user ’root’@’localhost’ using password yes有时候,在连接 MySQL 数据的时候,会报一个错误信息 "access denied for user ’root’@’localhost’ using password yes",看到这个错误不要一脸懵逼,造成错误的原因就是数据库访问的用户名或密码不正确,这时候一般又分为以下两种情况,分别说一说解决方法。

尴尬:access denied for user ’root’@’localhost’ using password yes

有时候,在连接 MySQL 数据的时候,会报一个错误信息 "access denied for user ’root’@’localhost’ using password yes",看到这个错误不要一脸懵逼,造成错误的原因就是数据库访问的用户名或密码不正确,这时候一般又分为以下两种情况,分别说一说解决方法。

一、新安MySQL未设置密码,这种情况就需要添加密码,如何添加?
1、用空密码方式使用root用户登录 MySQL

mysql -u root

2、修改root用户的密码:

mysql>update 数据库名称 set password=PASSWORD('新的密码') where USER='root'
mysql>flush privileges;
mysql>quit

3、重新启动MySQL,就可以使用新密码登录了

二、好久不用,忘记密码

1、打开DOS进入mysql下bin目录:本人:D:\Development\mysql-5.5.29-winx64\bin
2、停止mysql服务,net stop mysql
3、在D:\Development\mysql-5.5.29-winx64\bin 后面输入:
mysqld --defaults-file="D:\Development\mysql-5.5.29-winx64\bin\my.ini" --console --skip-grant-tables
4、重新打开一个DOS窗口,在D:\Development\mysql-5.5.29-winx64\bin后面输入:mysql -root -p
5、提示输入密码,在Enter后面输入密码,进入mysql>
6、在mysql>下输入:

mysql>update 数据库名称 set password=PASSWORD('新的密码') where USER='root'
mysql>flush privileges;
mysql>quit

注意:若有多个数据库可多次update操作即可。

通过属性文件来配置MySQL

一、常见的连接数据的方式

  • 编码方式,将数据库配置信息直接写入JAVA代码之中
  • Properties属性文件,将数据库配置信息写在属性文件中,然后在程序中读取该属性文件。
  • 数据源,用JNDI来获取DataSource 对象,从而的到Connection对象。
  • Hibernate配置
  • Spring配置

二、属性文件(.properties)配置与读取

1、配置文件users.properties

jdbc.drivers=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/databaseName
jdbc.username=root
jdbc.password=upassword

2、读取属性文件

(1) 创建Properties的对象;

Properties properties = new Properties();

这一步也可以这样做:创建继承Properties的类,并以单例模式获取对象。

(2) 使用Class对象的getResourceAsStream()方法,把指定的属性文件读入到输入流中,并使用Properties类中的load()方法,从输入流中读取属性列表(键/值对);

private String resource = "users.properties";
//假如配置文件名为users.properties
InputStream in = getClass().getResourceAsStream(resource);
properties.load(in);

(3) 在使用数据库连接时,使用Properties类中的getProperty()方法,通过key获取value值,从而实现数据库连接的操作。

String drivers = props.getProperty("jdbc.drivers");
String url = props.getProperty("jdbc.url");
String username = props.getProperty("jdbc.username");
String password = props.getProperty("jdbc.password");
//返回的是Connection类的实例
Class.forName(drivers);
return DriverManager.getConnection(url, username, password);

MySQL连接池

一、为什么使用数据源和连接池
应用程序需要频繁的连接数据库的,如果每次操作都连接数据库,然后关闭,这样做性能一定会受限。所以,一定要想办法复用数据库的连接。使用连接池可以达到复用数据库连接的目的。

二、连接池概念
连接池是用来管理Connection 对象的,连接池可以从数据源中获得连接,连接池中可以有若干个数据库连接对象,这些连接对象可以被重用。应用程序需要连接时,就向连接池申请,如果连接池中有空闲的连接,就会分配给应用程序,如果没有,可能就需要在等待队列里等待。

三、MySQL连接池配置

1、把数据库驱动包 以及JSTL的jar包 copy 到 %CATALINA_HOME%\lib 下。
2、修改 %CATALINA_HOME%\conf\server.xml 文件,在 <Host> 节点下添加:

<!-- appName 为项目名 docBase一定要准确 &符号要换成&--!>
<Context path="/appName" docBase="appName\WebRoot" auth="Container">
      <Resource name="jdbc/MySQLDS" scope="Shareable"
            type="javax.sql.DataSource"
            url="jdbc:mysql://localhost:3306/kqxt?useUnicode=true&characterEncoding=utf-8"
            driverClassName="com.mysql.jdbc.Driver"
            username="root" password="root"
            maxWait="3000" maxIdle="100" maxActive="10" />
</Context>

3、修改 web.xml,在 <web-app> 节点下添加下面内容

<resource-ref>
<description>Mysql Datasource example</description>
<res-ref-name>MySQLDS</res-ref-name>
<res-type>javax.sql.DataSource</res-type>
<res-auth>Container</res-auth>
</resource-ref>

4、在代码中获取数据库连接

// 注意导入的包名
import java.sql.Connection;
import javax.naming.Context;
import javax.naming.InitialContext;
import javax.sql.DataSource;
public class DBUtil {
public static Connection getConnection() throws Exception {
      Context context = new InitialContext();
      // 获取数据源
      DataSource ds = (DataSource) context.lookup("java:comp/env/jdbc/MySQLDS");
      // 获取数据库连接
      Connection conn = ds.getConnection();
      if (conn != null && !conn.isClosed()) {
             return conn;
         } else {
             return null;
            }
      }
}
相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
7天前
|
自然语言处理 算法 Java
Java如何判断两句话的相似度类型MySQL的match
【9月更文挑战第1天】Java如何判断两句话的相似度类型MySQL的match
13 2
|
8天前
|
存储 JSON 数据安全/隐私保护
"FastAPI身份验证与授权的奥秘:如何用Python打造坚不可摧的Web应用,让你的项目一鸣惊人?"
【8月更文挑战第31天】在现代Web开发中,保证应用安全性至关重要,FastAPI作为高性能Python框架,提供了多种身份验证与授权方式,包括HTTP基础认证、OAuth2及JWT。本文将对比这些机制并附上示例代码,展示如何使用HTTP基础认证、OAuth2协议以及JWT进行用户身份验证,确保只有合法用户才能访问受保护资源。通过具体示例,读者可以了解如何在FastAPI项目中实施这些安全措施。
30 1
|
8天前
|
存储 数据库 开发者
Web2py的神秘力量:如何用Python打造快速原型设计与开发,让你的项目一鸣惊人?
【8月更文挑战第31天】在现代软件开发中,快速原型设计至关重要。Web2py作为一款Python Web框架,凭借其简洁的语法和高效开发流程受到开发者青睐。本文通过在线调查问卷系统的案例,展示Web2py在快速原型设计中的应用,包括需求分析、数据库设计、表单创建及路由实现,并提供示例代码,帮助读者理解其最佳实践。
|
10天前
|
安全 Java 关系型数据库
Java连接Mysql SSL初始化失败
Java连接Mysql SSL初始化失败
|
8天前
|
Java Maven Android开发
解锁Web开发新技能:从零开始的Struts 2之旅——让你的Java编程之路更加宽广,首个应用实例带你飞!
【8月更文挑战第31天】对于初学者,掌握 Struts 2 框架不仅能提升 Web 开发能力,还能深入了解 MVC 架构。Struts 2 是一个基于 Servlet 的 Java 框架,提供表单验证、文件上传、国际化等功能,便于快速构建易维护的 Web 应用。本文通过示例演示如何从零开始搭建环境并创建一个简单的 Struts 2 项目,包括配置 `struts.xml`、编写 Action 类及视图文件,并配置 web.xml。通过这些步骤,你将学会基本的开发流程,为进一步学习高级功能打下基础。
20 0
|
8天前
|
开发者 安全 SQL
JSF安全卫士:打造铜墙铁壁,抵御Web攻击的钢铁防线!
【8月更文挑战第31天】在构建Web应用时,安全性至关重要。JavaServer Faces (JSF)作为流行的Java Web框架,需防范如XSS、CSRF及SQL注入等攻击。本文详细介绍了如何在JSF应用中实施安全措施,包括严格验证用户输入、使用安全编码实践、实施内容安全策略(CSP)及使用CSRF tokens等。通过示例代码和最佳实践,帮助开发者构建更安全的应用,保护用户数据和系统资源。
19 0
|
8天前
|
开发者 前端开发 开发框架
JSF与移动应用,开启全新交互体验!让你的Web应用轻松征服移动设备,让用户爱不释手!
【8月更文挑战第31天】在现代Web应用开发中,移动设备的普及使得构建移动友好的应用变得至关重要。尽管JSF(JavaServer Faces)主要用于Web应用开发,但结合Bootstrap等前端框架,也能实现优秀的移动交互体验。本文探讨如何在JSF应用中实现移动友好性,并通过示例代码展示具体实现方法。使用Bootstrap的响应式布局和组件可以确保JSF页面在移动设备上自适应,并提供友好的表单输入和提交体验。尽管JSF存在组件库较小和学习成本较高等局限性,但合理利用其特性仍能显著提升用户体验。通过不断学习和实践,开发者可以更好地掌握JSF应用的移动友好性,为Web应用开发贡献力量。
16 0
|
8天前
|
存储 测试技术 开发者
FastAPI异步处理的神奇之处:如何用Python打造高性能Web应用,让你的项目一鸣惊人?
【8月更文挑战第31天】在现代Web开发中,高性能至关重要。FastAPI作为一款高性能Python Web框架,支持多种异步处理方式,包括非阻塞I/O、异步函数(async/await)及异步上下文管理器(async with),能够大幅提升应用性能。本文通过示例代码详细介绍了FastAPI中的异步处理方法,并分享了最佳实践,帮助开发者构建高效的Web应用。
28 0
|
10天前
|
jenkins Java Shell
jenkins学习笔记之十三:配置SonarScanner扫描Java项目
jenkins学习笔记之十三:配置SonarScanner扫描Java项目
|
13天前
|
存储 Prometheus 中间件
2020最佳人气项目之Go Web框架
2020最佳人气项目之Go Web框架

热门文章

最新文章