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

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

ただいまの
回答率

90.60%

  • PHP

    19858questions

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

  • FuelPHP

    517questions

    FuelPHPは、軽量高速で開発が可能なPHPのWebアプリケーションフレームワークです。

  • MVC

    218questions

    MVC(Model View Controller)は、オブジェクト指向プログラミングにおけるモデル・ビュー・コントローラーの総称であり、ソフトフェア開発で使われている構築パターンとしても呼ばれます。

MVCの使い方、使い分けについて

解決済

回答 2

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 1,454

tampopopofu

score 9

WebサイトでのMVCの使い方、使い分けについて教えてください。

メールアドレスとパスワードでの新規登録を例とさせてください。

[やりたいこと]
 ・入力チェック
 ・メールアドレスの重複チェック

この処理を行う場合、下記の案1と案2のどちらの使い方がいいか迷っています。

■案1
・コントローラからモデルを呼び出す。
・モデル内で入力チェック、重複チェックを行い、結果をコントローラに返す。
・コントローラからその結果を判定し、NGの場合エラーページに遷移する。

■案2
・コントローラからモデルの入力チェックを呼び出す。
・コントローラからモデルの重複チェックを呼び出す。
・コントローラからその都度、結果を判定し、NGの場合エラーページに遷移する。

どちらも正解はなくて好きなほうを使えばいいのか、案1、案2のどちらかのほうが
これこれこういう場合にいいとかなのか、もしくはそれ以外の方法がいいのか分かりません。

ご指導の程、よろしくお願いします。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 2

checkベストアンサー

0

なるほど、そうなんですね。

「重複チェック」を「メールの送信」に置き換えても同じ考えでしょうか。

私であれば、その場合、モデルでのメール送信を行いません。
1 入力チェック
2 メール送信
という順番に、コントローラー側で呼び出します。

メール送信は、他の処理でも利用することがあると思うので、
共通化(コンポーネント化)させたいからです。

例えば、CakePHPなどでは、Componentクラスを継承して
コントローラーの共通化を行います。


それぞれに呼ぶ方法だと、俗に言う「コントローラの肥大」に
なってしまうのかと思っています。

私の場合は、コントローラが肥大化してきたときは、
共通化させる必要がなくても、整理させるために、
そのビジネスロジックだけを集めたクラスを用意することもあります。

MVCB(注意:私の適当な造語です。一般的ではありません)というような構成になると思います。
(Bは、コントローラの細かい処理を担うビジネスロジックという意味です)

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2015/05/05 18:16

    再び、ありがとうございます。

    >私であれば、その場合、モデルでのメール送信を行いません。
    >1 入力チェック
    >2 メール送信
    >という順番に、コントローラー側で呼び出します。
    ということは、案2のほうが近い感じですね。

    まだまだこれから悩むかもしれませんが、今回は

    コントローラ ⇒ モデル.処理A
    コントローラ ⇒ モデル.処理B
    コントローラ ⇒ モデル.処理C
    ・・・

    と、まとまった単位の処理ごとにコントローラからモデルを呼ぶ方法にします。

    これでなんとか先に進むことができそうです。
    分かりやすく丁寧なご回答ありがとうございました。

    キャンセル

  • 2015/05/05 19:18

    >ということは、案2のほうが近い感じですね。
    はい、その通りです。
    結果、案2のほうが近いです。

    お役に立てたようで嬉しいです。
    ありがとうございました。

    キャンセル

0

こんにちは。
私は、次の3点から、「案1」が最適解だと思います。

(1)
さまざまなMVCの概念を取り入れた
フレームワーク(PHPであれば、CakePHPやFuelPHPなど)の方針では、
モデルに複数のバリデーションルールを適用するようになっている。
(巨人の肩に乗る作戦です)

(2)
・未入力チェック
・フォーマットチェック
・重複チェック
などの処理をまとめて、
・入力チェック(validate)
と抽象化することで、
インターフェース(呼び出すメソッド)を共通化できる。

(3)
モデルが検証処理を担ったほうが
テストのカバレッジ率の高いユニットテストを作成しやすい。
(細かい話で、すみません)

備考:
もちろん、おっしゃる通り、物事に正解はないので、
状況によっては、「案2」を採用するかもしれません。

例としては、ちょっと苦しいかもしれませんけど、
次のようばケースですかね。

重複チェックするためには、データベースへのアクセスが発生する。
だから、入力チェックでNGの場合は、さっさと処理を終わらせて、
データベースの負担を軽させよう。

と考えるかもしれません。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2015/05/05 16:48

    ご回答ありがとうございます。
    大変分かりやすく勉強になります。

    申し訳ございませんが、追加でお聞きしたいことがございます。
    「重複チェック」を「メールの送信」に置き換えても同じ考えでしょうか。

    例題としました「新規登録」という処理の中で、
    入力チェック(validate) 、メール送信
    で一連の処理が完了するとします。

    この場合でも、コントローラから新規登録モデルを呼び出し、そのモデル内で
    入力チェック(validate) 、メール送信
    を行う、ほうが最適でしょうか。

    コントローラから入力チェック(validate) 、メール送信と
    それぞれに呼ぶ方法だと、俗に言う「コントローラの肥大」に
    なってしまうのかと思っています。

    しかし、コントローラは主処理をせず、モデルの操作を行う、という概念からすると
    こちらの方法でも合っているのかなと思ってしまいます。

    悩みます・・・。

    キャンセル

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

  • ただいまの回答率 90.60%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

  • 受付中

    play framework 1.2.7 におけるmodelについて

    現在、ECサイトを作成しています。 上記のフレームワークのバージョンにおける モデルの作り方、考え方が分かりません どなたか説明頂けませんでしょうか?

  • 受付中

    CakePHPでのコントローラの分け方

    CakePHPでアプリケーションを作成するとき、全体として統一されたインタフェースや連続した遷移があるのにモデルが異なるものを扱うとき、皆様はコントローラ(およびビュー)の分け方を

  • 受付中

    モデルとマネージャーについて

    質問を見ていいただきありがとうございます! 最近MVCを意識してコードを書くようになりました。 カスタムビューを使ったりすることが出来るようになり、ViewとController

  • 解決済

    MVCとは?

    フレームワークについて勉強しているのですが、MVCとはどのようなものですか?

  • 解決済

    GUIアプリ開発でクラス間のデータ共有方法について

    wxWidgetsを使って、GUIアプリケーションを開発しています。フレーム内に複数のウィンドウを作成し、それぞれのウィンドウ内でopenglを使って描画を行うということをしていま

  • 解決済

    MVC外でデータベース操作するには

    Railsを使ってMVC外でデータベース操作するにはどうすればよいのでしょうか 例えばコンソール上で pry(main)> Post.create(name:"佐藤") と入

  • 受付中

    Railsを使ったブログ開発で、カテゴリー機能を実装したい

    質問 Railsを使って基本的なブログ機能を実装しているのですが、カテゴリー機能がうまくいきません。 カテゴリーをつけてブログ記事を新規作成しようとするとエラーが出てDBへ保存され

  • 解決済

    MVCが理解できません

     以下のページを読みました https://qiita.com/shinkuFencer/items/f2651073fb71416b6cd7 MVCのユーザアクション M

同じタグがついた質問を見る

  • PHP

    19858questions

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

  • FuelPHP

    517questions

    FuelPHPは、軽量高速で開発が可能なPHPのWebアプリケーションフレームワークです。

  • MVC

    218questions

    MVC(Model View Controller)は、オブジェクト指向プログラミングにおけるモデル・ビュー・コントローラーの総称であり、ソフトフェア開発で使われている構築パターンとしても呼ばれます。