메뉴 건너뛰기

프로그램언어

조회 수 35894 추천 수 1 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
PHP] 게시판 글쓰기와 이미지 파일 DB 저장 및 불러오기 예제

게시판에 글쓰고, 이미지 파일 전송하여 DB에 저장하고, 게시물 볼때 게시물 내용과 이미지 파일 불러오는 예제입니다.
어느분이 물어보셔서 저장과 불러오기를 보여주기 위한 예제라 소스가 다소 엉성합니다~
개략적인 흐름만 참고하시고, 필요한 부분 덧붙여 사용하시면 될듯 합니다.

DB생성
- 게시판 글 내용 담을 테이블
CREATETABLE`inetag`.`test_bbs` (
 `bbsNo` INT NOTNULLAUTO_INCREMENTPRIMARYKEY ,
 `id` VARCHAR( 20)NOTNULL ,
 `content` VARCHAR( 255)NOTNULL ,
 `regdate` TIMESTAMP NOTNULLDEFAULT CURRENT_TIMESTAMP
) ENGINE=MYISAM ;

- 이미지 파일정보 담을 테이블
CREATETABLE`inetag`.`test_image` (
 `fileNo` INT NOTNULLAUTO_INCREMENTPRIMARYKEY ,
 `bbsNo` INT NOTNULL ,
 `path` VARCHAR( 255)NOTNULL ,
 `filename` VARCHAR( 50)NOTNULL
) ENGINE=MYISAM ;

소스
- form.php


<html>
<head>
	<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
	<title>게시물 작성 예제 폼</title>
</head>
<body>
	<form enctype="multipart/form-data" name="form" method="post" action="write.php">
		<table>
		<tr>
			<td>아이디:</td>
			<td><input type="text" name="id" /></td>
		</tr>
		<tr>
			<td>내용:</td>
			<td><textarea name="content"></textarea></td>
		</tr>
		<tr>
			<td>이미지:</td>
			<td><input type="file" name="imageform" /></td>
		</tr>
		<tr>
			<td colspan="2">
				<input type="submit" value="전송" />
			</td>
		</tr>
		</table>
	</form>
</body>
</html>



- write.php

<?
$id = $_POST['id'];
$content = $_POST['content'];

include "../include/db_connect.php";

$query = "insert into test_bbs (id,content) values('$id','$content')";

$db_inet->query($query);

$bbsid = $db_inet->insert_id;

//$path = $_SERVER['DOCUMENT_ROOT'].'/testBBS/';
$path = "/testBBS/";
$filename =  date("YmdHis").".jpg";
move_uploaded_file($_FILES['imageform']['tmp_name'], $filename);

$query = "insert into test_image (bbsNo,path,filename) values ($bbsid, '$path','$filename')";

$db_inet->query($query);

?>
<html>
<head>
	<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
	<title>게시물 작성 예제 폼</title>
</head>
<body>
<table>
<tr>
	<td>전송아이디:</td>
	<td><?=$id;?></td>
</tr>
<tr>
	<td>전송내용:</td>
	<td><?=$content;?></td>
</tr>
<tr>
	<td>전송이미지</td>
	<td><img src="<?=$path.$filename;?>" /></td>
</tr>
</table>
<p><b>전송완료</b></p>
<p><a href='list.php'>목록가기</a></p>
</body>
</html>



- list.php

<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<?
include "../include/db_connect.php";
$result = $db_inet->query("select * from test_bbs");

echo "<table border=1>";
while($row = $result->fetch_assoc()) {
	echo "<tr>";
	echo "<td>".$row['bbsNo']."</td>";
	echo "<td>".$row['id']."</td>";
	echo "<td><a href='view.php?bbsno=".$row['bbsNo']."'>".$row['content']."</a></td>";
	echo "<td>".$row['regdate']."</td>";
	echo "</tr>";
}

?>



- view.php

<?
$bbsno = $_GET['bbsno'];
include "../include/db_connect.php";
$result = $db_inet->query("select * from test_bbs where bbsNo=".$bbsno);
$row = $result->fetch_assoc();

$result = $db_inet->query("select * from test_image where bbsNo=".$bbsno);
$row2 = $result->fetch_assoc();
?>
<html>
<head>
	<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
	<title>게시물 보기</title>
</head>
<body>
<table>
<tr>
	<td>번호</td>
	<td><?=$row['bbsNo'];?></td>
</tr>
<tr>
	<td>아이디</td>
	<td><?=$row['id'];?></td>
</tr>
<tr>
	<td>내용</td>
	<td><?=$row['content'];?></td>
</tr>
<tr>
	<td>작성시간</td>
	<td><?=$row['regdate'];?></td>
</tr>
<tr>
	<td>이미지</td>
	<td>
<?
if(!empty($row2)) 
	echo "<img src='".$row2['path'].$row2['filename']."' />";
else 
	echo "이미지 없음";
?>
	</td>
</tr>
</table>
<p><b>전송완료</b></p>
<p><a href='list.php'>목록가기</a></p>
</body>
</html>


정말 간략한 예제입니다^^ 디자인에는 전혀 신경쓰지 않았으니 흐름만 참고하세여~


List of Articles
번호 제목 날짜 조회 수
20 리스트 페이징 2014.02.27 19386
19 필드값 저장 2014.02.27 24282
18 엔터의 표현 2014.02.27 19535
17 $_SERVER변수 2014.02.27 24446
16 날짜 계산하기 (하루전 날짜 구하기) 2014.02.27 21627
15 유용한 함수 모음 2014.02.27 21422
14 페이지 로딩 시간 측정 2014.02.27 26046
13 PHP에서 자바스크립트 값 가져오기 2014.02.27 31636
12 주간날짜 뽑아오기 2014.02.27 26733
11 로또 숫자 랜덤하게 1~45까지 숫자 빼오기 2014.02.27 25438
10 Record Drag/Drop Position 2014.02.27 29201
9 글내용 이미지 리사이징 2014.02.27 29446
8 쿠키변수받기 2014.02.27 29228
7 GD를 이용한 스팸성 게시물 차단을 위한 보안 단어 입력 예제 2014.02.27 26945
6 DB상의 많은 파일을 한꺼번에 다운받기 2014.02.27 28332
5 PHP에서 PDF파일 생성하기 2014.02.27 32783
4 PHP로 Excel 파일 만들기... 2014.02.27 30257
3 Text를 GD 이미지로 뿌리기 2014.02.27 29814
2 Class를 이용한 DB Connection 소스 (Oracle, MyS 2014.02.27 30504
1 무조건 알아야 할 PHP 속도 테스트 14 가지 2014.02.27 30280
Board Pagination Prev 1 ... 8 9 10 11 12 13 14 15 16 17 Next
/ 17

하단 정보를 입력할 수 있습니다

© k2s0o1d4e0s2i1g5n. All Rights Reserved