나너우리

Mysql 8.x 사용시 password 함수 처리

한동안 관리 안하던 홈페이지를 새로운 서버로 옮기면서 모든 것을 다 업데이트 했습니다.

 

그런데 로그인이 안되더군요.

 

찾아보니 mysql 8.x 에서는 pasword 함수가 없어 졌네요.

 

lib/common.lib.php의 sql_password 함수를 기존 password 대신에 CONCAT('*', UPPER(SHA1(UNHEX(SHA1('$value')))))로 수정 해 주니 되네요.

 

function sql_password($value)
{
    // mysql 4.0x 이하 버전에서는 password() 함수의 결과가 16bytes
    // mysql 4.1x 이상 버전에서는 password() 함수의 결과가 41bytes
   //  $row = sql_fetch(" select password('$value') as pass ");
    $row = sql_fetch(" SELECT CONCAT('*', UPPER(SHA1(UNHEX(SHA1('$value'))))) as pass ");

    return $row['pass'];
}
 

|

댓글 4개

2020년 10월 기준 8.0.22 버전이 최신이다. 8.0으로 업데이트되면서 새로운 기능을 넣기 위해 하위호환을 많이 포기했으므로, 버전 업데이트 시 주의할 필요가 있다.
라고 하는데...

mysql 8.x 를 사용하시는군요.
사용상 특이점이나 다른 사항이 발견되면 공유 부탁드립니다
@해피정 일부 테마나 게시판 스킨에 코드 호환이 있었지만 기본 기능에는 패스워드 이슈 밖에는 현재 없는 것 같습니다.
저거땜에 8로 올렸다가 바로 5.x로 재설치했었던 기억이...
@약관동의 저도 로그인 안되서 한참을 헤멨었습니다.
댓글을 작성하시려면 로그인이 필요합니다.

그누보드5 팁자료실

+
제목 글쓴이 날짜 조회
4년 전 조회 5,490
4년 전 조회 3,821
4년 전 조회 3,691
4년 전 조회 5,651
4년 전 조회 3,727
4년 전 조회 3,589
4년 전 조회 2,738
4년 전 조회 3,147
4년 전 조회 4,381
4년 전 조회 2,374
4년 전 조회 3,652
4년 전 조회 2,472
4년 전 조회 2,327
4년 전 조회 2,982
4년 전 조회 4,546
4년 전 조회 2,945
4년 전 조회 3,382
4년 전 조회 4,196
4년 전 조회 3,232
4년 전 조회 3,516
4년 전 조회 2,791
4년 전 조회 3,134
4년 전 조회 6,958
4년 전 조회 2,869
4년 전 조회 6,666
4년 전 조회 8,346
4년 전 조회 3,768
4년 전 조회 4,149
4년 전 조회 2,980
4년 전 조회 3,624