태터툴즈 고쳐쓰기 #12 - 답글에 국가 아이콘 표시하기
lunamoth님의 제보에 따라..;
답글의 IP를 조회해서 어느 국가의 IP인지 국기 아이콘으로 표시해주는 워드프레스 플러그인을베껴참고해서 태터툴즈에서 돌아가는 코드 몇줄을 만들었다. (pionelle님의 워드프레스 플러그인 소개 포스트에 있는 내용중 상당 부분을 중복해 적습니다)
1. DB 테이블 만들기
ip2nation 사이트에 접속해 왼쪽 메뉴중 Download를 눌러 sql 파일을 다운로드 받은 뒤 mysql에서 실행시켜 테이블을 생성시킨다. ip2nation, ip2nationCountries 두 테이블이 생성되면 성공. SQL 파일로 테이블 생성하는 법을 모른다면 MySQL DB 백업/복원에 대해 검색을 해보자; (ip2nation DB는 매월 업데이트 된다고 한다)
2. 국기 이미지 구하기
frenchfragfactory 사이트에 접속해 /download/utils/flags.zip 를 클릭하면 다운받을 수 있다. 다운받은 이미지는 사용중인 스킨 디렉토리 아래 images/flags 디렉토리에 넣었다고 가정하고 아래 내용을 계속한다.
3. inc_function.php 파일 수정
inc_function.php 파일 404번째줄부터 시작하는 get_rp_content($skin, $num) 함수의 447번째줄 if ($rno == "0") $bf2_rep = $skin->s_rp_rep; else $bf2_rep = $skin->s_rp2_rep; 문장 바로 다음줄에 아래 세줄을 삽입한다.
4. 스킨 파일 수정
skin.html 파일의 리플을 출력하는 곳인 <s_rp_rep></s_rp_rep> 안쪽의 적당한 위치에 아래처럼 아이콘 이미지 태그를 삽입한다.
5. 여기까지 하면 답글 부분은 끝. 방명록에도 추가하고 싶다면,
이번엔 inc_presswork.php 파일을 열어서 318번째줄부터 시작하는 get_guest() 함수의 428번째줄 $p2_rep = $GLOBALS["skin"]->s_guest_rep; 문장 다음줄에 아래 세줄을 삽입
462번째줄 $p3_rep = $GLOBALS["skin"]->s_guest_reply_rep; 다음줄에도 아래의 세줄을 삽입
6. 다시 스킨 파일을 열어서..
<s_guest_rep></s_guest_rep> 태그로 둘러싸인 방명록 본문의 적당한 곳과 <s_guest_reply_rep></s_guest_reply_rep> 태그로 둘러싸인 방명록 답글의 적당한 곳에 각각
방명록 답글에는 굳이 넣지 않아도 될 듯 하지만 손님이 답글을 다는 경우도 있어 그냥 넣기로 했다. 그리고 국기 이미지인 flags.zip 파일에 모든 국가의 국기가 들어있지 않음에 주의.. 달아놓고 방명록을 쭉 살펴보니까 우즈베키스탄(!) 아이피를 쓰시는분이 계셨는데 아이콘이 없다. img 태그 안에 onerror="this.src='./images/flags/flag_defalut.gif'" 하는 식으로 아이콘 없을때 기본 아이콘을 보여주도록 추가하면 좋을 것 같다.
근데 국기 아이콘에 그라데이션(?)이 들어가서 썩 예쁘지는 않네..;; (특히 태극기) 시간날때 살짝 고쳐봐야겠다.
답글의 IP를 조회해서 어느 국가의 IP인지 국기 아이콘으로 표시해주는 워드프레스 플러그인을
1. DB 테이블 만들기
ip2nation 사이트에 접속해 왼쪽 메뉴중 Download를 눌러 sql 파일을 다운로드 받은 뒤 mysql에서 실행시켜 테이블을 생성시킨다. ip2nation, ip2nationCountries 두 테이블이 생성되면 성공. SQL 파일로 테이블 생성하는 법을 모른다면 MySQL DB 백업/복원에 대해 검색을 해보자; (ip2nation DB는 매월 업데이트 된다고 한다)
2. 국기 이미지 구하기
frenchfragfactory 사이트에 접속해 /download/utils/flags.zip 를 클릭하면 다운받을 수 있다. 다운받은 이미지는 사용중인 스킨 디렉토리 아래 images/flags 디렉토리에 넣었다고 가정하고 아래 내용을 계속한다.
3. inc_function.php 파일 수정
inc_function.php 파일 404번째줄부터 시작하는 get_rp_content($skin, $num) 함수의 447번째줄 if ($rno == "0") $bf2_rep = $skin->s_rp_rep; else $bf2_rep = $skin->s_rp2_rep; 문장 바로 다음줄에 아래 세줄을 삽입한다.
$ip2nation = mysql_fetch_array(mysql_query("SELECT c.country, c.code FROM ip2nationCountries c, ip2nation i WHERE i.ip<INET_ATON('$ip') AND c.code=i.country ORDER BY i.ip DESC LIMIT 1"));
$bf2_rep = str_replace("[##_rp_rep_country_name_##]", $ip2nation[0], $bf2_rep);
$bf2_rep = str_replace("[##_rp_rep_country_code_##]", $ip2nation[1], $bf2_rep);
$bf2_rep = str_replace("[##_rp_rep_country_name_##]", $ip2nation[0], $bf2_rep);
$bf2_rep = str_replace("[##_rp_rep_country_code_##]", $ip2nation[1], $bf2_rep);
4. 스킨 파일 수정
skin.html 파일의 리플을 출력하는 곳인 <s_rp_rep></s_rp_rep> 안쪽의 적당한 위치에 아래처럼 아이콘 이미지 태그를 삽입한다.
<img src="./images/flags/flag_[##_rp_rep_country_code_##].gif" width="18" height="12" alt="[##_rp_rep_country_name_##]">
5. 여기까지 하면 답글 부분은 끝. 방명록에도 추가하고 싶다면,
이번엔 inc_presswork.php 파일을 열어서 318번째줄부터 시작하는 get_guest() 함수의 428번째줄 $p2_rep = $GLOBALS["skin"]->s_guest_rep; 문장 다음줄에 아래 세줄을 삽입
$ip2nation = mysql_fetch_array(mysql_query("SELECT c.country, c.code FROM ip2nationCountries c, ip2nation i WHERE i.ip<INET_ATON('$ip') AND c.code=i.country ORDER BY i.ip DESC LIMIT 1"));
$p2_rep = str_replace("[##_guest_rep_country_name_##]", $ip2nation[0], $p2_rep);
$p2_rep = str_replace("[##_guest_rep_country_code_##]", $ip2nation[1], $p2_rep);
$p2_rep = str_replace("[##_guest_rep_country_name_##]", $ip2nation[0], $p2_rep);
$p2_rep = str_replace("[##_guest_rep_country_code_##]", $ip2nation[1], $p2_rep);
462번째줄 $p3_rep = $GLOBALS["skin"]->s_guest_reply_rep; 다음줄에도 아래의 세줄을 삽입
$ip2nation = mysql_fetch_array(mysql_query("SELECT c.country, c.code FROM ip2nationCountries c, ip2nation i WHERE i.ip<INET_ATON('$ip') AND c.code=i.country ORDER BY i.ip DESC LIMIT 1"));
$p3_rep = str_replace("[##_guest_rep_country_name_##]", $ip2nation[0], $p3_rep);
$p3_rep = str_replace("[##_guest_rep_country_code_##]", $ip2nation[1], $p3_rep);
$p3_rep = str_replace("[##_guest_rep_country_name_##]", $ip2nation[0], $p3_rep);
$p3_rep = str_replace("[##_guest_rep_country_code_##]", $ip2nation[1], $p3_rep);
6. 다시 스킨 파일을 열어서..
<s_guest_rep></s_guest_rep> 태그로 둘러싸인 방명록 본문의 적당한 곳과 <s_guest_reply_rep></s_guest_reply_rep> 태그로 둘러싸인 방명록 답글의 적당한 곳에 각각
<img src="./images/flags/flag_[##_guest_rep_country_code_##].gif" width="18" height="12" alt="[##_guest_rep_country_name_##]">
이렇게 이미지 태그를 똑같이 추가해주면 모두 끝난다.방명록 답글에는 굳이 넣지 않아도 될 듯 하지만 손님이 답글을 다는 경우도 있어 그냥 넣기로 했다. 그리고 국기 이미지인 flags.zip 파일에 모든 국가의 국기가 들어있지 않음에 주의.. 달아놓고 방명록을 쭉 살펴보니까 우즈베키스탄(!) 아이피를 쓰시는분이 계셨는데 아이콘이 없다. img 태그 안에 onerror="this.src='./images/flags/flag_defalut.gif'" 하는 식으로 아이콘 없을때 기본 아이콘을 보여주도록 추가하면 좋을 것 같다.
근데 국기 아이콘에 그라데이션(?)이 들어가서 썩 예쁘지는 않네..;; (특히 태극기) 시간날때 살짝 고쳐봐야겠다.