yii2
API de descanso
Buscar..
Comience con el api de descanso
Tenemos una tabla que incluye de países, por lo que creamos un modelo que se llama modelo de compatilista.
<?php
namespace app\models;
use Yii;
/**
* This is the model class for table "countrylist".
*
* @property integer $id
* @property string $iso
* @property string $name
* @property string $nicename
* @property string $iso3
* @property integer $numcode
* @property integer $phonecode
*/
class Countrylist extends \yii\db\ActiveRecord
{
/**
* @inheritdoc
*/
public static function tableName()
{
return 'countrylist';
}
/**
* @inheritdoc
*/
public function rules()
{
return [
[['iso', 'name', 'nicename', 'phonecode'], 'required'],
[['numcode', 'phonecode'], 'integer'],
[['iso'], 'string', 'max' => 2],
[['name', 'nicename'], 'string', 'max' => 80],
[['iso3'], 'string', 'max' => 3]
];
}
/**
* @inheritdoc
*/
public function attributeLabels()
{
return [
'id' => 'ID',
'iso' => 'Iso',
'name' => 'Name',
'nicename' => 'Nicename',
'iso3' => 'Iso3',
'numcode' => 'Numcode',
'phonecode' => 'Phonecode',
];
}
}
y creo un servicio web de descanso para eso, creamos un controlador para restapi y configuramos la variable modelClass para nuestro modelo.
<?php
namespace app\controllers;
use yii\rest\ActiveController;
use Yii;
class CountrylistController extends ActiveController
{
public $modelClass='app\models\Countrylist';
}
?>
Para usar Restapi necesitamos URLs bonitas y
Añadimos esta regla para url bonita.
'urlManager' => [
'class' => 'yii\web\UrlManager',
'enablePrettyUrl' => true,
'showScriptName' => false,
'rules' => [
['class'=>'yii\rest\UrlRule','controller'=>'countrylist']
],
],
después de eso accedemos a podemos probar nuestra API de descanso como ejemplo
http: // localhost / countrylist nos da una lista de condados.
Cómo anular acciones predeterminadas de resto api Yii2
Como ejemplo, desea deshabilitar la paginación en su acción de índice predeterminada y obtener todos los resultados en el índice. Como puedes hacer eso? Es sencillo. Debería anular la acción de índice en su controlador de esta manera:
public function actions() {
$actions = parent::actions();
unset($actions['index']);
return $actions;
}
public function actionIndex() {
$activeData = new ActiveDataProvider([
'query' => \common\models\Yourmodel::find(),
'pagination' => false
]);
return $activeData;
}
Anular el tipo de contenido para una acción específica
Caso de uso: solo una acción que debe devolver un contenido plano (texto) como está:
public function actionAsXML()
{
$this->layout = false;
Yii::$app->response->format = Response::FORMAT_XML;
return ['aaa' => [1, 2, 3, 4]];;
}
Los formatos de respuesta predefinidos son:
- FORMAT_HTML
- FORMAT_XML
- FORMAT_JSON
- FORMAT_JSONP
- FORMAT_RAW
No hay un tipo de mime para text/plain fuera del cuadro, use este en su lugar:
public function actionPlainText()
{
$this->layout = false;
Yii::$app->response->format = Response::FORMAT_RAW;
Yii::$app->response->headers->add('Content-Type', 'text/plain');
return $this->render('plain-text'); // outputs template as plain text
}