質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

CakePHP

CakePHPは、PHPで書かれたWebアプリケーション開発用のフレームワークです。 Ruby on Railsの考え方を多く取り入れており、Railsの高速性とPHPの機動性を兼ね備えています。 MVCやORMなどを「規約優先の考え方」で利用するため、コードを書く手間を省くことができます。 外部のライブラリに依存しないので、単体での利用が可能です。

Q&A

解決済

1回答

925閲覧

cakephpで、一つだけDBに保存できないカラムがある。

tunnel

総合スコア30

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

CakePHP

CakePHPは、PHPで書かれたWebアプリケーション開発用のフレームワークです。 Ruby on Railsの考え方を多く取り入れており、Railsの高速性とPHPの機動性を兼ね備えています。 MVCやORMなどを「規約優先の考え方」で利用するため、コードを書く手間を省くことができます。 外部のライブラリに依存しないので、単体での利用が可能です。

0グッド

1クリップ

投稿2019/08/30 07:00

編集2019/08/30 08:03

Formからusername,password,genderを入力送信してDBに保存させたいのですが、genderだけ保存できません。

var_dump()で$_POSTを確認してみたところgenderの値も入っていました。
---array(5) { ["_method"]=> string(4) "POST" ["_csrfToken"]=> string(128) "4c5d6f8a4b0614cde3b1dff1c5bb4456f9b3a13240c48c21834390ba4a952cf78cc42abe638a4ec99a62e34cc5a839c55c29312275f304cc66423f0da8b5ba61" ["username"]=> string(5) "admin" ["password"]=> string(4) "dsds" ["gender"]=> string(6) "女性" }


テーブル定義は↓です。
+----------+--------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+----------+--------------+------+-----+---------+----------------+
| id | int(11) | NO | PRI | NULL | auto_increment |
| username | varchar(255) | NO | | NULL | |
| created | datetime | NO | | NULL | |
| modified | datetime | NO | | NULL | |
| password | varchar(255) | NO | | NULL | |
| gender | varchar(255) | NO | | NULL | |
+----------+--------------+------+-----+---------+----------------+


var_dump($this->request->data)の結果は下記の通りです。
object(App\Model\Entity\User)#149 (11) { ["username"]=> string(5) "dfdfd" ["password"]=> string(60) "$2y$10$6oWv90.BfzGFvKqbh26R2uZVPAFNUcTOynLye/Rm1bmTKbKsaYGWW" ["[new]"]=> bool(true) ["[accessible]"]=> array(2) { ["username"]=> bool(true) ["password"]=> bool(true) } ["[dirty]"]=> array(2) { ["username"]=> bool(true) ["password"]=> bool(true) } ["[original]"]=> array(0) { } ["[virtual]"]=> array(0) { } ["[hasErrors]"]=> bool(false) ["[errors]"]=> array(0) { } ["[invalid]"]=> array(0) { } ["[repository]"]=> string(5) "Users" }

php

1//UserController.php 2<?php 3namespace App\Controller; 4 5use Cake\Auth\DefaultPasswordHasher; 6use Cake\Event\Event; 7 8class UsersController extends AppController 9{ 10 public $paginate = [ 11 'limit' => 5, 12 'soft' => 'id', 13 'direction' => 'asc' 14 ]; 15 16 public function login() 17 { 18 if($this->request->is('post')) { 19 $user = $this->Auth->identify(); 20 if(!empty($user)) { 21 $this->Auth->setUser($user); 22 return $this->redirect($this->Auth->redirectUrl()); 23 } 24 $this->Flash->error('ユーザー名かパスワードが間違っています。'); 25 } 26 } 27 28 public function logout() 29 { 30 $this->request->session()->destroy(); 31 return $this->redirect($this->Auth->logout()); 32 } 33 34 public function beforeFilter(Event $event) 35 { 36 parent::beforeFilter($event); 37 $this->Auth->allow(['login', 'add', 'index']); 38 } 39 40 41 public function index() 42 { 43 $users = $this->paginate($this->Users); 44 // $users = $this->Users->find('all'); 45 46 $this->set(compact('users')); 47 } 48 49 public function add() { 50 $user = $this->Users->newEntity(); 51 if($this->request->is('post')){ 52 $user = $this->Users->patchEntity($user, $this->request->data); 53 if ($this->Users->save($user)) { 54 $this->Flash->success('Add success!'); 55 return $this->redirect(['action'=>'index']); 56 } else { 57 $this->Flash->error('Add error!'); 58 } 59 } 60 $this->set(compact('user')); 61 } 62}

php

1//User.php 2<?php 3namespace App\Model\Table; 4 5use Cake\ORM\Table; 6use Cake\Validation\Validator; 7 8class UsersTable extends Table 9{ 10 public function initialize(array $config) 11 { 12 $this->addBehavior('Timestamp'); 13 } 14 15 public function validationDefault(Validator $validator) 16 { 17 $validator 18 ->notEmpty('username') 19 ->requirePresence('username') 20 ->notEmpty('password') 21 ->requirePresence('password') 22 ->notEmpty('gender') 23 ->requirePresence('gender'); 24 return $validator; 25 } 26} 27

php

1//add.ctp 2<h1>ユーザー登録</h1> 3 <?= $this->Form->create($user); ?> 4 <?= $this->Form->control('username'); ?> 5 <?= $this->Form->control('password'); ?> 6 <?= $this->Form->radio('gender', [ 7 ['value'=>'男性', 'text'=>'男性'], 8 ['value'=>'女性', 'text'=>'女性'], 9 ['value'=>'etc', 'text'=>'etc'] 10 ]); ?> 11 <?= $this->Form->submit('送信'); ?> 12 <?= $this->Form->end(); ?>

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

m.ts10806

2019/08/30 07:04

テーブル定義はどうなっていますか?質問本文に追記してください(できればCREATE TABLE文で)
tunnel

2019/08/30 07:32

追記致しました。よろしくお願いいたします。
退会済みユーザー

退会済みユーザー

2019/08/30 07:34

データベースでの言語エンコーディングがlatin1だったりして
m.ts10806

2019/08/30 07:51

$_POSTではなく$this->request->dataを確認するとどうなってますか? (フレームワークは通常、直接スーパーグローバル変数を見ることはないはずです)
m.ts10806

2019/08/30 07:52

ただNotNullなのに「保存できない」という意味が分かりません。 空文字が入ったということでしょうか。
m.ts10806

2019/08/30 08:01

NotNullでDefault Nullなのも設計としては不整合起きてますね
tunnel

2019/08/30 08:06

テーブルのデータを確認すると他のカラムは保存されているのですがgenderカラムだけ空白の状態です。
m.ts10806

2019/08/30 08:18

requestにgender入ってないようですね。原因はそこですね。 ただvalidatorでnotEmptyとかrequirePresenceとか入れてますけどそこには引っかかってないんですか?
tunnel

2019/08/30 08:24

確かになんででしょうか。。引っかからずエラーメッセージも出ず他のデータだけでsaveに成功してしまってますね
FKM

2019/08/30 08:25

女性をfemale、あるいはjoseiなどと1バイト文字だけにしても値を受け取らないかどうか確認してみてください。バリデーションチェックで2バイト文字を弾いたりしていないですか?
m.ts10806

2019/08/30 08:26

ちなみに、ですが、ブラウザに出力されたHTMLどうなってます?
tunnel

2019/08/30 08:40

1bit文字にしてみましたが受け取れませんでした。 $user->genderでHtmlを出力すると何にもなりません。空文字分のスペースが空くわけでもなく、null?です
m.ts10806

2019/08/30 08:42

いえ違います。formの方です。 質問本文に追記してください。
tunnel

2019/08/30 08:51

3つめに貼り付けたadd.ctpじゃなくてですか?
FKM

2019/08/30 08:53

$user = $this->Users->patchEntity($user, $this->request->data); この前後でvar_dump($this->request->data)としたらどうなりますか?
tunnel

2019/08/30 08:57

本文の最後に追加いたしました。
nojimage

2019/08/30 10:09

src/Model/Entity/User.php を提示してください。 $_accessible はどうなっていますか?
tunnel

2019/08/31 03:44

$_accessibleのgenderが抜けていて追加したらgenderも保存できるようになりました。 ありがとうございます!
guest

回答1

0

自己解決

$_accessibleのgenderが抜けていて追加したらgenderも保存できるようになりました。

投稿2019/08/31 03:45

tunnel

総合スコア30

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問