테스트 사이트 - 개발 중인 베타 버전입니다

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

처음에 저도 이부분이 힘들었습니다. 하지만 원리를 알고 보면 쉽습니다.
필드 추가시에 문제가 되는 부분은 업데이트 할때 에러나는 부분입니다.
 
게시판 리스트와 뷰 부분에서는 따로 손대지 않아도 추가된 필드가 자동으로 불러와집니다.
 
나중에 배우시겠지만 필드를 불러올때 부분적으로 필요한 것만 불러오기도 하고 테이블에 있는 필드를 다 불러오게 하는 방법이 있습니다. 리스트와 뷰 페이지에서는 전체를 다 불러오니...궂이 다른 설정안하셔도 됩니다.
문제는 글쓰기 에서 업데이트 시키는 부분입니다.
 
그누보드의 기본 구조는 공통적으로 사용되는 페이지와 스킨으로 되어 있습니다.
 
게시판을 보면 모두 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개를 사용할수 있습니다.
 
단, 정말 주의할점은 필드추가한 것은 모든 게시판에 한것이 아니기 때문에...저 추가된 스킨을 다른 게시판에 적용하면 저 필드가 없다는 메세지가 뜹니다.......
 
꼭 필드를 추가한 게시판에서만 스킨을 사용해야 합니다..

댓글 작성

댓글을 작성하시려면 로그인이 필요합니다.

로그인하기

게시글 목록

번호 제목
15661
15657
3688
15650
15648
15647
15642
3676
29958
15639
15635
15632
3672
15630
15629
15628
15625
15624
15621
15613
3669
29953
15605
15604
15602
15601
15600
3666
3663
15596
29952
3662
15592
3655
29944
3648
15591
15589
29937
3644
3641
15586
15585
29936
15583
15578
15575
15572
15567
15563
24338
15560
15556
26168
29935
15552
3626
3617
3605
3596
15549
15547
15546
29933
26167
26166
26165
26164
26163
26161
26160
26152
26149
26148
26147
26146
26145
26141
26138
26134
15539
3590
29931
3583
3581
3578
15537
15535
29926
15524
29920
3560
15521
3557
29919
15517
29914
15506
29910
29909