예감

[디자이너의 초보PHP강의 02] 필드 추가시 방법

· 14년 전 · 1337
처음에 저도 이부분이 힘들었습니다. 하지만 원리를 알고 보면 쉽습니다.
필드 추가시에 문제가 되는 부분은 업데이트 할때 에러나는 부분입니다.
 
게시판 리스트와 뷰 부분에서는 따로 손대지 않아도 추가된 필드가 자동으로 불러와집니다.
 
나중에 배우시겠지만 필드를 불러올때 부분적으로 필요한 것만 불러오기도 하고 테이블에 있는 필드를 다 불러오게 하는 방법이 있습니다. 리스트와 뷰 페이지에서는 전체를 다 불러오니...궂이 다른 설정안하셔도 됩니다.
문제는 글쓰기 에서 업데이트 시키는 부분입니다.
 
그누보드의 기본 구조는 공통적으로 사용되는 페이지와 스킨으로 되어 있습니다.
 
게시판을 보면 모두 bbs 폴더에서 write.php 와 board.php로 되어 있습니다.
 
이 파일에는 공통적으로 들어가는 부분들이 적용되어 있고 이 파일에서 스킨파일을 불러와서 스킨마다 다른 설정을 주는 것입니다. 쓰기 페이지는 모두 /bbs/write.php  파일에서 적용된 스킨의 write.skin.php 파일을 불러와서 보여주는 것입니다. 스킨적용은 관리자 > 게시판 관리에서 각각 해줄수 있습니다.
 
일단 필드를 추가하셨다면, 손대야 하는 부분은 딱 한군데 입니다. 스킨의 write_update.skin.php 파일입니다.
기본스킨에서는 저파일이 없을수도 있습니다. 없다면....만들어주시거나 공유하는 스킨들을 보셔서 저파일이 있다면 업로드 해주세요...단, 그 파일에 다른 코드가 있다면 삭제해 주세요...
 
다음에 해줄 부분은 추가된 필드를 글쓸때와 수정할때 적용 되도록 해주는 것입니다.
 
<?
if($w==''){
 $sql = " insert into $write_table
                set wr_bob= '$wr_bob',
                     wr_bob2= '$wr_bob2',
                      wr_bob3= '$wr_bob3'
                     ";
    sql_query($sql);
}else if($w=='u'){
  $sql = " update $write_table
                set wr_bob= '$wr_bob',
                     wr_bob2= '$wr_bob2',
                     wr_bob3= '$wr_bob3' 
              where wr_id = '$wr[wr_id]' ";
    sql_query($sql);
}
?>
 
이렇게 넣어주면 됩니다. 변수 $w가 없으면 디비에 추가해주는 것이고 u 값이면 수정해서 업데이트 해주는 것이지요. 주의 할점은 추가필드의 맨 끝에 , 가 없어야 하는 것입니다. ,가 들어가면 에러납니다.
리스트에서는 $list[$i][wr_bob] 으로 넣어주면 되고 뷰페이지에서는 $view[wr_bob] 라고 넣어주면 됩니다.
 
쉽죠 쉽죠???
 
만일 기본적으로 사용하는 추가필드를 사용한다면...저런 설정 안해도 자동적으로 됩니다. wr_1 ~ wr_10까지 10개를 사용할수 있습니다.
 
단, 정말 주의할점은 필드추가한 것은 모든 게시판에 한것이 아니기 때문에...저 추가된 스킨을 다른 게시판에 적용하면 저 필드가 없다는 메세지가 뜹니다.......
 
꼭 필드를 추가한 게시판에서만 스킨을 사용해야 합니다..
|
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

+
제목 글쓴이 날짜 조회
14년 전 조회 1,478
14년 전 조회 4,566
14년 전 조회 1,571
14년 전 조회 3,296
14년 전 조회 1,500
14년 전 조회 1,559
14년 전 조회 1,317
14년 전 조회 1,123
14년 전 조회 2,121
14년 전 조회 1,177
14년 전 조회 1,105
14년 전 조회 1,413
14년 전 조회 1,252
14년 전 조회 1,481
14년 전 조회 1,245
14년 전 조회 2,274
14년 전 조회 2,777
14년 전 조회 1,576
14년 전 조회 1,567
14년 전 조회 1,340
14년 전 조회 3,382
14년 전 조회 1,356
14년 전 조회 1,084
14년 전 조회 1,905
14년 전 조회 2,320
14년 전 조회 1,268
14년 전 조회 1,862
14년 전 조회 1,867
14년 전 조회 1,905
14년 전 조회 2,028
14년 전 조회 1,701
14년 전 조회 9,170
14년 전 조회 1,802
14년 전 조회 2,107
14년 전 조회 1,238
14년 전 조회 1,128
14년 전 조회 1,267
14년 전 조회 1,642
14년 전 조회 2,652
14년 전 조회 1,195
14년 전 조회 2,150
14년 전 조회 2,412
14년 전 조회 1,549
14년 전 조회 1,482
14년 전 조회 1,038
14년 전 조회 1,621
14년 전 조회 1,514
14년 전 조회 1,370
14년 전 조회 1,295
14년 전 조회 1,338
14년 전 조회 1,702
14년 전 조회 2,487
14년 전 조회 1,604
14년 전 조회 1,068
14년 전 조회 1만
14년 전 조회 1,384
14년 전 조회 1,255
14년 전 조회 1,841
14년 전 조회 2,943
14년 전 조회 1,763
14년 전 조회 1,437
14년 전 조회 1,221
14년 전 조회 2,119
14년 전 조회 1,437
14년 전 조회 2,791
14년 전 조회 1,237
14년 전 조회 1,229
14년 전 조회 1,353
14년 전 조회 2,105
14년 전 조회 1,230
14년 전 조회 2,720
14년 전 조회 1,019
14년 전 조회 3,645
14년 전 조회 3,795
14년 전 조회 3,727
14년 전 조회 3,546
14년 전 조회 1,182
14년 전 조회 1,159
14년 전 조회 1,683
14년 전 조회 1,928
14년 전 조회 1,120
14년 전 조회 1,211
14년 전 조회 1,081
14년 전 조회 5,196
14년 전 조회 1,077
14년 전 조회 5,477
14년 전 조회 1,793
14년 전 조회 1,604
14년 전 조회 1,046
14년 전 조회 1,238
14년 전 조회 1,751
14년 전 조회 1,249
14년 전 조회 1,908
14년 전 조회 1,446
14년 전 조회 1,190
14년 전 조회 1,331
14년 전 조회 3,382
14년 전 조회 1,150
14년 전 조회 1,703
14년 전 조회 1,343