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

완벽한 UTF8 지원하기

· 2년 전 · 756

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

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

댓글 작성

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

로그인하기

게시글 목록

번호 제목
16801
16798
16796
16795
16791
16790
16785
16777
16776
16766
16760
16759
16740
16737
16735
16728
16713
16700
16691
16669
16668
16660
16655
16654
16647
16639
16637
16634
16629
16620