웹마스터 팁

http://sejin7940.co.kr/?mid=xe_tips&document_srl=23679  글을 퍼왔습니다.

 

---------------------------------

 

아직 이런 글이 XE Tips 부분등에 올라온게 없는걸 보니..

아직은 유지들이 XE 1.5 로 DB이전한 케이스가 거의 없나보네요. ^^

저와 같은 시행착오 겪으실 분들을 방지하고자, XE 1.5 이상으로 DB이전 툴 제작시 주의하실 점을 적어드립니다.

XE 1.5로 DB 마이그레이션할 경우... 때로는 자료가 일부 안 넘어가는 현상이 발생하는 경우가 있을겁니다.

원인은 XE 1.5 이후부터 강화된 필터(filter) 기능 때문입니다.

XE 1.5 부터는 이메일 및 홈페이지주소 에 관해 형식 필터링이 이뤄지고 어긋날 경우 등록이 아예 안 됩니다.

이는 회원가입시 뿐만 아니라, 글 작성시와 댓글 작성시에 모두 적용되는 사항입니다.

기존 사이트의 이메일주소나 홈페이지 형식이 잘못 된 글들을 그대로 이전시키려하면

결국 이 글들이 다 제외되어버리는 현상이 1.5 로의 이전시 발생하게 되는거죠

제가 테스트해보니, ZB4는 물론이고, 기본의 XE 1.4 버전에서도 이 이메일과 홈페이지 필터링이 안 되어있기에

이메일과 홈페이지가 잘못 기재된 글들이 꽤 있을 수 있는데, 이 글들이 다 이전이 안 된다는거죠

해결하려면, 결국 마이그레이션 툴 자체를 수정해서 이메일이나 홈페이지 형식이 잘못된 경우 해당 값을 삭제하거나..

아니면 XE의 해당 입력 쿼리마다 들어 있는 filter 를 지워버리거나, 아예 필터.js 파일을 수정하시면 됩니다.

(회원가입시 이메일이 필수면, 이메일 주소를 임의로 형성을 하셔야할 수도 있습니다. 아니면 안 넘어갈 수 있어요)

이렇게 필터가 강화되어서 이게 통과가 안 되면 글이 등록이 안 된다는게..안내가 안 되어있고

현재 배포되어있는 DB 이전 툴쪽에는 적용되어있는 예가 없기에..

이렇게 간단히라도 정보를 남겨놓습니다 ^^;;



--------------- 내용 추가 합니다 (120203) ----------------

이메일 형식등이 잘못 기재되는 유형이 워낙 다양한데다가...

가장 큰 문제는 회원가입시에 이메일이 필수사항이라는 점이죠..  이메일잘못기재되었다고 강제로 없애면

결국 회원가입이나 로그인등에 큰 문제가 발생하더군요.

따라서...  해결책은..   

modules/document/queries/insertDocument.xml  에서   filter="email"  와  filter="homepage" 를 지우고
modules/comment/queries/insertComment.xml 에서    filter="email"  와  filter="homepage" 를 지우고
modules/member/queries/insertMember.xml 에서     filter="email"  와  filter="homepage" 를 지운 뒤에

DB이전을 하는겁니다.  그러면 이메일주소가 틀려도  전부 다 이전이 될겁니다.

그 후에 다시 filter 값들을 다 복원해줍니다.  (그럼 XE 1.5 에서의 원 의도대로 filter 가 되겠죠)

이제 문제는, 잘못된 이메일주소 등으로 등록된 회원이 글을 쓸 때 발생합니다
회원이 글을 쓰면 회원정보를 기반으로 자동으로 이메일주소와 홈페이지주소가 기재가 되는데
회원정보의 이메일이 잘못 되면, 당연히 글 등록시 필터에 갈려 계속 에러메세지가 발생하게 됩니다
그러나, 글쓴이는 이메일기재란도 없는데, 왜 이런 메세지가 나와 글이 등록이 안 되는지 모르겠죠?

common/lang/lang.xml 파일에 가셔서
3452번줄 즈음에..   <item name="invalid_email">  부분의 언어를 바꿔주시면 됩니다.

<value xml:lang="ko"><![CDATA[%s의 값은 올바른 메일 주소가 아닙니다.]]></value>  부분을
<value xml:lang="ko"><![CDATA[%s의 값은 올바른 메일 주소가 아닙니다.\n만약 회원이시면 회원정보에서 이메일을 수정해주시기 바랍니다]]></value>

이런식으로 변경하면 되는거죠.
이 부분은 Core 에 해당되기에, 상황에 따라 XE 업그레이드로 지워질 수도 있는 부분인데 당장은 어쩔 수가 없네요 ^^;

기억해두셨다가, 혹시 Core 로 덮히면 다시 수정해주셔야합니다.

이렇게하면, DB이전이 깔끔하게 처리가 되겠네요. ^^;;

제목 글쓴이 날짜
로그인 후 그룹별로 다른 페이지로 가기 - 업데이트판 v1.5 [19] 무대포2 2009.06.24
XE용 query xml 방식으로 일반 테이블도 접근 처리 하기 [1] 라르게덴 2009.06.18
로그인 페이지 만드는 방법 [5] 산토 2009.06.12
BGM 가로스크롤바 없애는 방법.. 청개굴이 2009.06.03
별도 페이지 로그인방법 cornet 2009.05.21
게시판에서 헤더와 풋부분을 붙이면 이미지 출력이 되지 않아요.. [2] 율이★ 2009.05.19
까페 아이디 삭제후 동일 아이디로 생성하는 방법 키스메리 2009.05.15
내가 작성 한 글에 대한 일괄 삭제/이동/복사 권한 주기 [2] file 개돌 2009.05.15
XpressEngine 1.2.2용 배경음악 틀 [4] 마빈박사359 2009.05.10
1.2.2 업데이트 이후 위젯이 출력안되시는 분들 [1] [1] 반도체맨 2009.05.01
사랑비BGM 플레이기 설치하고 제어하기 [2] 스유군 2009.04.28
XE 위키에 최근 접속 페이지 정보 출력 file 개돌 2009.04.27
BNU님의 Planner XE 1.2 버젼(일정관리) [9] file 개돌 2009.04.21
다양한 언어로 홈페이지 서비스하기 - 무식한 방법 [4] 멀리서 2009.04.21
홈페이지 타이틀이 $user_lang->home ,freeboard등으로 나오는 문제 수정방법(자체해결) [1] 정박사닷컴 2009.04.18
페이지 및 게시판 메뉴 경로 [2] file 자반튀김 2009.04.15
게시판에서 확장 변수를 쓰는 경우 1.2.0 이상 버전으로 업그레이드하기 전에 패치하시기 바랍니다. [5] file mooo 2009.04.14
주민등록 입력 폼 1.2.0 [55] file 개돌 2009.04.10
IIS + PHP + MySQL5 설치 시 버젼 주의 [1] 개돌 2009.04.10
요청하신 모듈을 찾을 수 없습니다 문제해결 방법 [2] 반도체맨 2009.04.09