묻고답하기
php 게시판에서 참 희안한 오류가 발생됩니다!
2010.05.28 21:22
php로 게시판을 만들고 있습니다.
bbs_list.php에 한 페이지 당 표시될 게시물 갯수($perpage)를 10으로 잡았습니다.
bbs_function.php는 목록 뿌리기, 페이지 계산 등을 담당하는 파일입니다.
그런데 게시판의 게시물이 10개만 되면 맨 첫번째 글만 출력됩니다.
예를 들어 아래와 같이 목록에 나옵니다.
해당 게시판의 데이터베이스입니다. 총 10개입니다.
그런데 글 한개만 더 써서 11개를 만들면 정상적으로 출력됩니다.
아래와 같이 출력됩니다.
11개일경우 해당 게시판 데이터베이스입니다.
bbs_list.php 소스입니다.
<?
/*--------------------------
filename : list.php3
--------------------------*/
require "bbs_function.php";
$perpage = "10"; // 한페이지당 10개 뿌리기
if ($page == "") {
$page = 1;
}
$tlpn = get_pagenum();
$result = arti_list($tlpn, $perpage);
echo ("
// 맨 윗줄의 번호, 제목 등을 표시하는 부분 (편의상 생략)
");
$i = 0;
while($list = mysql_fetch_array($result)) {
echo "
echo ("
// 게시물 번호, 제목, 작성자 등을 반복적으로 출력하는 부분 (편의상 생략)
";
}
echo "<br><center><font size=\"1\">"; movepage ($page, 2); echo "</font></center>";
?>
bbs_function.php 소스입니다.
<?
/*--------------------------
filename : function.php3
--------------------------*/
function arti_list($tlpn, $perpage) {
include "account.php";
global $board, $page; // 수정
$result = lpp($tlpn, $perpage, $page); // 추가
return $result;
}
function get_pagenum() {
global $board, $perpage;
include "account.php";
$result = mysql_query("SELECT COUNT(*) FROM $board",$dbconn);
$tlpn[num] = mysql_result($result, 0, "COUNT(*)");
if($tlpn[num] % $perpage) {
$tlpn[page]= intval($tlpn[num] / $perpage) + 1;
}
else {
$tlpn[page]= $tlpn[num] / $perpage;
}
return $tlpn;
}
function lpp($tlpn, $perpage, $page) {
global $board;
include "account.php";
if(($tlpn[page] > $page) && ($page > 1)) {
$lastpagelist = $tlpn[num] - (($page - 1) * $perpage);
$result = mysql_query("SELECT * FROM $board WHERE
idx <= $lastpagelist
ORDER BY idx DESC LIMIT $perpage", $dbconn);
}
elseif ($tlpn[page] == $page) { // 맨 마지막 페이지라면..
if ($tlpn[num] % $perpage) {
$lastpagelist = $tlpn[num] % $perpage;
}
else {
$lastpagelist = $page;
}
$result = mysql_query("SELECT * FROM $board
WHERE idx <= $lastpagelist
ORDER BY idx DESC", $dbconn);
}
elseif ($page == "1") { // 첫 페이지라면..
$result = mysql_query("SELECT * FROM $board
ORDER BY idx DESC LIMIT $perpage", $dbconn);
}
else {
echo "잘못된 페이지";
exit;
}
return $result;
}
function movepage($page, $numpage) {
global $board, $tlpn;
if ($page == 1) { // 맨 처음 페이지
echo "<b>[Top]</b> ";
}
else {
echo "<a href=\"bbs_list.php?board=$board&page=1\">[Top]</a> ";
} // 맨 처음 페이지 끝
$topnear = $page - $numpage;
$lastnear = $page + $numpage;
if ($topnear <= 1) {
$pres = 1;
if ($tlpn[page] <= ($numpage * 2 + 1)) {
$nexs = $tlpn[page];
}
else {
$nexs = $numpage * 2 + 1;
}
}
elseif (($page == $tlpn[page]) && ($tlpn[page] <= ($numpage * 2))) {
$pres = 1;
$nexs = $tlpn[page];
}
elseif ($lastnear >= $tlpn[page]) {
$pres = $tlpn[page] - ($numpage * 2);
$nexs = $tlpn[page];
}
else {
$pres = $topnear;
$nexs = $lastnear;
}
// 이동할 페이지의 가장 처음이 1 페이지보다 클 경우 생략 기호 출력
if ($pres > 1) {
echo "<b> ... </b>";
}
for($i=$pres; $i <= $nexs; $i++) { // 중간
if ($i == $page) {
echo "<b>[$i]</b> ";
}
else {
echo "<a href=\"bbs_list.php?board=$board&page=$i\">[$i]</a> ";
}
} // 중간
// 이동할 페이지의 가장 끝이 마지막 페이지보다 작을 경우 생략 기호 출력
if ($nexs < $tlpn[page]) {
echo "<b> ... </b>";
}
if ($page == $tlpn[page]) { // 맨 끝 페이지
echo "<b>[Last]</b> ";
}
else {
echo "
<a href=\"bbs_list.php?board=$board&page=$tlpn[page]\">[Last]</a> ";
} // 맨 끝 페이지 완료
}
?>