프로젝트/게시판 사이트
[html, php] 게시판사이트 만들기 4.게시판 페이지, 글/댓글 쓰기
바디스
2021. 3. 1. 21:26
게시판 페이지
사이트 왼쪽에 카테고리에서 선택한 게시판이 열리게된다.
게시글은 한 페이지에 5개씩 출력되고 여러 페이지로 나뉜다.
처음 이전 다음 마지막 버튼과 페이지 번호들로 페이지 이동이 가능하다.
검색창으로 제목, 작성자, 내용으로 검색하여 게시판을 검색할 수 있다.
게시판 코드는 너무 길어서 생략합니다.
글쓰기
게시판 페이지에서 글쓰기 버튼을 누르면 글쓰기 페이지로 이동한다.
제목과 내용을 입력하고 글 작성 버튼을 누르면 글이 작성된다.
파일을 업로드 가능하다.
<write.php> - 글작성 ui
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
|
<!DOCTYPE html>
<head>
<meta charset="UTF-8">
<title>게시판</title>
</head>
<body>
<?$board_id=$_GET['board_id'];?>
<div id="board_write">
<h4>글을 작성하는 공간입니다.</h4>
<div id="write_area">
<form enctype="multipart/form-data" action="write_ok.php?board_id=<?echo $board_id;?>" method="post">
<div id="in_title">
<textarea name="title" id="utitle" rows="1" cols="55" placeholder="제목" maxlength="100" required></textarea>
</div>
<div class="wi_line"></div>
<div id="in_content">
<textarea name="content" id="ucontent" placeholder="내용" required></textarea>
</div>
<input type="file" name="SelectFile" />
<div class="bt_se">
<button type="submit">글 작성</button>
</div>
</form>
</div>
</div>
</body>
</html>
|
cs |
<write_ok.php> - 오류를 확인하고 데이터베이스에 글을 작성하는 부분
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
|
<?php
include ('db_connect.php');
$username = $_SESSION['userid'];
$usernic = $_SESSION['user_nic'];
$board_id = $_GET['board_id'];
$title = $_POST['title'];
$content = $_POST['content'];
$date = date('Y-m-d');
$upload_dir = 'uploads/';
$upload_file = $upload_dir . $_FILES['SelectFile']['name'];
$file_name = iconv("utf-8","CP949",$upload_file);
echo "<script>
alert('$tmpfile');
</script>";
print "<pre>";
if (move_uploaded_file($_FILES['SelectFile']['tmp_name'], $file_name)) {
print "[수신한 내용]<br><br>";
print "PATH: " .$upload_file."<br>";
print "제목 : ".$_POST['title']."<br>";
print "내용 : ".$_POST['content']."<br>";
print "파일 :".$_FILES['SelectFile']['type']."<br>";
if($_FILES['SelectFile']['type']=="image/jpeg"||$_FILES['SelectFile']['type']=="image/gif"){
print "<img src=$upload_file width='300'>";
}
}
else {
print "파일 업로드 실패 : ";
switch ($_FILES[SelectFile][error]) {
case UPLOAD_ERR_INI_SIZE:
print "php.ini 파일의 upload_max_filesize(".ini_get("upload_max_filesize").")보다 큽니다.<br>";
break;
case UPLOAD_ERR_FORM_SIZE:
print "업로드 한 파일이 Form의 MAX_FILE_SIZE 값보다 큽니다.<br>";
break;
case UPLOAD_ERR_PARTIAL:
print "파일의 일부분만 전송되었습니다.<br>";
break;
case UPLOAD_ERR_NO_FILE:
print "파일이 전송되지 않았습니다.<br>";
break;
case UPLOAD_ERR_NO_TMP_DIR:
print "임시 디렉토리가 없습니다.<br>";
break;
}
print_r($_FILES);
}
print "</pre>";
if($username && $title && $content){
$sql = mq("insert into ".$board_id."(id,name,title,content,date,file) values('".$username."','".$usernic."','".$title."','".$content."','".$date."','".$_FILES['SelectFile']['name']."');");
echo "<script>
alert('글쓰기 완료되었습니다.');
location.href='board.php?board_id=$board_id';</script>";
}
else{
echo "<script>
alert('글쓰기에 실패했습니다.');
history.back();</script>";
}
?>
|
cs |
글읽기
게시판 페이지에서 게시글을 누르면 데이터베이스에서 그 게시글을 읽어와 출력한다.
글을 읽어 올 때 댓글도 같이 읽어 온다.
<read.php> - 게시글과 댓글을 읽어오는 부분
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
|
<?php
include ('db_connect.php');
?>
<!doctype html>
<html>
<head>
<meta charset="UTF-8">
<title>게시판</title>
</head>
<body>
<?php
$board_id = $_GET['board_id'];
$bno = $_GET['idx']; /* bno함수에 idx값을 받아와 넣음*/
$hit = mysqli_fetch_array(mq("select * from ".$board_id." where idx ='".$bno."'"));
$hit = $hit['hit'] + 1;
$fet = mq("update ".$board_id." set hit = '".$hit."' where idx = '".$bno."'");
$sql = mq("select * from ".$board_id." where idx='".$bno."'"); /* 받아온 idx값을 선택 */
$board = $sql->fetch_array();
?>
<!-- 글 불러오기 -->
<div id="board_read">
<h2><?php echo $board['title']; ?></h2>
<div id="user_info" align=right>
<?php echo $board['name']; ?> <?php echo $board['date']; ?> 조회:<?php echo $board['hit']; ?>
<div id="bo_line"></div>
</div>
<div>
파일 : <a href="uploads/<?php echo $board['file'];?>" download><?php echo $board['file']; ?></a>
</div>
<div id="bo_content">
<?php echo nl2br("$board[content]"); ?>
</div>
<!-- 목록, 수정, 삭제 -->
<div id="bo_ser">
<ul>
<li><a href="board.php?board_id=<?echo $board_id;?>">[목록으로]</a></li>
<?if ($board['name']==$_SESSION['userid']){?>
<li><a href="modify.php?idx=<?php echo $board['idx']; ?>">[수정]</a></li>
<li><a href="delete.php?idx=<?php echo $board['idx']; ?>">[삭제]</a></li>
<?}?>
</ul>
</div>
</div>
<!--- 댓글 불러오기 -->
<div class="reply_view">
<h3>댓글목록</h3>
<?php
$sql3 = mq("select * from ".$board_id."_reply where con_num='".$bno."' order by idx desc");
while($reply = $sql3->fetch_array()){
?>
<div class="dap_lo">
<div><b><?php echo $reply['name'];?></b></div>
<div class="dap_to comt_edit"><?php echo nl2br("$reply[content]"); ?></div>
<div class="rep_me dap_to"><?php echo $reply['date']; ?></div>
</div>
<?php } ?>
<!--- 댓글 입력 폼 -->
<div class="dap_ins">
<form action="reply_ok.php?board_id=<?echo $board_id;?>&idx=<?php echo $bno; ?>" method="post">
<input type="hidden" name="dat_user" id="dat_user" class="dat_user" size="15" placeholder="아이디" value=<?$_SESSION['userid']?>>
<div style="margin-top:10px; ">
<textarea name="content" class="reply_content" id="re_content" ></textarea>
<button id="rep_bt" class="re_bt">댓글</button>
</div>
</form>
</div>
</div><!--- 댓글 불러오기 끝 -->
<div id="foot_box"></div>
</div>
</body>
</html>
|
cs |
<reply_ok.php> 댓글을 작성하는 부분
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
<?php
include ('db_connect.php');
$board_id = $_GET['board_id'];
$bno = $_GET['idx'];
$username = $_SESSION['userid'];
$date = date("Y-m-d H:i:s");
if($bno && $username && $_POST['content']){
$sql = mq("insert into ".$board_id."_reply (con_num,id,name,content,date) values ('".$bno."','".$username."','".$username."','".$_POST['content']."','".$date."');");
echo "<script>alert('댓글이 작성되었습니다.');
location.href='read.php?board_id=$board_id&idx=$bno;';</script>";
}else{
echo "<script>alert('댓글 작성에 실패했습니다.');
history.back();</script>";
}
?>
|
cs |