>Java >java지도 시간 >MySQL에 연결할 때 \'java.sql.SQLException: Access Denied\' 오류가 발생하는 이유는 무엇입니까?

MySQL에 연결할 때 \'java.sql.SQLException: Access Denied\' 오류가 발생하는 이유는 무엇입니까?

DDD
DDD원래의
2024-10-25 03:19:02464검색

Why Am I Getting a

부족한 사용자 권한으로 MySQL에 액세스: "java.sql.SQLException: 액세스 거부" 해결

"java.sql. Java를 통해 MySQL 데이터베이스에 연결하는 동안 SQLException: 액세스 거부됨"이 발생하면 실망스러울 수 있습니다. 이 오류는 일반적으로 연결을 시도하는 사용자에게 데이터베이스에 액세스할 수 있는 적절한 권한이 없음을 나타냅니다.

귀하의 경우 다음 코드 조각에서 예외가 발생합니다.

<code class="java">Connection m_connection = DriverManager.getConnection("jdbc:mysql://localhost", "root", "root");</code>

코드 시도 "root" 비밀번호를 가진 "root" 사용자를 사용하여 localhost에서 실행 중인 MySQL 데이터베이스에 대한 연결을 설정합니다. 그러나 오류는 이러한 자격 증명에 데이터베이스에 액세스하는 데 필요한 권한이 없음을 나타냅니다.

이 문제를 해결하려면 연결을 시도하는 사용자에게 적절한 권한을 부여해야 합니다. MySQL에서는 다음 쿼리를 실행하여 이를 수행할 수 있습니다.

<code class="sql">GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' IDENTIFIED BY '%password%' WITH GRANT OPTION;</code>

"%password%"를 실제 MySQL 비밀번호로 바꾸십시오.

이 쿼리를 실행한 후에는 "루트" 사용자와 지정된 비밀번호를 사용하여 MySQL 데이터베이스에 성공적으로 연결할 수 있어야 합니다.

또는 두 번째 코드 조각에서:

<code class="java">Connection conn = (Connection) DriverManager.getConnection("jdbc:mysql://localhost/?user=root&password=rootpassword"); </code>

다른 접근 방식을 사용하고 있습니다. 연결 URL 자체에 사용자와 비밀번호를 포함합니다. 이 접근 방식은 편리할 수 있지만 비밀번호를 일반 텍스트로 노출하므로 일반적으로 보안 수준이 낮습니다.

데이터베이스 자격 증명을 직접 삽입하는 대신 구성 파일이나 기타 보안 메커니즘을 사용하여 저장하는 것이 항상 권장됩니다. 코드 또는 연결 URL.

위 내용은 MySQL에 연결할 때 \'java.sql.SQLException: Access Denied\' 오류가 발생하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.