제목 | 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
감사합니다. 정말 찬찬히 다시 봐야겠습니다...;;
|
해당하는 라인을 찝어주세요. ^^;