yii 用户管理 controller

<pre name="code" class="php">namespace app\modules\admin\controllers;
use yii\web\Controller;

class BaseController extends Controller{
    
    
    public function url(){
        return \Yii::$app->urlManager;
    }

}


 
<?php

/* 
 * To change this license header, choose License Headers in Project Properties.
 * To change this template file, choose Tools | Templates
 * and open the template in the editor.
 */
namespace app\modules\admin\controllers;
use yii\web\Controller;
use yii\web\Request;
use app\models\User;
use yii\data\Pagination;
use app\models\Role;

class UserController extends BaseController{
    
    public $enableCsrfValidation = true;
    public $defaultAction="";
    public  $request= null;
    
    public function init(){
        $this->request= \Yii::$app->request;
    }

    /**
     * 用户列表
     */
    public function actionList(){
        
         $userModel=new User();
         $query=$userModel->find()->where(array());
         $countQuery=  clone $query;
         $pages=new Pagination(array('totalCount'=>$countQuery->count()));
         $pages->defaultPageSize=5;
         $result=$query->offset($pages->offset)->limit($pages->limit)->all();
         
         $roleModel=new Role();
         $role=$roleModel->find()->all();
            
         return $this->renderPartial("list",array('model'=>$result,'pages'=>$pages,"roles"=>$role));
    }
    
    /**
     * 添加用户
     */
    public function actionAdd(){
        if( $this->request->getIsPost()){
            $post=$this->request->post();
            unset($post['_csrf']);
            $userModel=new User();
            if($userModel->checkRepeat($post)){
                exit("不能添加重复记录");
            }
            $userModel->scenario="add"; 
            $userModel->attributes=$post;
            if( $userModel->insert() ){
                return $this->redirect($this->url()->createUrl("admin/user/list"));
            }     
            return $this->redirect($this->url()->createUrl("admin/user/add"));
        }else{
            $roleModel=new Role();
            $role=$roleModel->find()->all();
            return $this->renderPartial("add",array("roles"=>$role));
        }
    }
    
    /**
     * 更新用户
     */
    public function actionUpdate(){
        $userModel=new User();
        if( $this->request->getIsPost()){
            $post=$this->request->post();
            if($post['password']==""){
                unset($post['password']);
            }
            unset($post['_csrf']);
            $connection= \Yii::$app->db;
            //生成键值对
            $str="";
            $uid=$post['user_id'];
            unset($post['user_id']);
            if(!empty($post)){
                foreach ($post as $k=>$v){
                    if($v!=""){
                        $str.="`".$k."`='".$v."',";
                    }
                }
                $str=  rtrim($str,",");
                $sql="UPDATE `tb_user` SET  $str  WHERE `user_id`=:uid";
                $update=$connection->createCommand($sql);
                $result=$update->bindValue(':uid',$uid)->execute();
                if( $result ){
                    return $this->redirect($this->url()->createUrl("admin/user/list"));
                }
            }
           
            return $this->redirect($this->url()->createUrl(array("admin/user/update",'uid'=>$post['user_id'])));
        }else{
            $roleModel=new Role();
            $role=$roleModel->find()->all();
            $uid=  $this->request->get("uid");
            $result=$userModel->findOne($uid);
            return $this->renderPartial("update",array('model'=>$result,"roles"=>$role));
        }
    }
    
    /**
     * 删除用户
     */
    public function actionDelete(){
        $uid=  $this->request->get("uid");
        if(empty($uid)){
            return false;
        }
        $userModel=new User();
        $newModel=$userModel->findOne($uid);
        $newModel->scenario='delete';
        if($newModel->delete()){
             return $this->redirect($this->url()->createUrl("admin/user/list"));
        }
         return "删除失败";
    }
    
    /**
     * 查看详情
     */
    public function actionDetial(){
        $uid=  $this->request->get("uid");
        if(empty($uid)){
            return false;
        }
       
        $userModel=new User();
        $newModel=$userModel->findOne($uid);
        $roleModel=new Role();
        $role=$roleModel->find()->where("role_id=".$newModel->role_id)->one();
        $newModel->role_id=$role->role_name;
        return $this->renderPartial("detial", array("model"=>$newModel));
    }
    
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值