質問編集履歴

3 追記

ssk

ssk score 288

2017/01/22 23:46  投稿

CakePHPで画像を「データベース登録」&「編集」について
#####環境
・Apache     
・Mac OS Sierra     
・PHP Version 7.0.14   
・mysqlnd 5.0.12 
・CakePHP3
#####内容
画像のデータベース登録と編集方法について
以下の内容で意図した動作はしてくれているのですが
より、実戦的なプログラミングの記述を教えて欲しいです。
edit.php
```PHP
//データベースに値がある場合は表示、ない場合は非表示
if($hoges->カラム名 != ''){
    $DBimage = '<img src="'.$this->request->webroot.'/images/'.$hoges->カラム名.'" />';
}else{
    $DBimage = '';
}
           
echo $this->Form->input('カラム名', [
    'type' => 'file',
    'value' => $value,
    'templates' => [                         
                     'inputContainer' => '<tr><th>画像</th><td>'.$DBimage.'{{content}}</td></tr>',
                   ],
    'label' => false,
]);
```
HogesController.php
```PHP
//$img['error']が4の場合はデータベースと同じ画像名
$img = $this->request->data['カラム名'];
if($img['error'] === 4){
   $this->request->data['カラム名'] = $hoges->カラム名;
}else{
//画像が添付されている場合は画像を登録
   $ext = $img['name'];
   $time = time();
   $name = md5(uniqid(rand(), 1)).$time.'.'.$ext;
   move_uploaded_file($img['tmp_name'],'../webroot/images/'.$name);
   $this->request->data['カラム名'] = $name;
}
```
#####補足
```PHP
if($img['error'] === 4){
               $this->request->data['dbo59'] = $dbackorder->dbo59;
           }
```
で、画像を選択していない場合は
データベースにある値を入れています。
ただ、これでは
データベースの値と画像ファイルを削除することができません。
その他のプログラミングも含め
この点も助言していただけると助かります。
※バリデーション以外でお願いします。
※バリデーション以外の箇所でお願いします。
  • PHP

    36174 questions

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

  • MySQL

    11251 questions

    MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

  • CakePHP

    3123 questions

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

2 追記

ssk

ssk score 288

2017/01/22 23:46  投稿

CakePHPで画像を「データベース登録」&「編集」について
#####環境
・Apache     
・Mac OS Sierra     
・PHP Version 7.0.14   
・mysqlnd 5.0.12 
・CakePHP3
#####内容
画像のデータベース登録と編集方法について
以下の内容で意図した動作はしてくれているのですが
より、実戦的なプログラミングの記述を教えて欲しいです。
edit.php
```PHP
//データベースに値がある場合は表示、ない場合は非表示
if($hoges->カラム名 != ''){
    $DBimage = '<img src="'.$this->request->webroot.'/images/'.$hoges->カラム名.'" />';
}else{
    $DBimage = '';
}
           
echo $this->Form->input('カラム名', [
    'type' => 'file',
    'value' => $value,
    'templates' => [                         
                     'inputContainer' => '<tr><th>画像</th><td>'.$DBimage.'{{content}}</td></tr>',
                   ],
    'label' => false,
]);
```
HogesController.php
```PHP
//$img['error']が4の場合はデータベースと同じ画像名
$img = $this->request->data['カラム名'];
if($img['error'] === 4){
   $this->request->data['カラム名'] = $hoges->カラム名;
}else{
//画像が添付されている場合は画像を登録
   $ext = $img['name'];
   $time = time();
   $name = md5(uniqid(rand(), 1)).$time.'.'.$ext;
   move_uploaded_file($img['tmp_name'],'../webroot/images/'.$name);
   $this->request->data['カラム名'] = $name;
}
```
#####補足
```PHP
if($img['error'] === 4){
               $this->request->data['dbo59'] = $dbackorder->dbo59;
           }
```
で、画像を選択していない場合は
データベースにある値を入れています。
ただ、これでは
データベースの値と画像ファイルを削除することができません。
その他のプログラミングも含め
この点も助言していただけると助かります。
この点も助言していただけると助かります。
※バリデーション以外でお願いします。
  • PHP

    36174 questions

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

  • MySQL

    11251 questions

    MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

  • CakePHP

    3123 questions

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

1 編集

ssk

ssk score 288

2017/01/22 23:44  投稿

CakePHPで画像を「データベース登録」&「編集」について
#####環境
・Apache     
・Mac OS Sierra     
・PHP Version 7.0.14   
・mysqlnd 5.0.12 
・CakePHP3
#####内容
画像のデータベース登録と編集方法について
以下の内容で意図した動作はしてくれているのですが
より、実戦的なプログラミングの記述を教えて欲しいです。
edit.php
```PHP
//データベースに値がある場合は表示、ない場合は非表示
if($hoges->カラム名 != ''){
    $DBimage = '<img src="'.$this->request->webroot.'/images/'.$hoges->カラム名.'" />';
}else{
    $DBimage = '';
}
           
echo $this->Form->input('カラム名', [
    'type' => 'file',
    'value' => $value,
    'templates' => [                         
                     'inputContainer' => '<tr><th>画像</th><td>'.$DBimage.'{{content}}</td></tr>',
                   ],
    'label' => false,
]);
```
HogesController.php
```PHP
//$img['error']が4の場合はデータベースと同じ画像名
$img = $this->request->data['カラム名'];
if($img['error'] === 4){
   $this->request->data['カラム名'] = $hoges->カラム名;
}else{
//画像が添付されている場合は画像を登録
   $ext = $img['name'];
   $time = time();
   $name = md5(uniqid(rand(), 1)).$time.'.'.$ext;
   move_uploaded_file($img['tmp_name'],'../webroot/images/'.$name);
   $this->request->data['カラム名'] = $name;
}
```
```
#####補足
```PHP
if($img['error'] === 4){
               $this->request->data['dbo59'] = $dbackorder->dbo59;
           }
```
で、画像を選択していない場合は
データベースにある値を入れています。
ただ、これでは
データベースの値と画像ファイルを削除することができません。
その他のプログラミングも含め
この点も助言していただけると助かります。
  • PHP

    36174 questions

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

  • MySQL

    11251 questions

    MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

  • CakePHP

    3123 questions

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

思考するエンジニアのためのQ&Aサイト「teratail」について詳しく知る