前提・実現したいこと
初めまして。まだ勉強を始めて間もないものです。勉強不足だとは思いますが、どなたかお力を貸していただけませんでしょうか。
CakePHPで「タイトル」「内容」「作成者」の画面から、editでテーブルに反映させたいのですが、「作成者」の名前だけがフォームにきちんと入力してもテーブルに反映されません。
宜しくお願い致します。
わかりづらい文章で申し訳ありません。
発生している問題・エラーメッセージ
作成者が登録、表示されません。また、エラーメッセージは出てはいません。
<?php App::uses('AppController', 'Controller'); class PostsController extends AppController { public function index() { $posts = $this->Post->find('all'); $this->set('posts',$posts); } public function add() { if ($this->request->is('post')) { if($this->Post->save($this->request->data)) { $this->Session->setFlash('登録されました'); return $this->redirect(array('action' => 'index')); } } } public function edit($id = null) { if ($this->request->is(array('post','put'))) { if ($this->Post->save($this->request->data)) { $this->Session->setFlash(__('保存しました')); return $this->redirect(array('action' => 'index')); } else { $this->Session->setFlash(__('保存できませんでした')); } } else { $options = array('conditions' => array('Post.'. $this->Post->primaryKey => $id)); $this->request->data = $this->Post->find('first',$options); } } public function delete($id = null) { if ($this->repuest->is('post')) { if ($this->Post->delete($id)) { $this->Session->setFlash(__('削除できました')); }else{ $this->Session->setFlash(__('削除できませんでした')); return $this->redirect(array('action' => 'index')); } }
view <html> <meta charset="utf-8"> <body> <table> <tr> <th>ID</th> <th>title</th> <th>本文</th> <th>作成者</th> <th>操作</th> </tr> <tr> <?php foreach ($posts as $post) { ?> <tr> <td><?php echo $post['Post']['id']; ?></td> <td><?php echo $post['Post']['title']; ?></td> <td><?php echo $post['Post']['body']; ?></td> <td><?php echo $post['Post']['writer']; ?></td> <td><?php echo $post['Post']['data']; ?></td> <td><?php echo $post['Post']['data_taime']; ?></td> <td><?php echo $this->Html->link(__('編集'),array('action' => 'edit', $post['Post']['id'])); ?> <?php echo $this->Form->postLink(__('削除'),array('action' => 'delete', $post['Post']['id']), array('confirm' => __('削除してよろしいですか?'))); ?></td> </tr> <?php } ?> </table> </body> </html>
model <?php App::uses('AppModel','Model'); class Post extends AppModel { public $validate = array( 'title' => array( 'notblank' => array( 'rule' => array('notblank'), 'message' => 'タイトルを入力してください。', ), 'maxLength' => array( 'rule' => array('maxLength',30), 'message' => 'タイトルは30字以内で入力してください。', ), ), 'body' => array( 'notblank' => array( 'rule' => array('notblank'), 'message' => '本文を入力してください。', ), ), 'writer' => array( 'notblank' => array( 'rule' => array('notblank'), 'message' => '本文を入力してください。', ), 'maxLength' => array( 'rule' => array('maxLength',10), 'message' => 'タイトルは10字以内で入力してください。', ), ), ); } ?>
edit.ctp <?php echo $this->Form->create('Post'); echo $this->Form->input('id'); echo $this->Form->input('title'); echo $this->Form->input('body'); echo $this->Form->input('writer'); echo $this->Form->end('送信'); ?> var_dump($this->request->data);exit;
Nr Query Error Affected Num. rows Took (ms) 1 SELECT `Post`.`id`, `Post`.`title`, `Post`.`body`, `Post`.`作成者`, `Post`.`作成日`, `Post`.`更新日` FROM `fencer`.`posts` AS `Post` WHERE 1 = 1 12 12 0
試したこと
if ($this->Post->save($this->request->data)) {
のPostをwriterに変えたらエラーになってしまいました。
ここに問題に対して試したことを記載してください。
補足情報(FW/ツールのバージョンなど)
これだけだと「requestに作成者が入ってないんじゃないか」くらいしか言えません。
requestを送るフォームのHTML(またはview)
そこにどういうデータが表示されているか、
$this->request->data の内容(dd()で良いです)
データベースの定義(CREATE TABLE文が良いです)を質問本文に追記してください。
また「作成者だけがうまく反映されません。」がどういう状況なのか詳細に記載いただければと思います。
m.ts10806様
コメントありがとうございます。
説明不足で大変申し訳ありません。
追記したのでどうか宜しくお願い致します。
細かくて申し訳ないですが、もうちょっと調整いただきたいです。
・ファイルが違うのでしたらコードブロックはわけてもらいたいです
・viewファイル冒頭に何かいます [å]<html>
・テーブル定義を提示してください(要は対象のテーブルを作成するためのSQLのCREATE TABLE文です。)
・edit()でdd($this->request->data);もしくはvar_dump($this->request->data);exit;を書いて結果を教えてください。
懸念点
・viewには画面表示しているだけでフォーム送信できる情報が何もないのでは?
m.ts10806さま
ご丁寧にありがとうございます。
これが私の今の全知識です。
無知で申し訳ありません。
あと、var_dump($this->request->data);exit;
は何も起きませんでした。
えーっと・・
・posts というDBのテーブルはどのように作りましたか?例えばマイグレーションを実行したとか。そのマイグレーションのファイルとかでも良いです。要はpostsというテーブルにどういうカラムがあって、それぞれどういう型で、というのが知りたいので。
・var_dump($this->request->data);exit;はそこ(.ctp)ではないです。あくまで「登録処理をする際にちゃんと送信したいデータがきているか」の確認をしたいので、PostsController のedit()の冒頭に仕掛けてください。
DBはMyadminで作りました。id,title,body,作成者、作成日、更新日のカラムがあります。
var_dump($this->request->data);exit;をPostsController のedit()の冒頭に書着なおしたのですが何も起きませんでした。
話がずれていたら申し訳ありません。
>DBはMyadminで作りました。
phpMyAdmin ですね。了解です。
ではphpMyAdminでpostsテーブルの「構造」タブを開いて画面キャプチャをご提示ください。
そこにテーブルの定義が表示されているはずです。
> var_dump($this->request->data);exit;をPostsController のedit()の冒頭に書着なおしたのですが何も起きませんでした。
んーおかしいですね。edit()が実行されたら必ず通るはずですが。
↓のようにしてますよね?
public function edit($id = null) {
var_dump($this->request->data);exit;
if ($this->request->is(array('post','put'))) {
画像ご確認お願い致します。
public function edit($id = null) {
var_dump($this->request->data);exit;
if ($this->request->is(array('post','put')))
になっていますが、何も起きません。
状況確認できました。先だって回答もしています。
var_dump()通らないのが良く分かりませんね。送信ボタン押して確認しましたか?
想定では送信ボタン押したときにそこで処理が止まって送信された入力情報が出力されると思ったんですが。
もしくは、編集処理であるedit()ではなくadd()の方の話だったか・・
ありがとうございます。
var_dump()、送信ボタン押してもそのままテーブル表示に切り替わります。
exit;をつけていたらそこで処理は中断しますので、exit;は必要ですね。
echo 1; //出力される
exit;
echo 2; //出力されない
回答1件
あなたの回答
tips
プレビュー