게시판에 글을 작성할 때 본문 내용이 정상적으로 다 올라가지 않고 뒷부분이 잘리는 경우가 있습니다.
- 웹페이지에서 글을 복사해서 그대로 붙여 넣을 경우
- 한글이나 워드 프로그램에서 작성한 문서 내용을 복사해서 그대로 붙여 넣을 경우
특히 위와 같은 경우 글을 붙여 넣고 에디터 하단 탭에서 HTML 소스 보기를 해보면 다량의 태그 코드가 추가돼있는 걸 확인할 수가 있는데 그래서 데이터 저장 허용 크기를 넘어선 부분들은 전부 누락되는 것이죠.
1. 게시판 필드 타입 변경
그누보드는 게시판 내용 값이 저장되는 wr_content 필드 타입이 TEXT로 되어 있습니다.
해당 필드 타입을 TEXT에서 MEDIUMTEXT 또는 LONGTEXT로 변경합니다.
대부분 MEDIUMTEXT 정도로 커버가 될 거라 생각됩니다.
LONGTEXT는 너무 크기 때문에 MEDIUMTEXT로도 해결이 안 될 경우에만 적용하세요.
phpMyAdmin 을 이용하면 쉽게 변경할 수 있습니다.
웹호스팅을 이용 중이라면 내 호스팅 관리 메뉴 등에 phpMyAdmin 접속 링크가 대부분 있을 겁니다.
좌측 DB 테이블에서 원하는 게시판 선택 후 wr_content 필드 수정 버튼 클릭
g5_write_1111 이런 형태로 되어 있는 게 게시판 테이블이고 끝부분 1111 이 게시판 id 입니다.
수정 화면에서 필드 종류를 TEXT 에서 MEDIUMTEXT 또는 LONGTEXT 로 변경
phpMyAdmin 을 사용하기 곤란한 상황이거나 위와 같이 적용했는데 에러가 뜬다면 이렇게 하세요.
해당 게시판에서 사용하고 있는 게시판 스킨 write.skin.php 파일 상단
if (!defined('_GNUBOARD_')) exit; // 개별 페이지 접근 불가
위 코드 바로 밑에 다음 코드를 추가합니다.
MEDIUMTEXT 로 변경하려면 이렇게..
sql_query(" ALTER TABLE `{$write_table}` CHANGE `wr_content` `wr_content` MEDIUMTEXT NOT NULL ");
LONGTEXT 로 변경하려면 이렇게..
sql_query(" ALTER TABLE `{$write_table}` CHANGE `wr_content` `wr_content` LONGTEXT NOT NULL ");
MEDIUMTEXT 또는 LONGTEXT 둘 중 하나만 선택해서 적용하세요.
write.skin.php 파일에 위 코드를 추가하고 게시판 클릭 후 글쓰기 화면을 한 번 띄워주면 자동으로 변환됩니다.
다른 게시판도 바꾸고 싶으면 변환하고자 하는 게시판을 클릭 후 마찬가지로 글쓰기 화면을 띄워주면 됩니다.
해당 게시판에서 사용되고 있는 스킨 파일에 적용한 게 맞는지 정확히 확인하세요.
요즘은 반응형 테마까지 나와서 다른 스킨 파일에 잘못 적용하는 분들이 의외로 많이 계십니다.
적용 후 해결이 되면 추가했던 위 코드는 반드시 다시 삭제하세요.
2. bbs/write_update.php 파일 수정
if (isset($_POST['wr_content'])) {
$wr_content = substr(trim($_POST['wr_content']),0,65536);
$wr_content = preg_replace("#[\\\]+$#", "", $wr_content);
}
여기서 이 부분 숫자를 아래 참고사항에 있는 최대 저장 크기 값 참고해서 적당히 늘려주거나
$wr_content = substr(trim($_POST['wr_content']),0,16777216);
아니면 이렇게 없애버립니다.
$wr_content = trim($_POST['wr_content']);
* 참고사항 (데이터 타입별 최대 저장 크기)
TEXT : 65535
MEDIUMTEXT : 16777215
LONGTEXT : 4294967295
3. lib/editor.lib.php 파일 수정
아래 함수를 찾은 후 maxlength=\"65536\" 이 부분 최대 저장 크기를 2번 내용처럼 적당히 변경하거나 삭제
function editor_html($id, $content)
{
return "<textarea id=\"$id\" name=\"$id\" style=\"width:100%;\" maxlength=\"65536\">$content</textarea>";
}