You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
115 lines
3.8 KiB
115 lines
3.8 KiB
<?php
|
|
namespace Api\Model;
|
|
use Api\Model\BaseModel;
|
|
|
|
class UserModel extends BaseModel {
|
|
|
|
/**
|
|
* 用户名是否已经存在
|
|
*
|
|
*/
|
|
public function isExist($username){
|
|
return $this->where("username = '%s'",array($username))->find();
|
|
}
|
|
|
|
/**
|
|
* 注册新用户
|
|
*
|
|
*/
|
|
public function register($username,$password){
|
|
$password = md5(base64_encode(md5($password)).'576hbgh6');
|
|
return $this->add(array('username'=>$username ,'password'=>$password , 'reg_time'=>time()));
|
|
}
|
|
|
|
//修改用户密码
|
|
public function updatePwd($uid, $password){
|
|
$password = md5(base64_encode(md5($password)).'576hbgh6');
|
|
return $this->where("uid ='%d' ",array($uid))->save(array('password'=>$password));
|
|
}
|
|
|
|
/**
|
|
* 返回用户信息
|
|
* @return
|
|
*/
|
|
public function userInfo($uid){
|
|
return $this->where("uid = '%d'",array($uid))->find();
|
|
}
|
|
|
|
/**
|
|
*@param username:登录名
|
|
*@param password 登录密码
|
|
*/
|
|
|
|
public function checkLogin($username,$password){
|
|
$password = md5(base64_encode(md5($password)).'576hbgh6');
|
|
$where=array($username,$password,$username,$password);
|
|
return $this->where("( username='%s' and password='%s' ) ",$where)->find();
|
|
}
|
|
//设置最后登录时间
|
|
public function setLastTime($uid){
|
|
return $this->where("uid='%s'",array($uid))->save(array("last_login_time"=>time()));
|
|
}
|
|
|
|
//删除用户
|
|
public function delete_user($uid){
|
|
D("ItemMember")->where("uid = '$uid' ")->delete();
|
|
D("UserToken")->where("uid = '$uid' ")->delete();
|
|
D("Template")->where("uid = '$uid' ")->delete();
|
|
D("ItemTop")->where("uid = '$uid' ")->delete();
|
|
$return = D("User")->where("uid = '$uid' ")->delete();
|
|
return $return ;
|
|
}
|
|
//检测ldap登录
|
|
public function checkLdapLogin($username ,$password ){
|
|
$ldap_open = D("Options")->get("ldap_open" ) ;
|
|
$ldap_form = D("Options")->get("ldap_form" ) ;
|
|
$ldap_form = json_decode($ldap_form,1);
|
|
if (!$ldap_open) {
|
|
return false;
|
|
}
|
|
if (!$ldap_form['user_field']) {
|
|
$ldap_form['user_field'] = 'cn';
|
|
}
|
|
$ldap_conn = ldap_connect($ldap_form['host'], $ldap_form['port']);//建立与 LDAP 服务器的连接
|
|
if (!$ldap_conn) {
|
|
return false;
|
|
}
|
|
ldap_set_option($ldap_conn, LDAP_OPT_PROTOCOL_VERSION, $ldap_form['version']);
|
|
$rs=ldap_bind($ldap_conn, $ldap_form['bind_dn'], $ldap_form['bind_password']);//与服务器绑定 用户登录验证 成功返回1
|
|
if (!$rs) {
|
|
return false ;
|
|
}
|
|
|
|
$result = ldap_search($ldap_conn,$ldap_form['base_dn'],"(cn=*)");
|
|
$data = ldap_get_entries($ldap_conn, $result);
|
|
for ($i=0; $i<$data["count"]; $i++) {
|
|
$ldap_user = $data[$i][$ldap_form['user_field']][0] ;
|
|
$dn = $data[$i]["dn"] ;
|
|
if ($ldap_user == $username) {
|
|
//如果该用户不在数据库里,则帮助其注册
|
|
$userInfo = D("User")->isExist($username) ;
|
|
if(!$userInfo){
|
|
D("User")->register($ldap_user,$ldap_user.time());
|
|
}
|
|
$rs2=ldap_bind($ldap_conn, $dn , $password);
|
|
if ($rs2) {
|
|
D("User")->updatePwd($userInfo['uid'], $password);
|
|
return $this->checkLogin($username,$password);
|
|
}
|
|
}
|
|
}
|
|
|
|
return false ;
|
|
|
|
}
|
|
|
|
public function checkDbOk(){
|
|
$ret = $this->find() ;
|
|
if ($ret) {
|
|
return true;
|
|
}else{
|
|
return false;
|
|
}
|
|
}
|
|
|
|
}
|