getToken($cookie_token); if ($ret && $ret['token_expire'] > time() ) { D("UserToken")->setLastTime($cookie_token); $login_user = D("User")->where("uid = $ret[uid]")->find(); unset($ret['password']); session("login_user" , $login_user); return $login_user ; } } if ($redirect) { $this->sendError(10102); exit(); } }else{ return session("login_user") ; } } /** * 返回json结果 */ protected function sendResult($array){ if (isset($array['error_code'])) { $result['error_code'] = $array['error_code'] ; $result['error_message'] = $array['error_message'] ; } else{ $result['error_code'] = 0 ; $result['data'] = $array ; } //header('Access-Control-Allow-Origin: *');//允许跨域请求 echo json_encode($result); //如果开启API调试模式,则记录请求参数和返回结果 if (C('API_LOG')) { $info = ''; $info .= "\n\n【★★★★★★★★★★★】"; $info .= "\n请求接口:".MODULE_NAME ."/".CONTROLLER_NAME."/".ACTION_NAME.""; $info .= "\n请求".'$_REQUEST'.":\n"; $info .= json_encode($_REQUEST); $info .= "\n返回结果:\n"; $info .= json_encode($result)."\n"; $info .= "【★★★★★★★★★★★】\n"; \Think\log::record($info , 'INFO'); } } //返回错误提示 protected function sendError($error_code , $error_message = ''){ $error_code = $error_code ? $error_code : 10103 ; if (!$error_message) { $error_codes = C("error_codes"); foreach ($error_codes as $key => $value) { if ($key == $error_code ) { $error_message = $value ; } } } $array['error_code'] = $error_code; $array['error_message'] = $error_message ; $this->sendResult($array); } //判断某用户是否有项目管理权限(项目成员member_group_id为1,以及 项目创建者) protected function checkItemPermn($uid , $item_id){ if (!$uid) { return false; } if (session("mamage_item_".$item_id)) { return true; } $item = D("Item")->where("item_id = '%d' ",array($item_id))->find(); if ($item['uid'] && $item['uid'] == $uid) { session("mamage_item_".$item_id , 1 ); return true; } $ItemMember = D("ItemMember")->where("item_id = '%d' and uid = '%d' and member_group_id = 1 ",array($item_id,$uid))->find(); if ($ItemMember) { session("mamage_item_".$item_id , 1 ); return true; } return false; } //判断某用户是否为项目创建者 protected function checkItemCreator($uid , $item_id){ if (!$uid) { return false; } if (session("creat_item_".$item_id)) { return true; } $item = D("Item")->where("item_id = '%d' ",array($item_id))->find(); if ($item['uid'] && $item['uid'] == $uid) { session("creat_item_".$item_id , 1 ); return true; } return false; } //判断某用户是否有项目访问权限(公开项目的话所有人可访问,私有项目则项目成员、项目创建者和访问密码输入者可访问) protected function checkItemVisit($uid , $item_id, $refer_url= ''){ if (session("visit_item_".$item_id)) { return true; } if ($this->checkItemCreator($uid , $item_id)) { session("visit_item_".$item_id , 1 ); return true; } $ItemMember = D("ItemMember")->where("item_id = '%d' and uid = '%d' ",array($item_id,$uid))->find(); if ($ItemMember) { session("visit_item_".$item_id , 1 ); return true; } $item = D("Item")->where("item_id = '%d' ",array($item_id))->find(); if ($item['password']) { return false; }else{ session("visit_item_".$item_id , 1 ); return true; } } }