본문으로 이동
주 메뉴
주 메뉴
사이드바로 이동
숨기기
둘러보기
대문
최근 바뀜
임의의 문서로
미디어위키 도움말
특수 문서 목록
학교의 모든 지식. SMwiki
검색
검색
보이기
로그인
개인 도구
로그인
로그아웃한 편집자를 위한 문서
더 알아보기
기여
토론
OAuth2.0 연동
편집하기
문서
토론
한국어
읽기
편집
원본 편집
역사 보기
도구
도구
사이드바로 이동
숨기기
동작
읽기
편집
원본 편집
역사 보기
일반
여기를 가리키는 문서
가리키는 글의 최근 바뀜
파일 올리기
문서 정보
보이기
사이드바로 이동
숨기기
Sam
(
토론
|
기여
)
님의 2025년 7월 10일 (목) 07:09 판
(
차이
)
← 이전 판
|
최신판
(
차이
) |
다음 판 →
(
차이
)
경고: 이 문서의 오래된 판을 편집하고 있습니다.
이것을 게시하면, 이 판 이후로 바뀐 모든 편집이 사라집니다.
경고:
로그인하지 않았습니다. 편집을 하면 IP 주소가 공개되게 됩니다.
로그인
하거나
계정을 생성하면
편집자가 사용자 이름으로 기록되고, 다른 장점도 있습니다.
스팸 방지 검사입니다. 이것을 입력하지
마세요
!
== 개요 == OAuth2.0을 위키에 물리는 방법에 대해 다루는 문서. 이 문서는 미디어위키에 내가 직접 만든 OAuth2.0 인증 서버를 연동하여 로그인 기능을 구현하는 과정을 설명한다. == 전제 조건 == * 미디어위키 버전: 1.35 이상 * PHP 버전: 7.4 이상 * OAuth2 제공자(Authorization Server)는 RFC 6749를 준수 * 사용자 정보를 제공하는 <code>/userinfo</code> 엔드포인트 존재 == 과정 == {| class="wikitable" !과정 !설명 !비고 |- |확장기능 설치 |PluggableAuth(인증 플러그인 인터페이스), OAuth2Client(OAuth2 인증 연동용)를 설치한다. |<syntaxhighlight lang="bash"> # extensions 디렉토리에서 다음의 코드를 차례대로 실행. cd /var/www/html/mediawiki/extensions # PluggableAuth 확장 git clone https://gerrit.wikimedia.org/r/mediawiki/extensions/PluggableAuth cd PluggableAuth git checkout REL1_43 # 버전 맞춰주는 과정. composer install --no-dev # OAuth2Client 확장 cd .. git clone https://github.com/United-Earth-Team/MW-OAuth2Client.git OAuth2Client cd OAuth2Client composer install --no-dev --no-plugins --no-scripts # SSL 문제로.. 무시하기 위해서. </syntaxhighlight> |- |LocalSettings.php |일단 임시로 박아놓는다. |<syntaxhighlight lang="php"> wfLoadExtension( 'PluggableAuth' ); wfLoadExtension( 'OAuth2Client' ); $wgPluggableAuth_Class = "OAuth2Client"; // 클라이언트 등록 정보 $wgOAuth2Client['client']['id'] = 'mediawiki-client-id'; $wgOAuth2Client['client']['secret'] = 'mediawiki-client-secret'; $wgOAuth2Client['client']['redirect_uri'] = 'https://smwiki.info/index.php/Special:PluggableAuthLogin'; // OAuth2 인증 서버 엔드포인트 $wgOAuth2Client['authorization']['endpoint'] = 'https://auth.example.com/oauth/authorize'; $wgOAuth2Client['token']['endpoint'] = 'https://auth.example.com/oauth/token'; $wgOAuth2Client['userinfo']['endpoint'] = 'https://auth.example.com/api/userinfo'; // 사용자 매핑 필드 $wgOAuth2Client['userinfo']['username'] = 'username'; $wgOAuth2Client['userinfo']['email'] = 'email'; $wgOAuth2Client['userinfo']['realname'] = 'realname'; // 선택 // 로그인 UI 설정 $wgPluggableAuth_EnableAutoLogin = false; $wgPluggableAuth_ButtonLabel = "로그인 (OAuth2)"; </syntaxhighlight> |- |확인 |설치가 잘 되었는지 확인. PluggableAuth와 OAuth2Client이 잘 있나 확인. |[[특수:버전]] |- |값 기입 | | |} == OAuth2 서버 설정 == OAuth2 서버(내가 만든 인증 제공자)에 클라이언트 등록: * 클라이언트 ID: <code>mediawiki-client-id</code> * 리디렉션 URI: <code>https://smwiki.info/index.php/Special:PluggableAuthLogin</code> * 권한 범위 (scope): <code>openid email profile</code> 등 [[분류:관리용 문서]]
요약:
학교의 모든 지식. SMwiki에서의 모든 기여는 크리에이티브 커먼즈 저작자표시-동일조건변경허락 라이선스로 배포된다는 점을 유의해 주세요(자세한 내용에 대해서는
학교의 모든 지식. SMwiki:저작권
문서를 읽어주세요). 만약 여기에 동의하지 않는다면 문서를 저장하지 말아 주세요.
또한, 직접 작성했거나 퍼블릭 도메인과 같은 자유 문서에서 가져왔다는 것을 보증해야 합니다.
저작권이 있는 내용을 허가 없이 저장하지 마세요!
취소
편집 도움말
(새 창에서 열림)
검색
검색
OAuth2.0 연동
편집하기
새 주제