메뉴 건너뛰기

프로그램언어

조회 수 35882 추천 수 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
번호 제목 날짜 조회 수
220 내 계정 용량 체크 2019.01.08 1595
219 사업자번호로 사업자 종류알기 2019.01.08 1222
218 디비내용을 엑셀 파일로 다운로드 시키는 방법 2019.01.08 1391
217 php/asp에서 가상번호 부여와 가상번호를 거꾸로 적용 2019.01.08 1429
216 php에서 체크박스 선택한 것 보여주기 file 2019.01.08 1803
215 배열을 테이블로 만들기 2019.01.08 1624
214 include 와 namespace 2019.01.08 1087
213 파일 2019.01.08 1226
212 디렉토리의 제어 2019.01.08 1214
211 PHP 문자열에서 검색어를 기준으로 앞뒤로 일정 길이만큼 자르기 2018.10.27 3539
210 PHP 랜덤확률 구하기 2018.10.27 4761
209 PHP 소켓을 이용하여 URL의 응답결과를 문자열로 받기 2018.10.27 3502
208 PHP 랜덤 문자열 생성 2018.10.27 4121
207 PHP XML 문서파싱 (SAX 방식 , DOM 방식) file 2018.10.27 3585
206 PHP split()와 explode()의 차이점 2018.10.27 3536
205 PHP eregi가 빠를까, strpos가 빠를까? 2018.10.27 4091
204 PHP 확장 모듈을 이용한 C 라이브러리 사용 2018.10.27 3785
203 자바스크립트 이스케이프 문자열을 PHP로 디코딩 하기 2018.10.27 3259
202 이미지 땡겨와서 출력하기 2018.09.28 5284
201 DB 연동 4단 셀렉트 박스 2018.09.28 6070
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 11 ... 17 Next
/ 17

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

© k2s0o1d4e0s2i1g5n. All Rights Reserved