>백엔드 개발 >PHP 문제 >PHP가 mssql에 연결할 수 없는 경우 수행할 작업

PHP가 mssql에 연결할 수 없는 경우 수행할 작업

藏色散人
藏色散人원래의
2021-07-19 10:29:052360검색

mssql에 연결할 수 없는 PHP에 대한 해결 방법: 1. 인증 모드를 수정합니다. 2. 계정 비밀번호를 수정하고 확인합니다. 3. 데이터베이스에 액세스할 수 있는 계정 권한을 활성화합니다.

PHP가 mssql에 연결할 수 없는 경우 수행할 작업

이 기사의 운영 환경: windows7 시스템, PHP7.1 버전, DELL G3 컴퓨터

php가 mssql에 연결할 수 없으면 어떻게 해야 합니까?

php는 보통 mysql 데이터베이스와 함께 사용하는데, 일부 기업용 애플리케이션을 개발할 때 기업의 원래 애플리케이션은 MSSQL을 사용하기 때문에 php를 SQL Server에 연결해야 합니다.

이것도 큰 함정입니다. php를 사용하여 SQL에 연결합니다. 서버 오류의 3가지 일반적인 이유...

php를 mssql에 연결하기 전에 먼저 sqlsrv 확장 프로그램을 설치해야 하는데 이 역시 함정이 많습니다.

SQL Server에 연결하기 위한 PHP 코드는 다음과 같습니다

//$serverName = "localhost";
$serverName = "127.0.0.1";
$connectionInfo = array( "Database"=>"qinziheng", "UID"=>"sa", "PWD"=>"123456");
$conn = sqlsrv_connect( $serverName, $connectionInfo);
if( $conn ) {
     echo "Connection established.<br />";
}else{
     echo "Connection could not be established.<br />";
     die( print_r( sqlsrv_errors(), true));
}

1. 인증 모드가 잘못되었습니다

SQL Server에는 두 가지 인증 모드,

1-1) Windows 인증 모드,

를 사용합니다. Windows 시스템 계정의 계정 또는 도메인.

1-2) SQL Server 인증 모드. 일부는 SQL Server 및 Windows 인증 모드라고도 합니다.

SQL Server 데이터베이스에서 생성된 계정을 사용하세요.

2차 SQL Server 인증 모드를 사용하는 것이 좋습니다.

2. 계정 비밀번호가 올바르지 않습니다.

php가 msql 데이터베이스에 연결되면 Windows 시스템 계정, 도메인 계정 및 SQL Server 데이터베이스 계정이 포함됩니다.

처음 연결하는 사람들의 경우, 어느 것을 선택해야할지 모르겠습니다.

PHP를 사용하여 mssql 데이터베이스를 개발할 때 1-2에서 SQL Server ID 인증 모드를 사용합니다. SQL Server 데이터베이스 계정을 사용하여 연결은 성공하지만 도메인 계정 연결에 실패합니다.

Windows 시스템 계정과 SQL Server 데이터베이스 계정 간의 관계는 Linux 시스템 계정과 MySQL 데이터베이스 계정 간의 관계와 같습니다. Linux에서는 www 사용자를 사용하여 MySQL에 로그인하고 연결할 수 없습니다. 데이터 베이스.

3. 데이터베이스에 대한 무단 액세스

계정과 비밀번호가 정확하더라도 mssql에 대한 PHP 연결이 여전히 실패하는 이유는 귀하의 계정에 데이터베이스에 대한 액세스 권한이 없기 때문입니다. SSMS(SQL Server Management Studio)에 사용자 권한을 부여하거나 해당 보안 그룹에 사용자를 추가합니다.

오류가 발생하는 또 다른 이유가 있습니다

위의 세 가지 이유는 개발 중에 자주 발생합니다. PHP와 SQL Server가 다른 호스트에 설치된 경우 SQL Server가 원격 연결을 허용하지 않을 가능성이 있습니다. 그리고 접근.

추천 학습: "PHP 비디오 튜토리얼"

위 내용은 PHP가 mssql에 연결할 수 없는 경우 수행할 작업의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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