| 제목 | 125페이지 입력부분 질문 입니다. | ||
|---|---|---|---|
| 글쓴이 | 책상다리 | 작성시각 | 2013/10/28 11:34:14 | 
|  | |||
|   게시판의 글쓰기 부분을 만들어봤습니다. 글도 써지고, 입력되었습니다. 라는 팝업창도 뜨면서, DB에도 글도 무사히 등록되고 다 잘되는데, 입력되었습니다. 팝업 창이 뜨면서 뒤에 애러 문구가 하나 나오는데요. 이걸 해결을 못하겠습니다.. 애러 메세지는 Undefined offset: 4 파일 이름은 controllers/board.php 라인은 152번째 입니다. 아래는 제가 작성한 board.php 전체 내용입니다. 그대로 해석하면 offset 4가 정의되있지 않다는거 같은데, 해결방법을 모르겠습니다..ㅠ 도와주세요 ㅠ 
<?php if ( ! defined('BASEPATH')) exit('No direct script access allowed');
class Board extends CI_Controller{
 function __construct()
 {
  parent::__construct();
    $this->load->database();
    $this->load->model('board_m');
 }
 public function index()
 {
  $this->lists();
 }
 public function _remap($method)
 {
  $this->load->view('header_v');
  if(method_exists($this, $method))
  {
   $this->{"{$method}"}();
  }
  $this->load->view('footer_v');
 }
 public function lists()
 {
  $this->output->enable_profiler(FALSE);
  //검색어 초기화
  $search_word = $page_url = '';
  $uri_segment = 5;
  //주소중에서 q(검색어) 세그먼트가 있는지 검사하기 위해 주소를 배열로 변환
  $uri_array = $this->segment_explode($this->uri->uri_string());
  if( in_array('q', $uri_array) ) {
   //주소에 검색어가 있을 경우의 처리. 즉 검색시
   $search_word = urldecode($this->url_explode($uri_array, 'q'));
   //페이지네이션용 주소
   $page_url = '/q/'.$search_word;
   $uri_segment = 7;
  }
  $this->load->library('Pagination');
  //페이지네이션 설정
  $config['base_url'] = '/board/lists/ci_board'.$page_url.'/page/'; //페이징 주소
  $config['total_rows'] = $this->board_m->get_list($this->uri->segment(3), 'count','','',$search_word);
   //게시물의 전체 개수
  $config['per_page'] = 5; //한 페이지에 표시할 게시물 수
  $config['uri_segment'] = $uri_segment; //페이지 번호가 위치한 세그먼트
  //페이지네이션 초기화
  $this->pagination->initialize($config);
  //페이지 링크를 생성하여 view에서 사용할 변수에 할당
  $data['pagination'] = $this->pagination->create_links();
  //게시물 목록을 불러오기 위한 offset, limit 값 가져오기
  $page = $this->uri->segment($uri_segment, 1);
  if( $page > 1 )
  {
   $start = (($page/$config['per_page'])) * $config['per_page'];
  }
  else
  {
   $start = ($page-1) * $config['per_page'];
  }
  $limit = $config['per_page'];
  $data['list'] = $this->board_m->get_list($this->uri->segment(3), '', $start, $limit, $search_word);
  $this->load->view('board/list_v',$data);
 }
 function view()
 {
  $data['views'] = $this->board_m->get_view($this->uri->segment(3), $this->uri->segment(4));
  $this->load->view('board/view_v',$data);
 }
 function write()
 {
  echo '<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />';
  if( $_POST )
  {
   //글쓰기 POST 전송 시
   //경고창 헬퍼 로딩
   $this->load->helper('alert');
   //주소 중에서 page세그먼트가 있는지 검사하기 위해 주소를 배열로 변환
   $uri_array = $this->segment_explode($this->uri->uri_string());
   if( in_array('page', $uri_array) )
   {
    $pages = urldecode($this->url_explode($uri_array, 'page'));
   }
   else
   {
    $pages = 1;
   }
   if( !$this->input->post('subject', TRUE) AND !$this->input->post('contents', TRUE) )
   {
    //글 내용이 없을 경우, 프로그램단에서 한번 더 체크
    alert('비정상적인 접근입니다.','/board/lists/'.$this->uri->segment(3).'/page/'.$pages);
    exit;
   }
   //var_dump($_POST);
   $write_data = array(
    'table' => $this->uri->segment(3),
    'subject' => $this->input->post('subject', TRUE),
    'contents' => $this->input->post('contents', TRUE),
   );
   $result = $this->board_m->insert_board($write_data);
   if( $result )
   {
    //글 작성 성공 시 게시물 목록으로
    alert('입력되었습니다.', '/board/lists/'.$this->uri->segment(3).'/page/'.$pages);
    exit;    
   }
   else
   {
    //글 실패 시 게시물 목록으로
    alert('다시 입력해 주세요.','/board/lists/'.$this->uri->segment(3).'/page/'.$pages);
    exit;
   }
  }
  else
  {
   //쓰기 폼 view 호출
   $this->load->view('board/write_v');
  }
 }
 function url_explode($url, $key)
 {
  $cnt = count($url);
  for($i=0; $cnt>$i; $i++ )
  {
   if($url[$i] == $key)
   {
    $k = $i+1;
    return $url[$k];
   }
  }
 }
 function segment_explode($seg)
 {
  //세크먼트 앞뒤 '/' 제거후 uri를 배열로 반환
  $len = strlen($seg);
  if(substr($seg, 0, 1) == '/')
  {
   $seg = substr($seg, 1, $len);
  }
  $len = strlen($seg);
  if(substr($seg, -1) == '/')
  {
   $seg = substr($seg, 0, $len-1);
  }
  $seg_exp = explode("/", $seg);
  return $seg_exp;
 }
} | |||
| 다음글 | 56페이지 질문입니다. (2) | ||
| 이전글 | xampp 컨트롤러 실행시간 1초이상 나옵니다. (3) | ||
| 
                                변종원(웅파)
                                /
                                2013/10/28 12:01:59 /
                                추천
                                0
                             | 
| 
                                책상다리
                                /
                                2013/10/28 12:36:26 /
                                추천
                                0
                             
                                 아 죄송합니다...;; return$url[$k]; | 
| 
                                변종원(웅파)
                                /
                                2013/10/28 13:42:54 /
                                추천
                                0
                             
                                해당 함수는 주소의 세그먼트를 배열화 한 것에서 특정 키워드를 찾아주는 것인데 아무래도 write 주소를 잘못 적용하신 것 같습니다. 쓰기 주소는 http://도메인/bbs/board/write/ci_board/page/1 입니다. | 
| 
                                변종원(웅파)
                                /
                                2013/10/28 13:48:40 /
                                추천
                                0
                             
                                127 라인이 잘못 되었네요. 입력은 정상적으로 되는데 입력후 리스트로 포워딩할때 세그먼트를 잘못 지정하셨네요. 책 소스에는 /bbs/board/lists 로 시작을 합니다. 그래서 3번째 세그먼트로 지정되어 있고 책상다리님처럼 bbs 폴더를 없애고 사용한 경우에는 /board/lists/ '.$this->uri->segment(2) 가 되어야 합니다. | 
| 
                                책상다리
                                /
                                2013/10/28 14:21:37 /
                                추천
                                0
                             
                                아 답변 감사합니다. 그런데 아직 애러가 그대로 나고, 추가로  Error Number: 1064 You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'write ORDER BY board_id DESC' at line 1 SELECT * FROM write ORDER BY board_id DESC Filename: C:\xampp\htdocs\system\database\DB_driver.php Line Number: 330 | 
| 
                                변종원(웅파)
                                /
                                2013/10/29 12:09:53 /
                                추천
                                0
                             
                                세그먼트를 수정하게 되면 관련된 소스를 전부 수정해야 합니다. 쿼리 에러는 세그먼트에서 테이블명을 가져오도록 되어 있는데 그 값이 없어서 나는 에러입니다. http://도메인/bbs/board/write/ci_board/page/1 위 주소에서 ci_board가 테이블명입니다. | 
| 
                                책상다리
                                /
                                2013/10/29 14:06:50 /
                                추천
                                0
                             
                                 감사합니다. 정말 찬찬히 다시 봐야겠습니다...;;
                             | 
해당하는 라인을 찝어주세요. ^^;