15장 자료실 한빛미디어(주).

Slides:



Advertisements
Similar presentations
일정 관리 다이어리 제작 JSP Programming with a Workbook. 학습 목표  사용자의 일정을 관리할 수 있는 다이어리에 대하여 알아보자. JSP Programming with a Workbook2.
Advertisements

XHTML Basic 제 13 장 1. XHTML Basic의 개요 2. XHTML Basic 기본 문법 3. 표 만들기
10장 회원 가입과 로그인 한빛미디어(주).
09장 실습 웹 사이트 소개와 회원가입 페이지 제작.
PARK SUNGJIN Oracle 설치 PARK SUNGJIN
DB 프로그래밍 학기.
DB 프로그래밍 학기.
예방접종 정보 SITE.
Database Laboratory, Hong Ik University
13장 공지사항 한빛미디어(주).
예제모음.
웹 해킹 기초와 실습.
11장 방명록 한빛미디어(주).
8장 쿠키와 세션.
제 09 장 데이터베이스와 MySQL 학기 인터넷비즈니스과 강 환수 교수.
JDBC 프로그래밍 이수지 이동주 1.
13장. 자바빈과 데이터베이스를 연동한 게시판 시스템
6장 Mysql 명령어 한빛미디어(주).
MVC 기반 게시판 작성 Youbok Choi.
MySQL 및 Workbench 설치 데이터 베이스.
(개정판) 뇌를 자극하는 Red Hat Fedora 리눅스 서버 & 네트워크
ㅎㅎ 파일업로드와 이메일 발송 HTTP 파일 업로드와 탭스 업로드 컴포넌트 데이터베이스 연동 자료실 만들기
11장. 데이터베이스 서버 구축과 운영.
14장 질의응답 한빛미디어(주).
5장 Mysql 데이터베이스 한빛미디어(주).
4장. 웹로직 서버상에서의 JDBC와 JTA의 운용
ASP.NET : Database 접근 2008 컴퓨터공학실험(Ⅰ)
Root Filesystem Porting
07장. <TABLE> 태그로 표 디자인하기
SqlParameter 클래스 선문 비트 18기 발표자 : 박성한.
5. JSP의 내장객체1.
Root Filesystem Porting
16장. 테이블의 변경 새로운 행 삽입 테이블에서 테이블로 행을 복사 행 값의 변경 테이블에서 행 삭제
16장 설문조사 한빛미디어(주).
22강. 파일 업로드 - 파일 업로드 라이브러리 설치 - 파일 업로드 프로그래밍 Lecturer Kim Myoung-Ho
17강. 데이터 베이스 - I 데이터 베이스의 개요 Oracle 설치 기본적인 SQL문 익히기
KHS JDBC Programming 4 KHS
5장 Mysql 데이터베이스 한빛미디어(주).
DB연동하기 원격db접속.
Git 사용법 GitHub 가입 GitHub 새 저장소 만들기 Git 설치 로컬 저장소 만들기 로컬 저장소와 원격 저장소 연결
You YoungSEok Oracle 설치 You YoungSEok
Cross Compiler를이용한 커널 컴파일 및 포팅
CHAP 13. 방명록 만들기 실습.
게임웹사이트운영 [10] 폼 작성.
9장 웹 사이트 초기 화면 제작 한빛미디어(주).
JDBC Lecture 004 By MINIO.
JSP 게시판 구현.
JSP Programming with a Workbook
영상처리 실습 인공지능연구실.
Data Base Web Programming
툴 설치 가이드 Formality SynopsysMentor.
8장 쿠키와 세션 한빛미디어(주).
12장 자유게시판 한빛미디어(주).
17장 웹 사이트 제작 완성 한빛미디어(주).
PL/SQL 코드 생성 및 수행 1 여러가지 환경 DOS에서 sqlplus Windows에서의 sqlplusw
CHAP 21. 전화, SMS, 주소록.
문성우 SQL 실습 Part Ⅰ 문성우.
13장 자바빈과 데이터베이스를 연동한 게시판 시스템
테이블 관리 테이블 생성,수정,삭제 데이터 입력 수정, 삭제 2010학년도 2학기.
자바빈/커넥션 풀/세션을 사용한 Ajax 기반의 게시판 시스템
Homework #5 (1/3) 다음을 수행한 후, 결과 파일들을 출력하여 제출한다.
슬라이드 쇼의 설정 슬라이드 쇼의 실행 파일과 폴더의 관리 글꼴을 포함해서 저장 웹 페이지로 게시 압축 파일
maria db JDBC PROGRAMMING 5
Data Base Web Programming
웹과 모바일 홈페이지의 이해와 제작 [PHP / MYSQL] 게시판 만들기
Data Base Mysql.
어드민 로그인 ID : admin 비밀번호 : 서보테크 1. 제품소개 등록 - MISUBISHI
숙제 작성 및 제출 과정 김진하 2008/03/14.
 6장. SQL 쿼리.
제 5 장 MariaDB인덱스 생성 및 관리.
Presentation transcript:

15장 자료실 한빛미디어(주)

학습 목표 자료실의 동작 기능을 이해한다 자료실 게시판의 DB 테이블들의 구조를 이해한다 첨부 파일을 업로드하는 방법에 대하여 이해한다 첨부 파일에 관련된 정보를 DB에 저장하는 방법을 익힌다 첨부파일을 삭제하는 방법을 익힌다 첨부파일에 관련된 정보를 DB에서 가져와 출력하는 부분을 이해한다.

주요 학습 내용 01. 자료실 파일목록 및 DB 테이블 02. 자료실 목록 보기 03. 자료실 글 쓰기 04. 글내용 보기 05. 글 삭제

자료실 미리 보기 01 질의응답에 첨부파일 업로드 기능 추가

자료실 파일 목록 02 파일명 설명 down_board.sql 공지사항 DB 테이블 생성 명령 down_ripple.sql 자료실 파일 목록 02 파일명 설명 down_board.sql 공지사항 DB 테이블 생성 명령 down_ripple.sql 리플 저장을 위한 DB 테이블 생성 명령 list.php 자료실 목록 보기 insert.php 자료실 글을 DB에 저장 insert_ripple.php 리플을 DB에 저장 delete.php 게시판 글을 DB에서 삭제 delete_ripple.php 리플을 DB에서 삭제 modify_form.php 자료실 글 수정 양식 modify.php 자료실 글을 DB에서 수정 search.php 특정 문자열로 검색된 자료실 글 목록 view.php 글 내용 보기 write_form.php 자료실 글쓰기 양식 [표 15-1] 자료실 게시판에 사용되는 파일 목록

자료실 프로그램 설치 03 ⑴ 작업 폴더(“www" 폴더) 밑에 “download" 폴더를 만들고 생성된 “download" 폴더 밑에 교재 뒤 CD의 “www\download" 폴더에 있는 파일들과 "img" 디렉토리를 통째로 복사한다. ⑵ 생성된 “download” 폴더 밑에 “data” 폴더를 만든다. ⑶ 두 개의 자료실 DB 테이블을 생성한다. - 게시판 DB 테이블 - 리플 DB 테이블

not null, auto_increment, primary key 자료실 게시판 DB 테이블 04 필드 이름 타입 추가 사항 필드 설명 num int not null, auto_increment, primary key 일렬 번호 group_num not null 그룹 번호 ord 답변 글 순서 depth 답변 글 깊이 id varchar(10) 아이디 name 이름 subject varchar(100) 제목 content text 글 내용 regist_day varchar(20)   글 쓴 날짜 hit 조회수 ip 접속 IP filename varchar(50) 파일 이름 filesize 파일 크기 [표 15-2] 자료실의 게시판 DB 테이블 (테이블 명 : down_board)

자료실 게시판 DB 테이블 만들기 05 “c:\mysql\bin” 폴더에 “down_board.sql” 파일 작성     CREATE TABLE down_board (        num int not null auto_increment,        group_num int not null,        ord int not null,        depth int not null,        id varchar(10) not null,        name varchar(10) not null,        subject varchar(100) not null,        content text not null,        regist_day varchar(20),        hit int,        ip varchar(20),        filename varchar(50),        filesize varchar(20),        PRIMARY KEY (num)        ); 명령 프롬프트에서 다음을 실행  C:\mysql\bin> mysql -uphp5 -p1234 php5_db < down_board.sql

not null, auto_increment, 자료실 게시판 DB 테이블 06 필드 이름 타입 추가 사항 필드 설명 num int not null, auto_increment, primary key 일렬 번호 parent not null 리플의 부모 글 id varchar(10) 아이디 name varchar(20) 이름 content text 리플 내용 regist_day   리플 단 날짜 ip 접속 IP [표 15-3] 자료실 리플 DB 테이블 (테이블 명 : down_ripple)

자료실 리플 DB 테이블 만들기 07 메모장으로 다음을 타이핑한 다음 “c:\mysql\bin” 폴더 밑에 “down_ripple.sql”이름으로 저장   CREATE TABLE down_ripple (        num int not null auto_increment,        parent int not null,        id varchar(10) not null,        name varchar(10) not null,        content text not null,        regist_day varchar(20),        ip varchar(20),        PRIMARY KEY (num)        ); 명령 프롬프트에서 다음을 실행  C:\mysql\bin> mysql -uphp5 -p1234 php5_db < down_ripple.sql

【예제 15-1】list.php 02 자료실 목록 보기 108 : if ($row[filename])  109 :       { echo “ <td align=center><img src='img/file.gif‘ border=0></td>  111 :                <td align=center>$row[filesize]</td> ";  112 :       }      113 :       else  114 :       {  echo “ <td align=center></td>  116 :                <td align=center></td> ";  117 :       } // 중간 생략  181 :           <td align=right>  182 :              <a href='write_form.php'>  183 :              <img src='img/i_write.gif' align=absmiddle border=0></a>  184 :         <a href="list.php"><img src="img/i_list.gif“ border=0></a>

【예제 15-2】write_form.php 02 자료실 글쓰기 21 : <form name='writeform'  22 :          action='insert.php?num=<? echo $num ?>&page=<? Echo $page ?>'  23 :          method='post' enctype='multipart/form-data'>  24 :     <table width=776 border=0 cellspacing=0 cellpadding=0 align=center>  25 :         <tr>  26 :           <td colspan="5" height=25> <img src="img/down_title.gif"></td> // 중간 생략  97 :           <td><input style='font-size:8pt;border:1px solid' type='file'  98 :                    name='upfile' size=50 maxlength=100></td>  117 :     </form>

파일 업로드 08 변수명 내용 $upfile 서버에 저장되는 임시 파일명 $upfile_name 실제 업로드한 파일명 $upfile_size 파일 크기(바이트) [표 15-4] 파일 업로드 입력 양식에서 name 속성을 “upfile" 로 했을 때 전달되는 변수

【예제 15-3】insert.php 02 DB 테이블에 저장 39 : if($upfile_name) 40 : {  40 :    { 41 : if ( file_exists("data/$upfile_name") ){  42 :         echo(" <script>  44 :        window.alert('선택한 파일과 동일한 이름이 존재합니다.');  45 :         history.go(-1) </script>  47 :      ");  48 :          exit; }  50 :           51 :        if( !$upfile ) { echo(" <script>  54 :               window.alert  55 :               ('업로드 파일 사이즈가 지정된 용량(2M)을 초과합니다.');  56 :               history.go(-1)   </script>  58 :            ");  59 :          exit; }

【예제 15-3】insert.php 02 62 : if( strlen($upfile_size) < 7 )  63 :          $filesize = sprintf("%0.2f KB", $upfile_size/1000);  65 :       else  67 :          $filesize = sprintf("%0.2f MB", $upfile_size/1000000);  69 :  70 :       if( !copy($upfile, "data/$upfile_name") )  71 :       {  72 :          echo("  73 :      <script>  74 :        window.alert  75 :              ('파일을 지정한 디렉토리에 복사하는데 실패했습니다.');  76 :        history.go(-1)  77 :      </script>  78 :            ");  79 :          exit;  80 :       }

【예제 15-3】insert.php 02 82 : if ( !unlink($upfile) ) { 83 : echo("  84 :      <script>  85 :        window.alert('임시파일을 삭제하는데 실패했습니다.');  86 :        history.go(-1)  87 :      </script>  88 :            ");  89 :          exit;  90 :       }  91 :    } 92 : 93 :    if (!$num)  94 :    {  95 :       $depth = 0;   // depth, ord 를 0으로 초기화  96 :       $ord = 0;

【예제 15-3】insert.php 02 98 : // 레코드 삽입 명령 98 :      // 레코드 삽입 명령  99 :       $sql = "insert into down_board  100 :               (depth, ord, id, name, subject,";  101 :       $sql .= "content, regist_day, hit, ip, filename, filesize) ";  102 :       $sql .= "values($depth, $ord, '$userid', '$username',  103 :                       '$subject',";  104 :       $sql .= "'$content', '$regist_day', 0, '$ip', '$upfile_name',  105 :                '$filesize')";     106 :       mysql_query($sql, $connect);  // $sql 에 저장된 명령 실행  107 : // 중간 생략   118 :    } 119 :    else  120 :    { // 부모 글 가져오기  122 :       $sql = "select * from down_board where num = $num";  123 :       $result = mysql_query($sql, $connect);  124 :       $row = mysql_fetch_array($result);

【예제 15-3】insert.php 02  131 :      $sql = "update down_board set ord = ord + 1  132 :         where group_num = $row[group_num] and ord > $row[ord]";  133 :       mysql_query($sql, $connect);   134 :  135 :   $sql = "insert into down_board(group_num, depth, ord, id, name,  136 :               subject,";  137 :     $sql .= "content, regist_day, hit, ip, filename, filesize) ";  138 :     $sql .= "values($group_num, $depth, $ord, '$userid', '$username',  139 :                       '$subject',";  140 :     $sql .= "'$content', '$regist_day', 0, '$ip', '$upfile_name','$filesize')";  142 :       mysql_query($sql, $connect);  // $sql 에 저장된 명령 실행  143 :    }  144 :    mysql_close();                // DB 연결 끊기  146 :    Header("Location:list.php?page=$page");  // list.php 로 이동  147 : ?>

【예제 15-4】view.php 02 글 내용 보기 70 : <? 71 : if ($row[filename])  72 :  {  73 :       echo "  74 :         <tr valign=center>  75 :           <td width=5></td>  76 :           <td><img src='img/file.gif'>  77 :               <a href='data/$row[filename]'>$row[filename]  78 :                ($row[filesize])</a></td></tr>  79 :          <tr height=5 ><td colspan=2></td></tr>  80 :            ";  81 :  }  82 : ?>

【예제 15-5】delete.php 02 글 삭제 11 :    if ($userid != "admin" and $userid != $row[id])   12 :    { echo("  14 :      <script>  15 :              window.alert('삭제 권한이 없습니다.')  16 :              history.go(-1)  17 :      </script>  18 :            ");  19 :       exit;  20 :    }  21 :    else  22 :    { if ($row[filename])  25 :           unlink("data/$row[filename]");  26 :        28 :       $sql = "delete from down_board where num = $num";  29 :       mysql_query($sql, $connect);  30 :    }