메뉴 건너뛰기

프로그램언어

조회 수 35890 추천 수 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
번호 제목 날짜 조회 수
200 몫과 나머지 구하기 2017.03.07 18471
199 PHP에서 데이터를 엑셀(Excel)로 저장 2017.02.19 18431
198 정규표현식 검사 도구 (ereg, eregi) 2016.12.23 18395
197 이스케이프 함수 (htmlentities) 2016.12.23 18375
196 PHP 속도 테스트 20 가지 2017.03.06 18306
195 PHP EXCEL export시 시트 이름 지정하여 여러 시트에 데이터 쓰기 2017.03.06 18270
194 fileatime 파일에 최종적으로 접근한 시간을 반환 2016.12.23 18117
193 문자열의 태그를 그대로 출력 (htmlspecialchars) 2016.12.23 18069
192 is_array — 변수가 배열인지 확인 2016.12.23 18048
191 gd_info 사용 가능한 GD 라이브러리에 대한 정보를 배열로 반환 2016.12.23 17989
190 네이버 자동 띄어쓰기를 이용하기 2017.03.27 17940
189 PHP로 엑셀 자료 MySQL에 넣기 2017.03.06 17875
188 어떤 스마트폰으로 접속했는지 알아내는 소스 , (안드로이드 아이폰 ) 2014.03.26 17716
187 PHP 날짜 함수 2017.04.13 17673
186 http://홈주소/?mode=xxx 하는방법 2017.03.07 17642
185 그누보드, 여분필드 사용팁 2017.03.06 17606
184 정규식 2017.04.13 17599
183 PHP 도메인 이름이나 웹문서 주소 알아내기 2017.03.06 17589
182 text파일에 한줄씩 내용추가하기 2017.03.06 17538
181 문자열에서 태그를 제거 (strip_tags) 2016.12.23 17522
Board Pagination Prev 1 ... 3 4 5 6 7 8 9 10 11 12 ... 17 Next
/ 17

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

© k2s0o1d4e0s2i1g5n. All Rights Reserved