Yii 前后台分离 demo

简介:

1.首先我把目录结构写下来:

    wwwroot/

        htdocs  //webroot目录,方便资源文件,和程序文件做Linux权限控制

             index.php
             admin.php 
             assets/
             images/
        protected/
            config/
                main.php
            components/
            controllers/
            models/
            views/
            runtime/

       admin /
            config/
                main.php
            components/
            controllers/
            views/
           runtime/

1.新建admin的目录结构,注意后台必须保留main.php defaultController中的controller文件和defaultAction对应的view文件 ,如siteController.php view/site/index.php

 

2.前后台引导文件分别如下,复制index.php改名为admin.php并修改
Yii::app()->createWebApplication('protected/admin/config/main.php')->run();

 

3.protected/admin/config/main.php的代码如下:

Java代码   收藏代码
  1. <?php  
  2. $backend = dirname(dirname(__FILE__));  
  3. $frontend = dirname($backend);  
  4. Yii::setPathOfAlias('backend',$backend);  
  5.   
  6. $frontendArray = require_once($frontend.'/config/main.php');  
  7.   
  8. $backendArray=array(  
  9.     'name'=>'网站后台管理系统',  
  10.     'basePath'=>$frontend,  
  11.     'viewPath'=>$backend.'/views',  
  12.     'controllerPath'=>$backend.'/controllers',  
  13.     'runtimePath'=>$backend.'/runtime',  
  14.     'import'=>array(   
  15.         'application.models.*',  
  16.         'application.components.*',  
  17.         'backend.models.*',  
  18.         'backend.components.*',  
  19.     ),  
  20.     //'params'=>CMap::mergeArray(require($frontend.'/config/params.php'),require($backend.'/config/params.php')),  
  21. );  
  22. if(isset($frontendArray['components']['user']))unset($frontendArray['components']['user'])  
  23. return CMap::mergeArray($frontendArray,$backendArray);   

这里我们的model是公用的 ,controller和view,runtime是分开的,我们还可以通过命令行对后台进行model和crud,方法如下:

Java代码   收藏代码
  1. >yiic shell path/to/site/admin.php  
  2. >model Article  
  3. >crud Article  

这样后台对应的controller和view就生成了!
如果只对后台的变量进行配置的话,只需要修改protected/admin下的配置文件就可以了!

后台配置文件与前台配置文件进行数组合并,没有的项自动包含,相同项则将其覆盖 ,例如后台中可使用 'name'=>'网站后台管理系统'仍为自己,是将前台覆盖的结果

 

前后台分离:前台入口index.php,后台是admin.php。后台可以重用前台,module那个更像是子项目,这个前后台两个像并行的.访问www.test.com/admin.php检测后台配置文件是否正确

 

Yii中处理前后台登录

如果有前台会员登陆和后台管理员登陆分离的需求,则需要为前台和后台的登陆定制两套不同的验证机制,主要是通过定义不同的Session来实现。要解决这个问题就要将前后台使用不同的Cwebuser实例登录。这样就已经做到了前后台登录分离开了,但是此时你退出的话你就会发现前后台一起退出了。于是我找到了logout()这个方法,发现他有一个参数$destroySession=true,原来如此,如果你只是logout()的话那就会将session全部注销,加一个false参数的话就只会注销当前登录实例的session了

Java代码   收藏代码
  1. Yii::app()->user->logout(false);  

main.php

前台user(Cwebuser)的配置: UserIdentity

Java代码   收藏代码
  1. 'user'=>array(  
  2.     'class'=>'WebUser',//这个WebUser是继承CwebUser,稍后给出它的代码  
  3.     'stateKeyPrefix'=>'member',//这个是设置前台session的前缀  
  4.     'allowAutoLogin'=>true,//这里设置允许cookie保存登录信息,一边下次自动登录  
  5. ),  

后台user(Cwebuser)的配置: AdminIdentity

Java代码   收藏代码
  1. 'admin' => array(  
  2.     'class' => 'AdminWebUser'//后台登录类实例  
  3.     'stateKeyPrefix' => 'admin'//后台session前缀  
  4.     "guestName" => "游客"  
  5. ),  
Yii::app()->user//前台访问用户信息方法
Yii::app()->admin//后台访问用户信息方法
Java代码   收藏代码
  1. Yii::app()->admin->login($this->_identity,$duration);  

http://hudeyong926.iteye.com/blog/1338494

相关文章
|
11月前
|
前端开发 API 开发者
Javaweb之前后台分离开发介绍的详细解析
2.1 前后台分离开发介绍 在之前的课程中,我们介绍过,前端开发有2种方式:前后台混合开发和前后台分离开发。 前后台混合开发,顾名思义就是前台后台代码混在一起开发,如下图所示:
131 0
|
中间件
83 # 静态服务中间件 koa-static 的使用以及实现
83 # 静态服务中间件 koa-static 的使用以及实现
84 0
|
NoSQL JavaScript 前端开发
【Node.js实战】一文带你开发博客项目之Koa2重构(实现session、开发路由、联调、日志)
【Node.js实战】一文带你开发博客项目之Koa2重构(实现session、开发路由、联调、日志)
270 0
|
存储 中间件 数据库
Egg.js中间件进行登录鉴权的核心思路
Egg.js中间件进行登录鉴权的核心思路
775 9
Egg.js中间件进行登录鉴权的核心思路
|
缓存 安全 JavaScript
Yii2.0的视图渲染机制是怎样的?底层原理是什么?
Yii2.0的视图渲染机制是怎样的?底层原理是什么?
106 0
|
PHP 开发工具 数据库
Yii2 修改框架入口增加配置适应开发生产环境
Yii2 修改框架入口增加配置适应开发生产环境
154 0
Yii2 修改框架入口增加配置适应开发生产环境
Yii2如何实现自动加载?底层原理是什么?
Yii2如何实现自动加载?底层原理是什么?
199 0
|
前端开发
前端hook项目pc总结笔记-文件上传单独封装axios
前端hook项目pc总结笔记-文件上传单独封装axios
147 0
|
前端开发 JavaScript 网络架构
微服务项目:尚融宝(26)(后端搭建:Nuxt.js入门)
微服务项目:尚融宝(26)(后端搭建:Nuxt.js入门)
微服务项目:尚融宝(26)(后端搭建:Nuxt.js入门)
|
数据可视化 IDE Java
Flutter框架在项目中使用App Manifest检查用户界面以及配置混乱之后对于构建配置的方案【Flutter】
Flutter框架在项目中使用App Manifest检查用户界面以及配置混乱之后对于构建配置的方案【Flutter】