ホームページ >バックエンド開発 >PHPチュートリアル >PHP ソースコード差別化プラットフォーム MVC 構造の紹介

PHP ソースコード差別化プラットフォーム MVC 構造の紹介

不言
不言オリジナル
2018-07-04 16:24:252221ブラウズ

この記事では、主に PHP ソース コード差別化プラットフォームの MVC 構造を紹介します。これには特定の参考値があります。今、あなたと共有します。必要な友人はそれを参照できます。

メイン:

  1. モデル シングルトン ファクトリ

  2. ディレクトリ構造の最適化

  3. プラットフォームの区別 (フロントエンド、バックエンド...) )

--------------:--------------------------------------
blog
├─App
│  ├─Model 模型
│  │  └─UserModel.class.php 用户模型类    
│  ├─View 视图
│  │  ├─Back后台
│  │  │  └─Index
│  │  │          └─index.html  后台首页面
│  │  └─Home前台
│  │      └─User 用户视图目录
│  │             └─login.html  登录表单页面
│  ├─Controller 控制器
│  │  ├─Back后台
│  │  │  └─IndexController.class.php 后台首页控制器
│  │  └─Home前台
│  │      └─UserController.class.php 用户控制器
├─Public   静态公共文件(js,css,images)
│  ├─Plugins 插件
│  │  └─layui 前端框架插件
│  ├─Back后台
│  │    ├─js/   js文件
│  │    ├─css/  css样式文件
│  │    └─image img图片 
│  └─Home前台
│      ├─js/   js文件
│      ├─css/  css样式文件
│      └─image img图片 
├─Frame 公共使用的类
│   ├─BaseModel.class.php 数据库连接类
│   ├─BaseController.class.php 控制器公共操作(设置编码,信息跳转)
│   ├─FactoryModel.class.php  模型工厂类
│   └─MySQLDB.class.php 数据库操作工具类
└─index.php  入口文件
----------------------------------------------------------------

このプロジェクトのソース コードをダウンロードして表示します: https://gitee.com/NewbiesYang/young_blog

Model Singleton Factory

準備:ブランチの作成

1 $ git checkout master
2 $ git checkout -b "folder-model-app"

手順:

1)プログラムは3行です。 。 。省略されたコードを示します。

は前から見ることも、ソースコードから見ることもできます。 2) [XXX/XXX] はプロジェクトファイルの相対パスを示します

アイデア:

問題: プロジェクト内のモデル データ テーブルを操作するには、1 つのアクションでデータベースを 1 回操作し、一度に複数のアクションを要求する必要がある場合があります。各アクションは対応するモデルをインスタンス化する必要があります。

解決策のアイデア: モデルを作成するclass singleton Factory
実装: シングルトン モデルの作成 class FactoryModel.class.php
属性 $model=array(); モデル クラスのインスタンスの格納
メソッド: M($cmodelName, array $conf=null) インスタンス化モデル クラス
使用: コントローラーでモデル クラス インスタンスを使用します: $model=FactoryModel::M('モデル名')

コード実装

1 ) モデルのシングルトン ファクトリを作成します【 Frame/FactoryModel.class.php】

 1 <?php 
 2 /** 
 3  * 单例模型工厂类 
 4  * User: young 
 5  */ 
 6  
 7 class FactoryModel 
 8 { 
 9     protected static $model = array(); //存储模型类实例
 10 
 11     /**
 12      * 构造方法
 13      */
 14     protected function  __construct()
 15     {
 16     }
 17 
 18     /*
 19      * 传递一个模型类的类名,就返回该类的一个单例实例对象
 20     *@param string $modelName  模型类的类名
 21     *@param array  $conf  数据库配置信息
 22     *@return object 传入模型类的实例(单例)
 23     */
 24     public static function M($modelName, array $conf=null)
 25     {
 26         $modelName = $modelName.&#39;Model&#39;;
 27         if(empty(static::$model[$modelName]) || !(static::$model[$modelName] instanceof $modelName)){
 28             static::$model[$modelName] = new $modelName($conf);
 29         }
 30         return static::$model[$modelName];
 31     }
 32 }

2) クラス ファイルを導入します【index.php】

 1 <?php 
 2 /** 
 3  * 入口文件 
 4  */ 
 5 require_once &#39;Frame/Db.class.php&#39;;  //数据库操作类 
 6 require_once &#39;Frame/BaseModel.class.php&#39;;  //基础模型类 
 7 require_once(&#39;Model/UserModel.class.php&#39;); 
 8  
 9 require_once &#39;Frame/FactoryModel.class.php&#39;;//模型工厂类
 10 。。。
 11 。。。
 12 。。。

エントリ ファイルにファクトリ モデル クラスを導入します

3) アプリケーション: ユーザー コントローラーでのログイン操作など、コントローラーで使用されます。 UserController [Controller/UserController.class.php]

 1  <?php 
 2 /** 
 3  * UserController.class.php 用户控制器 
 4  */ 
 5  
 6 class UserController  extends  BaseController{ 
 7     。。。 
 8     。。。 
 9     。。。
 10 
 11     /**
 12      * 登录操作: 校验登录信息
 13      */
 14     public function dlogin()
 15     {
 16         //接收登录信息17         $data = array();
 18         $data[&#39;username&#39;] = trim($_POST[&#39;username&#39;]);
 19         $data[&#39;pwd&#39;] = trim($_POST[&#39;pwd&#39;]);
 20 
 21         //实例化模型,调用模型方法
 22         //$model = new UserModel();
 23         //$result = $model->checkLoginInfo($data);
 24         //替换上面两行
 25         $result = FactoryModel::M(&#39;User&#39;)->checkLoginInfo($data);
 26 
 27         //跳转提示
 28         if($result){
 29             $this->msg(&#39;登录成功!&#39;, &#39;?a=index&#39;,3);
 30         } else {
 31             $this->msg(&#39;用户名或密码不正确!!&#39;);
 32         }
 33     }
 34 }

4) テスト プログラムの実行中、http:/ /www.test.com/blog/index.php ログイン テストの結果は、以前の結果と一致しています。とりあえずコードを提出

1 git add -
2 git commit -m "完成模型工厂类"

ディレクトリ構造の最適化

アイデア

複数のプラットフォーム (モジュール): フロントとバック、バックエンド
MVC 構造サブプラットフォーム
C: コントローラー/ホーム コントローラー/管理者 .....
V: ビュー/ホーム ビュー/管理者 .....
M: 操作データ テーブル 一般モジュール 共通パブリック リソースディレクトリ Public Public Public Public Public Public Public Public Public Public Public Public Public Public Public Public Public Public Public Public Public そのパブリックリソースディレクトリ Public Public Public : Public/Home Public/Admin .....
ディレクトリ構造が変更されます。 、ロードされたすべてのクラスとビューのパスもそれに応じて変更されます。

コード実装

1) 操作ステップ

1)目录构建: 
step 1: 根目录下创建目录App, 将Model目录,View目录,Controller目录放大App目录下
	既根目录只有: App/ Public/ Frame/  index.php

step 2: 在Controller目录中,创建Back目录和Home目录。将UserController控制器类文件放入Home目录中

step 3: 在View目录中,创建Back目录和Home目录。将login.html文件放入Home目录中

step 4: 在Public目录中,创建Back目录,Home目录,Plugins目录。将js,images,css目录放入Home目录中,公共插件放入对应的Plugins目录中

2)文件引入修改:
step 5: index.php入口文件对UserCotroller类的引入路径修改

step 6:UserController类中对视图login.html的include路径的修改

step 7: 视图login.html中对css和js路径的引入

操作ステップのアイデア#2) 具体的なコード修正操作

## エントリファイル導入クラスパス修正[index.php] 主にユーザモデルクラスとユーザコントローラクラスパスの導入と修正です

 1 <?php 
 2 /** 
 3  * 入口文件 
 4  */ 
 5 require_once &#39;Frame/Db.class.php&#39;;  //数据库操作类 
 6 require_once &#39;Frame/BaseModel.class.php&#39;;  //基础模型类 
 7 require_once &#39;App/Model/UserModel.class.php&#39;; 
 8  
 9 require_once &#39;Frame/FactoryModel.class.php&#39;;//模型工厂类
 10 
 11 require_once &#39;Frame/BaseController.class.php&#39;;  //基础控制器类
 12 require_once &#39;App/Controller/Home/UserController.class.php&#39;;
 13 
 14 //实例化控制器
 15 $userCtr = new UserController();
 16 
 17 $a = !empty($_GET[&#39;a&#39;]) ? $_GET[&#39;a&#39;] : &#39;login&#39;;
 18 
 19 $userCtr -> $a();

入口ファイル導入クラスの修正

ユーザーコントローラクラスで導入したログインフォームビューパスの修正【 App/Controller/Home/UserController.class.php 】

 1 <?php 
 2 /** 
 3  * UserController.class.php 用户控制器 
 4  */ 
 5  
 6 class UserController  extends  BaseController{ 
 7     /** 
 8      * 展示登录界面 
 9      * @access public10      */
 11     public function login()
 12     {
 13         include "App/View/Home/User/login.html";
 14     }
 15 。。。
 16 。。。
 17 。。。

ユーザーコントローラー表示ログインインターフェース変更

ログインフォームビュー【App/View/Home/User/login.html】静的リソースパスの変更

 1 <!DOCTYPE html> 
 2 <html lang="zh-CN"> 
 3 <head> 
 4     <meta charset="UTF-8"> 
 5     <title>登录</title> 
 6     <link rel="stylesheet" type="text/css" href="public/plugins/layui/css/layui.css"> 
 7     <link rel="stylesheet" type="text/css" href="public/Home/css/style.css"> 
 8 </head> 
 9 。。。
 10 。。。
 11 。。。
 12 <script type="text/javascript" src="public/plugins/layui/layui.js"></script>
 13 <script>
 14     layui.use(&#39;form&#39;, function(){
 15         var form = layui.form;
 16     });
 17 </script>
 18 </body>
 19 </html>

ログイン フォーム ビュー

エフェクトと送信コード

コードを送信して保存

1 git add -A
2 git commit -m "目录结构优化"

差別化プラットフォーム (フロントデスク、バックエンド...)

アイデア

さまざまなプラットフォームに応じてさまざまな操作を実装します

ユーザーはページ リクエストをクリックし、 URL とともに 3 つのパラメータを送信します: p=Platform&c=Controller&a=Action

エントリ ファイルで get データを受信することでわかります: Platform、Controller、Action


コード実装

1) 操作手順:
1)入口文件平台区分:
    step 1:  入口-登录页面提交的action="?p=Home&c=User&a=dlogin"

    step 2:  入口文件index.php  接收$_GET

    step 3:  登录判断成功跳转地址: $this->msg(&#39;登录成功!&#39;, &#39;?p=Admin&c=Index&a=index&#39;,3);
	
2) 后台首页:
     step 1:   静态css,js,img文件放置 Public/Admin/

     step 2:   创建后台首页控制器类,
			index() 载入后台首页视图文件

     step 3:  View/Admin/Index/index.html 修正css等静态文件路

操作手順のアイデア

2) ログイン フォーム送信アクション ="?p=Home&c=User&a=dlogin" [App/View/Home/User/login.html]

 1 <!DOCTYPE html> 
 2 <html lang="zh-CN"> 
 3 <head> 
 4     <meta charset="UTF-8"> 
 5     <title>登录</title> 
 6     <link rel="stylesheet" type="text/css" href="public/plugins/layui/css/layui.css">
 7     <link rel="stylesheet" type="text/css" href="public/Home/css/style.css"> 
 8 </head> 
 9 <body>
 10 <p class="container">
 11     <p class="content">
 12         <form action="?p=Home&c=User&a=dlogin" class="layui-form" method="post">
 13 。。。。。。。

ログイン フォーム フォーム送信アクションの変更

3 ) エントリ ファイルはプラットフォームを識別します [index.php]

<?php
/**
 * 入口文件 
 */
 $p = !empty($_GET[&#39;p&#39;]) ? $_GET[&#39;p&#39;] : &#39;Home&#39;;  //平台
 $c = !empty($_GET[&#39;c&#39;]) ? $_GET[&#39;c&#39;] : &#39;User&#39;;  //控制器
 $a = !empty($_GET[&#39;a&#39;]) ? $_GET[&#39;a&#39;] : &#39;login&#39;; //动作
 require_once &#39;Frame/Db.class.php&#39;;  //数据库操作类
 require_once &#39;Frame/BaseModel.class.php&#39;;  //基础模型类
 require_once &#39;App/Model/UserModel.class.php&#39;;
 require_once &#39;Frame/FactoryModel.class.php&#39;;//模型工厂类
 require_once &#39;Frame/BaseController.class.php&#39;;  //基础控制器类
 require_once &#39;App/Controller/&#39;.$p.&#39;/&#39;.$c.&#39;Controller.class.php&#39;;
 $ctr = $c."Controller";//实例化控制器
 $userCtr = new $ctr();$userCtr -> $a();

ユーザー コントローラーのログイン操作、ログインが成功するとバックグラウンドのホームページにジャンプします [App/Controller/Home/UserController.class.php]

 1 <?php 
 2 /** 
 3  * UserController.class.php 用户控制器 
 4  */ 
 5  
 6 class UserController  extends  BaseController{ 
 7 。。。 
 8 。。。 
 9 。。。
 10  /**
 11      * 登录操作: 校验登录信息
 12      */
 13     public function dlogin()
 14     {
 15         //接收登录信息
 16         $data = array();
 17         $data[&#39;username&#39;] = trim($_POST[&#39;username&#39;]);18         $data[&#39;pwd&#39;] = trim($_POST[&#39;pwd&#39;]);
 19 
 20         //实例化模型,调用模型方法
 21         $result = FactoryModel::M(&#39;User&#39;)->checkLoginInfo($data);
 22 
 23         //跳转提示
 24         if($result){25             $this->msg(&#39;登录成功!&#39;, &#39;?p=Admin&c=Index&a=index&#39;,3);26         } else {
 27             $this->msg(&#39;用户名或密码不正确!!&#39;);
 28         }
 29     }
 30 }

ログイン操作が成功した後のジャンプ パスの変更

  测试

 1)模板准备: 

      准备后台视图模板程序。可以自己写前端视图模板程序,也可以到网上下载别人写好的前端模板,如到 模板之家  选择所需求的 前台,后台模板 

      寻找模板:  www.mycodes.net

   2) 将后台模板视图的静态资源文件(如 js, css,image)拷贝到 【Public/admin/】目录下

   3) 创建后台首页控制器 【App/Controller/Admin/IndexController.class.php】

 1 <?php 
 2 /** 
 3  * IndexController控制器类 
 4  * 后台相关操作 
 5  * User: young 
 6  */ 
 7  
 8 class IndexController extends BaseController 
 9 {
 10     //展示后台首页
 11     public function index()
 12     {
 13         include &#39;App/View/Admin/Index/index.html&#39;;
 14     }
 15 }

4) 创建后台首页视图 【App/View/Admin/Index/index.html】

  1 <!doctype html>  
  2 <html>  
  3 <head>  
  4     <meta charset="UTF-8">  
  5     <title>后台管理</title>  
  6     <link rel="stylesheet" type="text/css" href="./Public/Admin/css/common.css"/>  
  7     <link rel="stylesheet" type="text/css" href="./Public/Admin/css/main.css"/>  
  8     <script type="text/javascript" src="./Public/Admin/js/libs/modernizr.min.js"></script>  
  9     <script type="text/javascript" src="./Public//home/js/jquery1.42.min.js"></script> 
  10 </head> 
  11 <body> 
  12  
  13  
  14 <p class="topbar-wrap white"> 
  15     <p class="topbar-inner clearfix"> 
  16         <p class="topbar-logo-wrap clearfix"> 
  17             <h1 class="topbar-logo none"><a href="index.html" class="navbar-brand">后台管理</a></h1> 
  18             <ul class="navbar-list clearfix"> 
  19                 <li><a class="on" href="?p=back">首页</a></li> 
  20                 <li><a href="./" target="_blank">网站首页</a></li> 
  21             </ul> 
  22         </p> 
  23         <p class="top-info-wrap"> 
  24             <ul class="top-info-list clearfix"> 
  25                 <li><a href="">user1</a></li> 
  26                 <li><a href="?p=back&c=Index&a=ChangePswd">修改密码</a></li> 
  27                 <li><a href="?c=User&a=Logout">退出</a></li> 
  28             </ul> 
  29         </p> 
  30     </p> 
  31 </p> 
  32 <p class="container clearfix"> 
  33  
  34     <!--左侧菜单栏--> 
  35  
  36     <!--左侧菜单栏 begin--> 
  37     <p class="sidebar-wrap"> 
  38         <p class="sidebar-title"> 
  39             <h1>菜单</h1> 
  40         </p> 
  41         <p class="sidebar-content"> 
  42             <ul class="sidebar-list"> 
  43                 <li> 
  44                     <a href="#"><i class="icon-font">&#xe003;</i>常用操作</a> 
  45                     <ul class="sub-menu"> 
  46                         <li><a href="#"><i class="icon-font">&#xe008;</i>分类管理</a></li> 
  47                         <li><a href="#"><i class="icon-font">&#xe005;</i>博文管理</a></li> 
  48                         <li><a href="#"><i class="icon-font">&#xe012;</i>评论管理</a></li> 
  49                         <li><a href="#"><i class="icon-font">&#xe052;</i>友情链接</a></li> 
  50                     </ul> 
  51                 </li> 
  52                 <li> 
  53                     <a href="#"><i class="icon-font">&#xe018;</i>系统管理</a> 
  54                     <ul class="sub-menu"> 
  55                         <li><a href="#"><i class="icon-font">&#xe017;</i>系统设置</a></li> 
  56                         <li><a href="#"><i class="icon-font">&#xe046;</i>数据备份</a></li> 
  57                         <li><a href="#"><i class="icon-font">&#xe045;</i>数据还原</a></li> 
  58                     </ul> 
  59                 </li> 
  60             </ul> 
  61         </p> 
  62     </p> 
  63     <!--左侧菜单栏 begin--> 
  64  
  65     <!--右侧主操作区--> 
  66     <p class="main-wrap"> 
  67         <p class="crumb-wrap"> 
  68             <p class="crumb-list"> 
  69                 <i class="icon-font">&#xe06b;</i> 
  70                 <span>欢迎使用博客后台管理系统。</span> 
  71             </p> 
  72         </p> 
  73         <p class="result-wrap"> 
  74             <p class="result-title"> 
  75                 <h1>系统基本信息</h1> 
  76             </p> 
  77             <p class="result-content"> 
  78                 <ul class="sys-info-list"> 
  79                     <li> 
  80                         <label class="res-lab">操作系统</label><span class="res-info">WINNT</span> 
  81                     </li> 
  82                     <li> 
  83                         <label class="res-lab">运行环境</label><span class="res-info">Apache/2.2.21 (Win64) PHP/5.3.10</span> 
  84                     </li> 
  85                     <li> 
  86                         <label class="res-lab">PHP运行方式</label><span class="res-info">apache2handler</span> 
  87                     </li> 
  88                     <li> 
  89                         <label class="res-lab">模板版本</label><span class="res-info">v-0.1</span> 
  90                     </li> 
  91                     <li> 
  92                         <label class="res-lab">上传附件限制</label><span class="res-info">2M</span> 
  93                     </li> 
  94                     <li> 
  95                         <label class="res-lab">北京时间</label> 
  96                         <span class="res-info" id=&#39;nowtime&#39;><?php echo date(&#39;Y年m月d日 H:i:s&#39;,time()); ?></span> 
  97                     </li> 
  98                     <li> 
  99                         <label class="res-lab">服务器域名</label><span class="res-info"><span id="host">localhost</span></span>
  100                     </li>
  101                 </ul>
  102             </p>
  103         </p>
  104     </p>
  105     <!--/main-->
  106     <script >
  107         $(function(){
  108             $("#nowtime").css({color:&#39;red&#39;});
  109             $("#host").html(location.host);
  110             window.setInterval(&#39;ShowTime()&#39;,1000);
  111         });
  112         function ShowTime(){
  113             var t = new Date();
  114             var str = t.getFullYear() + &#39;年&#39;;
  115             str += t.getMonth()+1 + &#39;月&#39;;
  116             str += t.getDate()-1 + &#39;日 &#39;;
  117             str += t.getHours() + &#39;:&#39;;
  118             str += t.getMinutes() + &#39;:&#39;;
  119             str += t.getSeconds() + &#39;&#39;;
  120             $("#nowtime").html(str);
  121         }
  122     </script>
  123 </p>
  124 
  125 </body>
  126 </html>

后台首页视图

  效果及提交代码

  代码提交,推送

1 $  git add -A
2 $  git commit -m "区分平台,实现后台首页"
3 $  git checkout master
4 $  git merge &#39;folder-model-app&#39;
5 $  git push origin master

小结: 根据平台进一步优化目录结构,制作模型的单例工厂,实现后台首页

提出问题

  1. 项目中可以看到 include或require的文件路径很长,容易出错,也不便于使用  ==> 如何更加简单引入且不易出错

     2. 写一个类,就要到入口文件引入一次, 比较麻烦  ==>  如何实现自动加载类

  3. 随着类的引入增加,入口文件代码量会越来越大  ==>  如何 封装,简化入口文件

  4. 现在项目中任何一个目录,都可以随意访问  ==> 如何加强安全访问,限制目录的访问

下一步:常量使用,自动加载类实现,入口封装,限制目录访问

以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

相关推荐:

php源码之搭建站点实现登录页面的方法

php源码之实现单入口MVC结构的方法

以上がPHP ソースコード差別化プラットフォーム MVC 構造の紹介の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。