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

완벽한 UTF8 지원하기

· 2년 전 · 761

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

이것은 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) 로 설정해주어야 한다.

댓글 작성

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

로그인하기

게시글 목록

번호 제목
16019
16015
16014
16013
16011
16010
16009
16008
16004
16003
16002
16001
15993
15992
15991
15988
15987
15986
15985
15981
15980
15979
15978
15977
15976
15975
15974
15973
15971
15970