A diferencia de las aplicaciones Web, las API RESTful son usualmente sin estado (stateless), lo que permite que las sesiones o las cookies no sean usadas. Por lo tanto, cada petición debe llevar alguna suerte de credenciales de autenticación, porque la autenticación del usuario no puede ser mantenida por las sesiones o las cookies. Una práctica común es enviar una pieza (token) secreta de acceso con cada petición para autenticar al usuario. Dado que una pieza de autenticación puede ser usada para identificar y autenticar solamente a un usuario, la API de peticiones tiene que ser siempre enviado vía HTTPS para prevenir ataques tipo "man-in-the-middle" (MitM) .
Hay muchas maneras de enviar una token (pieza) de acceso:
https://example.com/users?access-token=xxxxxxxx
. Debido que muchos servidores dejan los parámetros de consulta en los logs del servidor,
esta aproximación suele ser usada principalmente para servir peticiones JSONP
que no usen las cabeceras HTTP para enviar piezas de acceso.Yii soporta todos los métodos anteriores de autenticación. Puedes crear nuevos métodos de autenticación de una forma fácil.
Para activar la autenticación para tus APIs, sigue los pasos siguientes:
user
de la aplicación:false
.null
para mostrar un error HTTP 403 en vez de redireccionar a la pantalla de login. authenticator
en tus
clases de controladores REST.El paso 1 no es necesario pero sí recomendable para las APIs RESTful, pues son sin estado (stateless).
Cuando enableSession es false
, el estado de autenticación del usuario puede NO persistir entre peticiones usando sesiones.
Si embargo, la autenticación será realizada para cada petición, lo que se consigue en los pasos 2 y 3.
Tip:Puedes configurar enableSession del componente de la aplicación
user
en la configuración de las aplicaciones si estás desarrollando APIs RESTful en términos de un aplicación. Si desarrollas un módulo de las APIs RESTful, puedes poner la siguiente línea en el método del móduloinit()
, tal y como sigue:
public function init() { parent::init(); \Yii::$app->user->enableSession = false; }
Por ejemplo, para usar HTTP Basic Auth, puedes configurar el comportamiento (behavior) authenticator
como sigue,
use yii\filters\auth\HttpBasicAuth;
public function behaviors()
{
$behaviors = parent::behaviors();
$behaviors['authenticator'] = [
'class' => HttpBasicAuth::class,
];
return $behaviors;
}
Si quieres implementar los tres métodos de autenticación explicados antes, puedes usar CompositeAuth
de la siguiente manera,
use yii\filters\auth\CompositeAuth;
use yii\filters\auth\HttpBasicAuth;
use yii\filters\auth\HttpBearerAuth;
use yii\filters\auth\QueryParamAuth;
public function behaviors()
{
$behaviors = parent::behaviors();
$behaviors['authenticator'] = [
'class' => CompositeAuth::class,
'authMethods' => [
HttpBasicAuth::class,
HttpBearerAuth::class,
QueryParamAuth::class,
],
];
return $behaviors;
}
Cada elemento en authMethods
debe de ser el nombre de una clase de método de autenticación o un array de configuración.
La implementación de findIdentityByAccessToken()
es específico de la aplicación. Por ejemplo, en escenarios simples
cuando cada usuario sólo puede tener un token de acceso, puedes almacenar este token en la columna access_token
en la tabla de usuario. El método debe de ser inmediatamente implementado en la clase User
como sigue,
use yii\db\ActiveRecord;
use yii\web\IdentityInterface;
class User extends ActiveRecord implements IdentityInterface
{
public static function findIdentityByAccessToken($token, $type = null)
{
return static::findOne(['access_token' => $token]);
}
}
Después que la autenticación es activada, tal y como se describe arriba, para cada petición de la API, el controlador solicitado
puede intentar autenticar al usuario en su evento beforeAction()
.
Si la autenticación tiene éxito, el controlador realizará otras comprobaciones (como son límite del ratio, autorización)
y entonces ejecutar la acción. La identidad del usuario autenticado puede ser recuperada via Yii::$app->user->identity
.
Si la autenticación falla, una respuesta con estado HTTP 401 será devuelta junto con otras cabeceras apropiadas
(tal como la cabecera para autenticación básica HTTP WWW-Authenticate
).
Después de que un usuario se ha autenticado, probablementer querrás comprobar si él o ella tiene los permisos para realizar la acción solicitada. Este proceso es llamado autorización (authorization) y está cubierto en detalle en la Sección de Autorización.
Si tus controladores extienden de yii\rest\ActiveController, puedes sobreescribir el método checkAccess() para realizar la comprobación de la autorización. El método será llamado por las acciones contenidas en yii\rest\ActiveController.
Found a typo or you think this page needs improvement?
Edit it on github !
Signup or Login in order to comment.