알짜게시판

[PHP] 다국어 번역 함수 구현 방법

다국어 웹사이트를 구축할 때, 언어에 따라 텍스트를 자동으로 변환하는 기능은 필수적이다.
이 글에서는 PHP로 간결하고 확장 가능한 다국어 번역 함수를 구현하는 방법을 소개한다.


기본 구조

아래는 예시로 작성된 번역 함수이다.

function __($str)
{
    global $meta;

    $translations = [
        '전체 카테고리' => [
            'en' => 'All Categories',
            'ja' => '全体カテゴリー',
            'zh' => '所有类别',
        ],
        '홈' => [
            'en' => 'Home',
            'ja' => 'ホーム',
            'zh' => '首页',
        ],
    ];

    $lang = $meta['lang'] ?? 'ko';

    if ($lang === 'ko') return $str;

    return $translations[$str][$lang] ?? $str;
}

이 함수는 $meta['lang'] 값에 따라 주어진 문자열 $str을 해당 언어로 변환한다.
기본 언어는 한글이며, 다른 언어로 변환이 지정되어 있지 않은 경우에는 원문을 그대로 반환한다.


$translations 배열

이 배열은 한글을 기준으로 한 번역 테이블이다.
각 한글 키에 대해 'en', 'ja', 'zh' 등 언어 코드를 지정하고 해당 번역 문자열을 매핑한다.

예를 들어 '전체 카테고리'라는 한글 문구가 있을 때, 영어에서는 "All Categories",
일본어에서는 "全体カテゴリー", 중국어에서는 "所有类别"로 변환된다.

언어를 추가할 때는 이 배열에 새로운 언어 코드와 번역을 추가하기만 하면 된다.


$meta['lang'] 설정

글로벌 변수 $meta에서 현재 페이지의 언어 설정을 가져온다.
만약 설정이 존재하지 않는다면 'ko'를 기본값으로 사용한다.

이 값은 보통 페이지 상단의 설정 파일에서 지정되며,
사용자의 선택 언어나 사이트 환경설정에 따라 동적으로 변경된다.


한국어 처리 분기

if ($lang === 'ko') return $str;

현재 언어가 한국어일 경우, 별도의 번역이 필요하지 않으므로 원문을 그대로 반환한다.
이 조건문은 빠른 종료(early return) 구조로 작성되어 불필요한 연산을 줄인다.


번역 반환 로직

return $translations[$str][$lang] ?? $str;

?? 연산자는 PHP의 null 병합 연산자이다.
해당 번역이 존재하면 그 값을 반환하고, 존재하지 않으면 $str을 그대로 반환한다.

이 구조는 키가 존재하지 않을 때 발생할 수 있는 오류를 예방하며,
불필요한 조건문을 줄여 코드 가독성을 높인다.


언어 확장 방법

언어를 추가하려면 $translations 배열에 새로운 언어 코드를 추가한다.
예를 들어 프랑스어를 지원하려면 다음과 같이 작성한다.

'홈' => [
    'en' => 'Home',
    'ja' => 'ホーム',
    'zh' => '首页',
    'fr' => 'Accueil',
],

이 방식은 다국어 확장이 용이하며, 유지보수 시에도 구조를 한눈에 파악할 수 있다.


마무리

이 함수는 구조가 단순하고 동작이 명확하다.
한글을 기준으로 각 언어의 번역을 관리하기 때문에 별도의 데이터베이스나 파일 구조가 필요하지 않다.

사이트 내에서 반복적으로 사용되는 단어를 일관된 형태로 처리하기에 적합하며,
규모가 커질 경우 $translations를 별도의 파일로 분리하거나 캐시 시스템과 연동하여 효율적으로 관리할 수 있다.

로그인 후 댓글내용을 입력해주세요

제목 글쓴이 조회 날짜
[PHP] 다국어 번역 함수 구현 방법 213 3시간 전
[워드프레스] "치명적인 오류가 발생했습니다" 디버깅 가이드 11,123 25-10-31
[리눅스] Apache 웹 로그 분석하기 – awk와 GoAccess 활용 15,572 25-10-28
[칼무리] 외부 명령으로 캡처 자동화하기 1 36,857 25-10-14
[윈도우] 윈도11 강제업데이트 피하고 윈도10 계속 쓰기 38,907 25-10-12
[리눅스] PHP 파일 업로드 용량 늘리기 54,149 25-10-03
[HTML] 애드센스 충돌 문제 해결하기 73,982 25-09-20
[파이썬] Python Playwright로 Edge 브라우저 제어하기 75,851 25-09-12
[델파이] TDirectory.Delete 대신 CMD 으로 폴더 삭제 74,364 25-09-10
[윈도우] Chrome 및 Edge를 TLS 1.2 모드로 실행 73,475 25-08-30
[HTML] 애드센스 자동 광고 사용 시 빈 화면이 출력된다면? 158,546 25-06-20
[윈도우] 브라우저 환경설정 추출 145,026 25-06-18
[워드프레스] xmlrpc.php 차단으로 보안 강화하기 136,378 25-06-05
[델파이] 폼이 모니터 한 가운데 있는 경우 자연스럽게 왼쪽으로 이동시키기 133,946 25-05-26
[윈도우] WSH script registration is not valid. 134,061 25-05-23
[워드프레스] 제목 블록 기본값을 H5로 변경하는 방법 115,494 25-05-22
[파이썬] 동영상 특정 영역 모자이크(흐리게) 하기 47,105 25-04-30
[리눅스] 구글 크롬 콘솔 'Attestation check for Topics on' 에러 원인 & 해결방… 60,241 25-04-11
[크롬] 개발자 도구(DevTools)에서 붙여넣기 안될때 72,536 25-03-10
[그누보드] SmartEditor2Skin.html 다운로드 되는 현상 110,418 25-01-08
[윈도우] 네트워크 탐지 114,800 24-12-31
[델파이] TrayIcon 이 흐릿하게 보이는 버그? 수정 128,389 24-12-12
[델파이] 실행 중인 프로세스가 활성 창인지 확인하는 함수 145,694 24-11-02
[델파이] 메세지 다이어그램(Message Dialog) 에 체크박스(CheckBox) 추가 132,606 24-10-30
[그누보드] 부트스트랩 테마 예제로 사용중인 main.php 116,197 24-10-21
[그누보드] 유튜브 스킨 75,554 24-10-14
[윈도우] TLS 연결 끊김 해결 방법 - Kyber 비활성화 279,597 24-10-12
[PHP] 검색 로봇 접속시 종료 56,690 24-10-07
[윈도우] WinDivert 사용중인 어플리케이션 검색 46,012 24-09-12
[워드프레스] 답글 남기기 메시지 변경 43,162 24-09-05
[리눅스] PHP-FPM 튜닝을 위한 메모리 계산 41,731 24-08-29
강남언니야주방연구소잡학지식의료건강망치와삽