本文整理汇总了PHP中Token::findFirst方法的典型用法代码示例。如果您正苦于以下问题:PHP Token::findFirst方法的具体用法?PHP Token::findFirst怎么用?PHP Token::findFirst使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Token
的用法示例。
在下文中一共展示了Token::findFirst方法的4个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的PHP代码示例。
示例1: verifyToken
/**
* 验证token
* @return bool true为合法,false为非法
*/
protected function verifyToken()
{
$request = new Request();
$token = $request->getHeader('singou-token');
//如果token不为空则检查,为空放行
if (!empty($token)) {
$model_token = new Token();
$dbToken = $model_token->findFirst(array('token' => $token));
$offset = time() - intval($dbToken->expire());
if ($offset < 0) {
return false;
}
return true;
}
}
示例2: logout
public function logout()
{
$token = parent::verifyToken();
if (false == $token) {
return parent::tokenError();
}
if (!empty($token->logout_time)) {
return parent::tokenError();
}
$dbToken = Token::findFirst("token='" . $token->token . "'");
if (false == $dbToken->delete()) {
return parent::serverError();
}
$this->session->destroy($token->token);
// 删除缓存中的token
return parent::success();
}
示例3: logout
/**
* @api {post} /token 登录获得token
* @apiUse header
*
* @apiName logout
* @apiGroup Token
* @apiVersion 1.0.0
*
* @apiSuccess {Array} empty_array 空数组,无实际意义
*
* @apiUse errorExample
*/
public function logout()
{
$token = $this->session->get('token');
if (false == $token) {
return parent::tokenError();
}
if (!empty($token->logout_time)) {
return parent::tokenError();
}
$dbToken = Token::findFirst("token='" . $token->token . "'");
$dbToken->logout_time = time();
if (false == $dbToken->delete()) {
return parent::serverError();
}
$this->session->set('token', null);
// 设置token为null
return parent::success();
}
示例4: verifyToken
/**
* 验证token
* @return bool false为非法 否则返回储存在数据库的token值
*/
public function verifyToken()
{
$request = new Request();
$token = $request->getHeader('token');
if (!empty($token)) {
session_id($token);
$cacheToken = $this->session->get('token');
//从session中取得token
if (null == $cacheToken) {
$tokenModel = new Token();
// 避免缓存失效,再去数据库里面拿
$cacheToken = $tokenModel->findFirst("token='" . $token . "'");
if (false == $cacheToken) {
return false;
} else {
$this->session->set('token', $token);
// 再次存进session中去
}
}
$offset = time() - intval($cacheToken->expire);
if ($offset > 0) {
// 过期
$this->session->set('token', null);
return false;
}
if (!empty($cacheToken->logout_time)) {
// 已经退出登录
$this->session->set('token', null);
return false;
}
return $cacheToken;
}
// 为空,直接返回false
return false;
}