테스트 사이트 - 개발 중인 베타 버전입니다

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

· 3년 전 · 4375 · 4

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

 

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

 

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

게시글 목록

번호 제목
24318
24317
24315
24309
24294
24293
24277
24262
24260
24253
24251
24236
24233
24228
24226
24221
24214
24203
24201
24199
24196
24195
24194
24192
24191
24187
24185
24183
24172
24168