부족한 사용자 권한으로 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!