>백엔드 개발 >PHP 튜토리얼 >PHP 사용자 비밀번호 암호화 알고리즘 분석 [Discuz 암호화 알고리즘]

PHP 사용자 비밀번호 암호화 알고리즘 분석 [Discuz 암호화 알고리즘]

高洛峰
高洛峰원래의
2017-02-06 16:12:282121검색

이 기사의 예에서는 PHP 사용자 비밀번호 암호화 알고리즘을 설명합니다. 참고하시라고 자세한 내용을 공유드립니다.

오늘 Discuz를 2차 개발로 사용하다가 코드에서 Discuz 사용자 이름과 비밀번호를 확인해야 했는데요. Discuz 포럼에는 사용자 데이터를 저장하는 테이블이 두 개 있는데, 하나는 Discuz 데이터베이스 ultrax의 pre_common_member에 있고 다른 하나는 UCenter 데이터베이스 ucenter의 uc_members 테이블에 저장되어 있기 때문에 함정에 빠졌습니다. ultrax 라이브러리에 있는 pre_common_member 데이터와 그 비밀번호가 어떻게 생성되는지 연구하는 데 많은 시간을 투자한 결과, 인터넷에서 무작위로 생성된다는 솔트를 검색해서 발견했습니다

생각했습니다. 무작위로 생성되었습니다. 로그인 시 소금은 어떻게 확인되나요? 그런데 온라인에서 Discuz는 실제로 해당 비밀번호를 전혀 사용하지 않는다고 하더군요. 직접 테스트해본 결과, pre_common_member에서 사용자 비밀번호를 변경해도 여전히 정상적으로 로그인이 되는 것 같았습니다. 그로 인해 나는 큰 우회로를 겪게 되었습니다.

본론으로 들어가겠습니다. Discuz의 비밀번호 암호화 알고리즘은 실제로 2개의 MD5 암호화입니다. 먼저 일반 텍스트로 한 번 암호화한 다음 무작위로 솔트를 생성하고 첫 번째 암호 텍스트 뒤에 솔트를 일반 텍스트로 추가합니다. .MD5 암호화를 다시 수행하십시오. 솔트는 uc_members 테이블에 저장되며 사용자 이름으로 얻을 수 있습니다.

이렇게:

MD5(MD5(plaintext)+salt)

다음은 .net 구현 코드입니다:

string GetDiscuzPWString(string sourceStr, string salt)
{
   return GetMd5Hash(string.Concat(GetMd5Hash(sourceStr),salt));
}
string GetMd5Hash(string input)
{
  MD5 md5Hasher = MD5.Create();
  byte[] data = md5Hasher.ComputeHash(Encoding.Default.GetBytes(input));
  StringBuilder sBuilder = new StringBuilder();
  for (int i = 0; i < data.Length; i++)
  {
    sBuilder.Append(data[i].ToString("x2"));
  }
  return sBuilder.ToString();
}

요약 비밀번호 판단 방법:

① UC를 설치하려면

② 데이터베이스를 열고 uc_members 테이블을 찾아 마지막 필드 "salt"를 찾은 후

안에 값을 복사합니다. ③ 의사 코드 :

$s=md5(md5("密码")."salt字段的值");
echo $s;

④ IF를 사용하여 판단

⑤ 다시 말해보세요! 그 난수는 6자리입니다!

이 글이 PHP 프로그래밍에 종사하는 모든 분들께 도움이 되기를 바랍니다.

더 많은 PHP 사용자 비밀번호 암호화 알고리즘 분석 [Discuz 암호화 알고리즘] 관련 기사를 보려면 PHP 중국어 사이트를 주목해주세요!

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