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

완벽한 UTF8 지원하기

· 2년 전 · 762

가끔 개발과정에 디비에 저장한 텍스트가 페이지에서는 깨진 글처럼 보일 때가 있다.

이것은 UTF8을 제대로 구현하지 못한것을 의미한다.

이번 글에서는 PHP, HTML 쪽에서 이문제를 어떻게 해결 하는지 샘플코드로 설명하려고 한다.

1. 입력값에 대한 UTF8설정

PHP에서 클라이언트쪽에서 요청보내어진 문자열을 정확히 UTF8처리하려면

[code]

$string = $_REQUEST['user_comment'];
if (!mb_check_encoding($string, 'UTF-8')) {
// 문자열이 UTF8인코딩이 아니면 UTF8로 인코딩한다.
$actualEncoding = mb_detect_encoding($string);
$string = mb_convert_encoding($string, 'UTF-8', $actualEncoding);

// $string 을 디비에 저장 또는 그어떤 로직 실행....
}
[/code]

만일 웹페이지에서 form태그로 서버에 값을 넘긴다면

[code]

<form action="somepage.php" accept-charset="UTF-8">
[/code]

이렇게 해주는것이 좋다.

 

2. 출력값에 대한 UTF8

PHP에서 직접 UTF8인코딩 헤더를 작성해줄수 있다.

[code]

header('Content-Type: text/html; charset=utf-8');
[/code]

만일 출력을 HTML페이지로 한다면

[code]

HTML5

<meta charset="utf-8">
낮은 버전에서는 

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

[/code]

 

3. 디비에서 UTF8

디비의 charset, collation을 utf8mb4(MySQL < 5.5.3 은 utf8) 로 설정해주어야 한다.

댓글 작성

댓글을 작성하시려면 로그인이 필요합니다.

로그인하기

게시글 목록

번호 제목
15935
15934
jQuery .first()
15933
15932
15931
15930
15929
15928
15924
15923
15922
15921
15920
15919
15917
15916
15915
15914
15913
15912
15911
15910
15909
15908
15907
15906
15901
15900
15899
15898