알짜게시판

다국어 번역 함수 구현 방법

다국어 웹사이트를 구축할 때, 언어에 따라 텍스트를 자동으로 변환하는 기능은 필수적이다.
이 글에서는 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를 별도의 파일로 분리하거나 캐시 시스템과 연동하여 효율적으로 관리할 수 있다.

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

제목 글쓴이 조회 날짜
윈도우 ZImage AI 이미지 생성 환경 구축 방법 65 26-03-26
윈도우 파일 복사 후 실행 배치파일 - 에러 감지 포함 182 26-03-10
개발팁 네이버 검색 Open API 430 26-02-10
개발팁 네이버 검색광고 키워드 도구 API 검색 479 26-02-10
개발팁 MariaDB column_stats 테이블 오류 해결 방법 665 25-12-06
개발팁 PHP-FPM 에러 로그 실시간 모니터링 631 25-12-03
윈도우 윈도우11 업데이트 후 네트워크 드라이브 접근 불가 문제 해결 방법 1,264 25-11-24
개발팁 다국어 번역 함수 구현 방법 3,021 25-11-08
워드프레스 "치명적인 오류가 발생했습니다" 디버깅 가이드 13,839 25-10-31
리눅스 Apache 웹 로그 분석하기 – awk와 GoAccess 활용 18,396 25-10-28
윈도우 윈도11 강제업데이트 피하고 윈도10 계속 쓰기 41,571 25-10-12
리눅스 PHP 파일 업로드 용량 늘리기 56,475 25-10-03
개발팁 애드센스 충돌 문제 해결하기 74,464 25-09-20
파이썬 Python Playwright로 Edge 브라우저 제어하기 76,532 25-09-12
델파이 TDirectory.Delete 대신 CMD 으로 폴더 삭제 74,860 25-09-10
개발팁 애드센스 자동 광고 사용 시 빈 화면이 출력된다면? 159,124 25-06-20
워드프레스 xmlrpc.php 차단으로 보안 강화하기 136,854 25-06-05
델파이 폼이 모니터 한 가운데 있는 경우 자연스럽게 왼쪽으로 이동시키기 134,422 25-05-26
윈도우 WSH script registration is not valid. 134,614 25-05-23
워드프레스 제목 블록 기본값을 H5로 변경하는 방법 115,933 25-05-22
파이썬 동영상 특정 영역 모자이크(흐리게) 하기 47,642 25-04-30
리눅스 구글 크롬 콘솔 'Attestation check for Topics on' 에러 원인 &… 60,808 25-04-11
기타 크롬 - 개발자 도구(DevTools)에서 붙여넣기 안될때 73,360 25-03-10
그누보드 SmartEditor2Skin.html 다운로드 되는 현상 110,853 25-01-08
개발팁 검색 로봇 접속시 종료 57,098 24-10-07
리눅스 PHP-FPM 튜닝을 위한 메모리 계산 42,122 24-08-29
윈도우 아이폰 벨소리 쉽게 추가하기 95,062 24-06-14
윈도우 C:\Windows\Installer 폴더 다른 드라이브로 옮기기 105,995 24-05-29
개발팁 REQUEST 값 받기(application/json 포함) 99,940 24-04-20
리눅스 데몬(systemd service) 작성 및 실행하기 66,811 24-03-14
개발팁 업데이트 이후 에러 발생([ERROR] Incorrect definition of tabl… 92,416 23-12-08
목록
꽃한송이성장노트주점닷컴청년돈길결혼의신