업로드 된 소스는 원본 소스와 제 홈피에 맞게 변경된 파일
두가지 입니다.
------------------------------------------
그동안 제 개인 홈페이지엔 수정된 사항이 올려졌는데, nzeo엔 올리지 않고 있어서 이번기회에 한번에 올립니다.
예전에 올린것과 차이점이 있다면, 여럿이 있지만... 이미지도 추출한다는 것입니다.
_____________________________________________________________________________________________________
제로보드의 전체게시판(정확히 말하자면 지정한 게시판)의 최신글, 최신덧글,최고 추천글 등을 리스트화 해주는 함수(?)입니다.
사용된 예는 제 홈페이지( http://lpbox.co.kr )의 오른쪽 카테고리로 들 수가 있겠습니다.
스킨은 제로보드의 최근글의 스킨을 사용하시면 됩니다.
저만을 위한 함수였기에 부족한점이 많습니다. 보완점을 알려주시면 수정에 수정을 더하겠습니다.
설치방법
outlogin.php 하단에
require ("../global/function/main_bbs.php");와 같이 함수 파일의 경로를 지정하여 추가하시면 됩니다.
또는 함수 파일내의 모든 내용을 outlogin.php하단에 추가하셔도 됩니다.
사용방법
기본적으로 제공하는 제로보드의 최신글과 비교해서 설명드리겠습니다.
< ? print_bbs("lpbox/bbs", "Guest Book", "guest", 5, 20)? > <-일반 제로보드의 최신글
< ? main_bbs("comment","reg_date|DESC","lpbox/bbs","Recent Comments", "Gallery|guest|notice", 5, 20) ? > <- 전체 게시판의 최신글
보시면 아시겠지만 일반 제로보드의 최신글과 동일합니다.
차이점1. 스킨을 지정하는곳 앞(맨 앞)에 게시글을 출력할것인지, 덧글을 출력할것인지 지정합니다.
덧글일때 comment 게시물일때 board로 지정하시면 됩니다.
차이점2. 스킨을 지정하는곳 앞(앞에서 두번째)에 정렬내용과 순서를 지정합니다.
최신글은 reg_date|DESC, 최고추천글은 vote|DESC 입니다.
그밖에 글의 제목순(subject), 제목역순(subject|DESC), 글쓴이순(name), 글쓴이 역순(name|DESC) 등으로도 설정가능합니다.
차이점3. 지정 게시판명이 복수개이기 때문에 구분자(|)로 출력하시고자 하는 게시판명을 복수 지정합니다.
차이점4. 기본적으로 제로보드에서 지원하는 치환자를 사용하였으나, 몇몇은 제로보드에서 사용하지 않는 치환자이기에 추가된 부분이 있습니다.
[category_name] -> 카테고리명
[table] -> 게시판 아이디
[bbs_title] -> 게시판 명(타이틀 지정)
[new] -> 24시간 이내의 글에 붙는 아이콘
등등등 ㅡㅡ;;;
차이점5. 이미지 추출도 가능합니다.
[img1_사이즈][img2_사이즈] 라는 치환자를 스킨파일에 넣으시면 [img1_사이즈]는 첨부파일1에 첨부된 이미지를, [img2_사이즈]는 첨부파일2에 첨부된 이미지를 지정한 사이즈 크기로 추출해줍니다.
단 사이즈는 숫자입니다.
------[소 스] --------------------------------------------------------------------------------
< ?
function main_bbs($ctype, $wsort, $skinname, $post_title,$board,$list_num,$max_len,$datetype="y/m/d"){
global $_zb_path, $_zb_url, $connect, $t_board, $admin_table;
$board_name = explode("|", $board); // 게시판 아이디 추출(분리)
$str = zReadFile($_zb_path."latest_skin/".$skinname."/main.html");
if(!$str) {
echo "지정하신 $skinname 이라는 최근목록 스킨이 존재하지 않습니다< br >";
return;
}
// 추출 조건
$whsort=explode("|",$wsort); // 추출 조건 분리
if(!$whsort[0]) $whsort[0]="reg_date"; // 추출 조건이 없을때 최근글을 디폴트로 잡음
if(!$whsort[1]) $whsort[1]="DESC";
if($whsort[2]){ // 최근 몇일의 글을 추출할것인가?
$limit_date=(time()-($whsort[2]*24*60*60));
$reg_limit=" AND [board].reg_date >='$limit_date'";
}
$whsort[1]=strtoupper($whsort[1]);
if($whsort[0]=="reg_date" && $whsort[1]=="DESC") $reg_limit.=" AND [board].no >= '[max_no]'"; // 최근글 추출일때 속도 증가를 위한 쿼리
// 각 게시판의 글을 추출
for ($i = 0; $i < sizeof($board_name); $i++){
// 퀘리에 게시판 아이디를 대입시킵
$boards = "zetyx_board_".$board_name[$i];
$reg_limit2 = str_replace("[board]","$boards",$reg_limit);
if($ctype=="comment") $boards_category = "zetyx_board_comment_".$board_name[$i];
else $boards_category = "zetyx_board_category_".$board_name[$i];
// 최근글일때 no를 기준으로 너무 오래된 글을 잘라 버림으로써 속도를 증가시킴
$max_no=@mysql_fetch_array(mysql_query("SELECT MAX(no) FROM $boards"));
$max_no[0]-=(5*$list_num);
$reg_limit2 = str_replace("[max_no]","$max_no[0]",$reg_limit2);
// 글을 추출하는 쿼리
if($ctype=="comment") $query = "SELECT a.* FROM $boards_category AS a LEFT JOIN $boards AS b ON a.parent=b.no WHERE a.reg_date >='$limit_date' AND b.is_secret=0 ORDER BY a.reg_date DESC LIMIT $list_num";
else $query = "SELECT $boards.* , $boards_category.name AS category_name FROM $boards LEFT JOIN $boards_category ON $boards.category=$boards_category.no WHERE $boards.is_secret=0 $reg_limit2 ORDER BY $boards.$whsort[0] $whsort[1] LIMIT $list_num";
// 추출된 글을 항목별로 배열에 담음
$result = mysql_query($query);
while ($data_board = mysql_fetch_array($result)){
$bbs_tmp[] = $board_name[$i];
$subject[] = stripslashes($data_board[subject]);
$name[] = stripslashes($data_board[name]);
$category_name[] = stripslashes($data_board[category_name]);
$comment[] = $data_board[total_comment];
if($ctype=="comment"){
$num[]="$data_board[parent]";
$co_num[]="$data_board[no]";
}else{
$num[] = $data_board[no];
$comment_date=mysql_fetch_array(mysql_query("SELECT MAX(reg_date) FROM zetyx_board_comment_".$board_name[$i]." WHERE parent='$data_board[no]'"));
$date3[]=$comment_date[0];
}
$file_name1[]=$data_board[file_name1];
$file_name2[]=$data_board[file_name2];
$use_htmls[] = $data_board[use_html];
$sc=$whsort[0];
$sort_center[] = $data_board[$sc];
setlocale (LC_TIME,"ko");
$date1[] ="$data_board[reg_date]";
$date2[] = date($datetype, $data_board[reg_date]);
$memo[] = stripslashes($data_board[memo]);
$board_info = mysql_fetch_array(mysql_query("SELECT title, use_alllist FROM $admin_table WHERE name='$board_name[$i]'"));
$use_alllist[] = $board_info[use_alllist];
$bbs_title[]=$board_info[title];
}
}
// 각 게시판의 글이 저장된 배열을 추출 조건에 따라 재정렬
if(count($sort_center)){
if($whsort[1]=="DESC") arsort($sort_center);
else asort($sort_center);
reset($sort_center);
// 스킨에서 loop부분만을 잘라냄
list($header,$tmpStr)= explode("[loop]",$str);
list($loop,$footer) = explode("[/loop]",$tmpStr);
// 재정렬된 배열을 스킨(loop 부분)에 대입시킴
while(list($key,$value)=each($sort_center)){
$j++;
if($comment[$key]==0 || $ctype=="comment") $comments="";
else $comments="[".$comment[$key]."]";
if($use_alllist[$key]) $target = "".$_zb_url."zboard.php"; // 목록 보기글
else $target = "".$_zb_url."view.php"; // 목록보기가 없는 글
$subject[$key]=cut_str($subject[$key],$max_len); // 지정한 숫자로 글자를 자름
$memo[$key]=strip_tags($memo[$key]); // 태그를 없앰
$memo[$key]=cut_str($memo[$key],$max_len); // 지정한 숫자로 글자를 자름
// 대입
$main = str_replace("[name]",$name[$key],$loop);
$main = str_replace("[date]",$date2[$key],$main);
$main = str_replace("[category_name]",$category_name[$key],$main);
$main = str_replace("[table]",$bbs_tmp[$key],$main);
$main = str_replace("[bbs_title]",$bbs_title[$key],$main);
$main = str_replace("[comment]",$comments,$main);
if($date1[$key] >=(time()-86400) || $date3[$key] >=(time()-86400)) $main = str_replace("[new]","< img src=".$_zb_url."latest_skin/".$skinname."/images/new.gif >",$main); // 등록한지 1일 이내의 글일때 new 아이콘을 붙임
else $main = str_replace("[new]","",$main);
if($ctype=="comment") $main = str_replace("[subject]","< a href='$target?id=$bbs_tmp[$key]&no=$num[$key]$co_num[$key]' >".$memo[$key]."< /a >",$main);
else $main = str_replace("[subject]","< a href='$target?id=$bbs_tmp[$key]&no=$num[$key]' >".$subject[$key]."< /a >",$main);
// 최근 이미지 대입
@preg_match_all("/\[(img)([1-2])(_)([0-9]*)\]/",$main,$tag_info); // 이미지 치환자를 찾음
for($k=0;$tag_info[0][$k];$k++){ // 이미지 치환자 만큼 돌림
$img_size_tmp=$tag_info[4][$k]; // 치환자에서 원하는 사이즈를 저장
$img_tag=$tag_info[0][$k]; // 치환자 내용을 저장
if ($file_name1[$key] && (substr($file_name1[$key],-3)=="jpg"||substr($file_name1[$key],-3)=="gif" || substr($file_name1[$key],-3)=="png")){ // 이미지1을 치환
$get_size1=getimagesize($_zb_path."$file_name1[$key]");
if($get_size1[0] >=$get_size1[1]) $img_size1="width='$img_size_tmp'";
else $img_size1="height='$img_size_tmp'";
$main=str_replace("$img_tag","< img src='".$_zb_url."$file_name1[$key]' $img_size1' >",$main);
}
if ($file_name2[$key] && (substr($file_name2[$key],-3)=="jpg"||substr($file_name2[$key],-3)=="gif" || substr($file_name2[$key],-3)=="png")){ // 이미지2를 치환
$get_size2=getimagesize($_zb_path."$file_name2[$key]");
if($get_size2[0] >=$get_size2[1]) $img_size2="width='$img_size_tmp'";
else $img_size2="height='$img_size_tmp'";
$main=str_replace("$img_tag","< img src='".$_zb_url."$file_name2[$key]' $img_size2' >",$main);
}
}
$main=preg_replace("/\[img(.*?)\]/","",$main);
$main_data .= "\n".$main;
if ($j >=$list_num) break; // 지정한 추출글 숫자에 도달하면 대입을 중지
}
// 스킨에 추출된 부분을 삽입
$list = $header.$main_data.$footer;
$list = str_replace("[title]","$post_title",$list); // title 치환
$list = str_replace("[dir]",$_zb_url."latest_skin/".$skinname."/images/",$list); // dir치환
echo $list; // 출력 ^^v
}
}
? >
-------[ 참고사항 ]--------------------------------------------------------------------------
최근 자료 및 기타 자세한 내용은 제 개인 홈페이지 http://lpbox.co.kr 의 Programming -> PHP Function 메뉴와 http://naezip.net의 web-tip을 통해 확인하실 수 있습니다.
질문은 제 두번째 개인 홈페이지 http://naezip.net 의 서비스 센터 게시판에 올려주세요 ^^;;
< > 문자 앞뒤의 공백은 제거하신후 붙이십시요. 그냥 위에꺼 붙이시면 에러납니다. 아니면 제 개인홈페이지에서 파일을 다운받으십시요
첨부파일은 제 개인 홈페이지에 있습니다. 여기에 파일을 첨부하고 싶지만, 파일이 삭제되더군요 ㅡㅡ;;;
출처 : http://www.nzeo.com/bbs/zboard.php?id=cgi_tip&page=1&sn1=&divpage=1&sn=off&ss=on&sc=off&keyword=덧글&select_arrange=headnum&desc=asc&no=7369
두가지 입니다.
------------------------------------------
그동안 제 개인 홈페이지엔 수정된 사항이 올려졌는데, nzeo엔 올리지 않고 있어서 이번기회에 한번에 올립니다.
예전에 올린것과 차이점이 있다면, 여럿이 있지만... 이미지도 추출한다는 것입니다.
_____________________________________________________________________________________________________
제로보드의 전체게시판(정확히 말하자면 지정한 게시판)의 최신글, 최신덧글,최고 추천글 등을 리스트화 해주는 함수(?)입니다.
사용된 예는 제 홈페이지( http://lpbox.co.kr )의 오른쪽 카테고리로 들 수가 있겠습니다.
스킨은 제로보드의 최근글의 스킨을 사용하시면 됩니다.
저만을 위한 함수였기에 부족한점이 많습니다. 보완점을 알려주시면 수정에 수정을 더하겠습니다.
설치방법
outlogin.php 하단에
require ("../global/function/main_bbs.php");와 같이 함수 파일의 경로를 지정하여 추가하시면 됩니다.
또는 함수 파일내의 모든 내용을 outlogin.php하단에 추가하셔도 됩니다.
사용방법
기본적으로 제공하는 제로보드의 최신글과 비교해서 설명드리겠습니다.
< ? print_bbs("lpbox/bbs", "Guest Book", "guest", 5, 20)? > <-일반 제로보드의 최신글
< ? main_bbs("comment","reg_date|DESC","lpbox/bbs","Recent Comments", "Gallery|guest|notice", 5, 20) ? > <- 전체 게시판의 최신글
보시면 아시겠지만 일반 제로보드의 최신글과 동일합니다.
차이점1. 스킨을 지정하는곳 앞(맨 앞)에 게시글을 출력할것인지, 덧글을 출력할것인지 지정합니다.
덧글일때 comment 게시물일때 board로 지정하시면 됩니다.
차이점2. 스킨을 지정하는곳 앞(앞에서 두번째)에 정렬내용과 순서를 지정합니다.
최신글은 reg_date|DESC, 최고추천글은 vote|DESC 입니다.
그밖에 글의 제목순(subject), 제목역순(subject|DESC), 글쓴이순(name), 글쓴이 역순(name|DESC) 등으로도 설정가능합니다.
차이점3. 지정 게시판명이 복수개이기 때문에 구분자(|)로 출력하시고자 하는 게시판명을 복수 지정합니다.
차이점4. 기본적으로 제로보드에서 지원하는 치환자를 사용하였으나, 몇몇은 제로보드에서 사용하지 않는 치환자이기에 추가된 부분이 있습니다.
[category_name] -> 카테고리명
[table] -> 게시판 아이디
[bbs_title] -> 게시판 명(타이틀 지정)
[new] -> 24시간 이내의 글에 붙는 아이콘
등등등 ㅡㅡ;;;
차이점5. 이미지 추출도 가능합니다.
[img1_사이즈][img2_사이즈] 라는 치환자를 스킨파일에 넣으시면 [img1_사이즈]는 첨부파일1에 첨부된 이미지를, [img2_사이즈]는 첨부파일2에 첨부된 이미지를 지정한 사이즈 크기로 추출해줍니다.
단 사이즈는 숫자입니다.
------[소 스] --------------------------------------------------------------------------------
< ?
function main_bbs($ctype, $wsort, $skinname, $post_title,$board,$list_num,$max_len,$datetype="y/m/d"){
global $_zb_path, $_zb_url, $connect, $t_board, $admin_table;
$board_name = explode("|", $board); // 게시판 아이디 추출(분리)
$str = zReadFile($_zb_path."latest_skin/".$skinname."/main.html");
if(!$str) {
echo "지정하신 $skinname 이라는 최근목록 스킨이 존재하지 않습니다< br >";
return;
}
// 추출 조건
$whsort=explode("|",$wsort); // 추출 조건 분리
if(!$whsort[0]) $whsort[0]="reg_date"; // 추출 조건이 없을때 최근글을 디폴트로 잡음
if(!$whsort[1]) $whsort[1]="DESC";
if($whsort[2]){ // 최근 몇일의 글을 추출할것인가?
$limit_date=(time()-($whsort[2]*24*60*60));
$reg_limit=" AND [board].reg_date >='$limit_date'";
}
$whsort[1]=strtoupper($whsort[1]);
if($whsort[0]=="reg_date" && $whsort[1]=="DESC") $reg_limit.=" AND [board].no >= '[max_no]'"; // 최근글 추출일때 속도 증가를 위한 쿼리
// 각 게시판의 글을 추출
for ($i = 0; $i < sizeof($board_name); $i++){
// 퀘리에 게시판 아이디를 대입시킵
$boards = "zetyx_board_".$board_name[$i];
$reg_limit2 = str_replace("[board]","$boards",$reg_limit);
if($ctype=="comment") $boards_category = "zetyx_board_comment_".$board_name[$i];
else $boards_category = "zetyx_board_category_".$board_name[$i];
// 최근글일때 no를 기준으로 너무 오래된 글을 잘라 버림으로써 속도를 증가시킴
$max_no=@mysql_fetch_array(mysql_query("SELECT MAX(no) FROM $boards"));
$max_no[0]-=(5*$list_num);
$reg_limit2 = str_replace("[max_no]","$max_no[0]",$reg_limit2);
// 글을 추출하는 쿼리
if($ctype=="comment") $query = "SELECT a.* FROM $boards_category AS a LEFT JOIN $boards AS b ON a.parent=b.no WHERE a.reg_date >='$limit_date' AND b.is_secret=0 ORDER BY a.reg_date DESC LIMIT $list_num";
else $query = "SELECT $boards.* , $boards_category.name AS category_name FROM $boards LEFT JOIN $boards_category ON $boards.category=$boards_category.no WHERE $boards.is_secret=0 $reg_limit2 ORDER BY $boards.$whsort[0] $whsort[1] LIMIT $list_num";
// 추출된 글을 항목별로 배열에 담음
$result = mysql_query($query);
while ($data_board = mysql_fetch_array($result)){
$bbs_tmp[] = $board_name[$i];
$subject[] = stripslashes($data_board[subject]);
$name[] = stripslashes($data_board[name]);
$category_name[] = stripslashes($data_board[category_name]);
$comment[] = $data_board[total_comment];
if($ctype=="comment"){
$num[]="$data_board[parent]";
$co_num[]="$data_board[no]";
}else{
$num[] = $data_board[no];
$comment_date=mysql_fetch_array(mysql_query("SELECT MAX(reg_date) FROM zetyx_board_comment_".$board_name[$i]." WHERE parent='$data_board[no]'"));
$date3[]=$comment_date[0];
}
$file_name1[]=$data_board[file_name1];
$file_name2[]=$data_board[file_name2];
$use_htmls[] = $data_board[use_html];
$sc=$whsort[0];
$sort_center[] = $data_board[$sc];
setlocale (LC_TIME,"ko");
$date1[] ="$data_board[reg_date]";
$date2[] = date($datetype, $data_board[reg_date]);
$memo[] = stripslashes($data_board[memo]);
$board_info = mysql_fetch_array(mysql_query("SELECT title, use_alllist FROM $admin_table WHERE name='$board_name[$i]'"));
$use_alllist[] = $board_info[use_alllist];
$bbs_title[]=$board_info[title];
}
}
// 각 게시판의 글이 저장된 배열을 추출 조건에 따라 재정렬
if(count($sort_center)){
if($whsort[1]=="DESC") arsort($sort_center);
else asort($sort_center);
reset($sort_center);
// 스킨에서 loop부분만을 잘라냄
list($header,$tmpStr)= explode("[loop]",$str);
list($loop,$footer) = explode("[/loop]",$tmpStr);
// 재정렬된 배열을 스킨(loop 부분)에 대입시킴
while(list($key,$value)=each($sort_center)){
$j++;
if($comment[$key]==0 || $ctype=="comment") $comments="";
else $comments="[".$comment[$key]."]";
if($use_alllist[$key]) $target = "".$_zb_url."zboard.php"; // 목록 보기글
else $target = "".$_zb_url."view.php"; // 목록보기가 없는 글
$subject[$key]=cut_str($subject[$key],$max_len); // 지정한 숫자로 글자를 자름
$memo[$key]=strip_tags($memo[$key]); // 태그를 없앰
$memo[$key]=cut_str($memo[$key],$max_len); // 지정한 숫자로 글자를 자름
// 대입
$main = str_replace("[name]",$name[$key],$loop);
$main = str_replace("[date]",$date2[$key],$main);
$main = str_replace("[category_name]",$category_name[$key],$main);
$main = str_replace("[table]",$bbs_tmp[$key],$main);
$main = str_replace("[bbs_title]",$bbs_title[$key],$main);
$main = str_replace("[comment]",$comments,$main);
if($date1[$key] >=(time()-86400) || $date3[$key] >=(time()-86400)) $main = str_replace("[new]","< img src=".$_zb_url."latest_skin/".$skinname."/images/new.gif >",$main); // 등록한지 1일 이내의 글일때 new 아이콘을 붙임
else $main = str_replace("[new]","",$main);
if($ctype=="comment") $main = str_replace("[subject]","< a href='$target?id=$bbs_tmp[$key]&no=$num[$key]$co_num[$key]' >".$memo[$key]."< /a >",$main);
else $main = str_replace("[subject]","< a href='$target?id=$bbs_tmp[$key]&no=$num[$key]' >".$subject[$key]."< /a >",$main);
// 최근 이미지 대입
@preg_match_all("/\[(img)([1-2])(_)([0-9]*)\]/",$main,$tag_info); // 이미지 치환자를 찾음
for($k=0;$tag_info[0][$k];$k++){ // 이미지 치환자 만큼 돌림
$img_size_tmp=$tag_info[4][$k]; // 치환자에서 원하는 사이즈를 저장
$img_tag=$tag_info[0][$k]; // 치환자 내용을 저장
if ($file_name1[$key] && (substr($file_name1[$key],-3)=="jpg"||substr($file_name1[$key],-3)=="gif" || substr($file_name1[$key],-3)=="png")){ // 이미지1을 치환
$get_size1=getimagesize($_zb_path."$file_name1[$key]");
if($get_size1[0] >=$get_size1[1]) $img_size1="width='$img_size_tmp'";
else $img_size1="height='$img_size_tmp'";
$main=str_replace("$img_tag","< img src='".$_zb_url."$file_name1[$key]' $img_size1' >",$main);
}
if ($file_name2[$key] && (substr($file_name2[$key],-3)=="jpg"||substr($file_name2[$key],-3)=="gif" || substr($file_name2[$key],-3)=="png")){ // 이미지2를 치환
$get_size2=getimagesize($_zb_path."$file_name2[$key]");
if($get_size2[0] >=$get_size2[1]) $img_size2="width='$img_size_tmp'";
else $img_size2="height='$img_size_tmp'";
$main=str_replace("$img_tag","< img src='".$_zb_url."$file_name2[$key]' $img_size2' >",$main);
}
}
$main=preg_replace("/\[img(.*?)\]/","",$main);
$main_data .= "\n".$main;
if ($j >=$list_num) break; // 지정한 추출글 숫자에 도달하면 대입을 중지
}
// 스킨에 추출된 부분을 삽입
$list = $header.$main_data.$footer;
$list = str_replace("[title]","$post_title",$list); // title 치환
$list = str_replace("[dir]",$_zb_url."latest_skin/".$skinname."/images/",$list); // dir치환
echo $list; // 출력 ^^v
}
}
? >
-------[ 참고사항 ]--------------------------------------------------------------------------
최근 자료 및 기타 자세한 내용은 제 개인 홈페이지 http://lpbox.co.kr 의 Programming -> PHP Function 메뉴와 http://naezip.net의 web-tip을 통해 확인하실 수 있습니다.
질문은 제 두번째 개인 홈페이지 http://naezip.net 의 서비스 센터 게시판에 올려주세요 ^^;;
< > 문자 앞뒤의 공백은 제거하신후 붙이십시요. 그냥 위에꺼 붙이시면 에러납니다. 아니면 제 개인홈페이지에서 파일을 다운받으십시요
첨부파일은 제 개인 홈페이지에 있습니다. 여기에 파일을 첨부하고 싶지만, 파일이 삭제되더군요 ㅡㅡ;;;
출처 : http://www.nzeo.com/bbs/zboard.php?id=cgi_tip&page=1&sn1=&divpage=1&sn=off&ss=on&sc=off&keyword=덧글&select_arrange=headnum&desc=asc&no=7369