메뉴 건너뛰기

XE : Xpress Engine


XE에 대한 생각! XE에 대한 공감! - XE를 사용하는 다른 사람들과 의견을 나눌 수 있는 곳입니다. 많은 의견 공유로 더 좋은 XE를 만들어 주세요.


XE 사용팁

리플이나 서명에서 특정 태그 막기

2008.05.05 19:57

[레벨:11]老姜君 조회 수:6447 추천:1

이 팁은 임시적인 땜빵 처방에 불과합니다. 더 깔끔하과 완전한 방법이 나오길 기다리면서, 그 전까지의 임시 대책으로만 사용하시기 바랍니다.


현재 제로보드 XE에서는 html 태그의 제한 기능이 딱히 없습니다. 좋게 보면 회원들에게 보다 많은 자유도를 제공해주는 것이지만, 운영자 입장에서는 괴상한 태그로 사이트가 깨지는 일부터 시작해서, 이를 악용할 경우 악의적인 의도의 태그를 집어넣는 일이 생길 수도 있습니다.

제로보드 4 시절에는 del_html이라는 함수가 있어서, 이를 사용하면 각종 태그를 무력화시킬 수가 있었습니다. 그 내용은 다음과 같습니다.

function del_html( $str ) {
    $str = str_replace( ">", ">",$str );
    $str = str_replace( "<", "&lt;",$str );
    return $str;
}

이 함수는 str_replace를 이용하여, html 태그 제일 앞/뒤에 반드시 나오는 <와 >를 모양은 비슷하지만 코드는 다른 특수문자, &gt;와 &lt;로 대체시켜버리는 역할을 하게 됩니다.

하지만 이를 제로보드 XE에서 그대로 사용할 수는 없는데, 이를 사용하면 해당 부분의 div와 CSS까지 아작나기 때문입니다. 아래는 리플에 del_html을 그대로 적용시켰을 경우 나타나는 현상입니다.

사용자 지정 1.jpg

따라서 사이트의 균형을 깨는데 제일 큰 역할을 하는 몇몇 태그만 골라나서 매우 구차하게 막는 방법을 쓸 수밖에 없습니다. 그래서 수정한 것이 이것입니다.

function del_html( $str ) {
    $str = str_ireplace( "img","코멘트의 이미지 태그는 사용 금지",$str );
    $str = str_ireplace( "table","코멘트의 테이블 태그는 사용 금지",$str );
    return $str;
}

str_replace대신 str_ireplace를 사용한 이유는, str_ireplace가 대/소문자를 가리지 않기 때문입니다. img건 IMG건 둘 다 똑같은 이미지 태그니까요.

이대로라면<img src="파일경로">의 태그가, <코멘트의 이미지 태그는 사용 금지 src="파일경로">로 바뀌어서 출력되게 됩니다. 이미지 태그를 막는 효과는 있는데, 별로 깔끔하지는 않습니다.

코멘트의 이미지 태그는 사용 금지 대신 a herf로 넣으면 링크로 바뀌지만 </a>로 링크 영역 설정이 안되어서 해당 코멘트 자체가 날라가버리게 됩니다. 차라리 아무것도 안보이는게 낫다고 생각하신다면 이게 좋겠지만, 이런 불완전한 태그가 사이트 어디에서 문제를 일으킬지는 알 수 없으니 쓰지 않았습니다.

어쨌건 저렇게 금지 운운하게 나온다면, 글쓴이 입장에서도 생각을 다시 해본다던가, 수정한다던가 할 여지가 있을테니 그나마 낫다고 보이는군요.

같은 맥락으로, 테이블 태그 역시 레이아웃을 깨먹는데 일등 공신인지라 막았습니다. 임베디드라던가 아이프레임이라던가, 금지시킬 태그가 있다면 저런 방식으로 추가하면 되겠습니다.

이 방법의 단점은, 전혀 상관없는 글자에서도 img라던가 table이 들어가면 무조건 저걸로 전환이 된다는 것입니다. 영어를 쓸 일이 그리 많은건 아니지만 단점임에는 확실합니다. 그래서 시작할때도 임시 땜빵이라는걸 강조했었고.

다음은 이걸 어디에 넣느냐 하는 문제가 남습니다. 제로보드 XE의 구조에 무지한 저로서는 좋은 방법을 찾지 못해서, 결국 어딜 보건 엑세스하게 되어있는 zbxe\index.php의 제일 마지막에 넣게 되었습니다. ...다시 강조하는데 정말 갑갑한 방법입니다.

index.php의 제일 마지막줄에 ?>라고 php 소스의 끝을 알리는 명령이 있는데, 그 줄 제일 앞에서 엔터 몇번 쳐줘서 빈 공간을 만들고 거기에 넣으면 됩니다.

남는건 이걸 어떻게 적용시키느냐는 것입니다. 먼저 코멘트에 넣어 보겠습니다. zbxe/modules\board\skins\스킨이름\comment.html입니다.

{$comment->getContent(true)}라는 부분을 찾아서 {del_html($comment->getContent(true))}로 바꿔주면 됩니다.

다음은 서명입니다. zbxe/modules\board\skins\스킨이름\view_document.html입니다.

{$oDocument->getSignature()}라는 부분을 찾아서 {del_html($oDocument->getSignature())}로 바꿔주면 됩니다.


이상입니다. 이보다 더 좋은 방법이 나와서 이런 급조 처방을 쓸 일이 없어지길 바랄 뿐입니다.
번호 제목 글쓴이 날짜 조회 수
공지 질문은 묻고 답하기로~ TSCMD 2012.02.03 10400
954 XE 강의 #2 - XE에서 레이아웃 적용하기 [12] [레벨:10]서기 2010.04.24 3372
» 리플이나 서명에서 특정 태그 막기 [4] [레벨:11]老姜君 2008.05.05 6447
952 큐브리드로 변환후 인덱스 재생성 [1] [레벨:13]카르마 2010.10.22 1817
951 회원가입시 닉네임 특수문자 제한하기 [7] [레벨:2]절망린 2009.06.06 1806
950 대용량 파일 첨부 업로드시 php.ini 파일조정값들 [3] TS비나무 2007.12.28 7583
949 카테고리별로 최근게시물 뽑아오기 [11] file [레벨:10]팔공산 2008.05.22 12118
948 권한없는 모듈을 만났을때 로그인 페이지 띄우기.. [11] [레벨:16]똑디 2007.12.11 8295
947 게시판에 구글 SyntaxHighlighter 3.0.83(구문강조) 적용하기 - 본문에 코드삽입시 유용 file [레벨:2]으아악. 2010.10.20 1839
946 imageshack 업로드 버튼 코드 [2] [레벨:27]도라란 2010.09.27 2121
945 나눔고딕 웹폰트가 아닌 API로 적용하여 사용해보자!! [10] [레벨:2]으아악. 2010.10.07 3263
944 게시판 링크 무조건 새창으로 뜨게 하는 법 ^^ [7] [레벨:9]Jiyoung540 2009.07.29 2231
943 파일첨부 에러가 날때 이렇게 하시면 됩니다. [5] file [레벨:1]밀림의 왕자 2009.08.12 5035
942 광고성 글때문에.... 금지 ip 목록 공유 [5] [레벨:2]한니발2 2010.10.06 1621
941 간단한 위키링크 흉내내기 [5] [레벨:2]고진감래 2009.10.17 1640
940 이미지 삽입시 아래에 한줄 띄우고 클릭가능하게 하여 편히 입력하게 만들자~ [8] file [레벨:9]xemall 2010.10.13 1622
939 새글/업데이트/이미지/동영상/첨부파일 아이콘 없애기 [16] file [레벨:11]老姜君 2008.11.21 6023
938 링크시 텍스트 혹은 이미지에 생기는 점선 CSS로 없애기 [9] file [레벨:0]겨우리851 2010.04.24 2286
937 XE를 처음 접하거나 이제막 사이트개발을 하려는 초보자를 위한 XE 접근방법 [1] [레벨:4]DuRi 2009.11.12 5331
936 1.4.4.1 업데이트이후 이미지가 엑스박스로 뜨는 분들 참고 [1] [레벨:2]위드파트너 2010.10.04 2232
935 [강추]!! 긁어와서 [자동]으로 게시글로!! [메타 블로그] php 로 넣기!!! xe블로그api를 이용한.. [27] file [레벨:1]김기철980 2009.01.29 7059