To create a RESTful API, first use yii\rest\Controller or its subclass as the controller base class, then configure URL rules to implement a concise API endpoint, then customize the operations as needed and ensure the response format is consistent. 1. Select the appropriate controller base class, such as yii\rest\ActiveController, to automatically provide standard operations; 2. Configure yii\rest\UrlRule in the urlManager to map resource routing; 3. Custom operation methods return data arrays, and Yii will be automatically converted to JSON; 4. Unify the response structure, such as wrapping in an object containing status and data fields to improve API consistency and ease of use.
Creating RESTful APIs with Yii controllers is straightforward once you understand how Yii's controller and model system works. The key lies in structuring your controllers properly, using the right components, and formatting responses correctly.
1. Use yii\rest\Controller
or its subclasses
The first step is to make sure you're using the right base controller class. Yii provides a dedicated set of controller classes for building RESTful APIs. The most common one is yii\rest\Controller
.
use yii\rest\Controller; class UserController extends Controller { // Your actions go here }
This base class comes with built-in support for JSON formatting, authentication, and data serialization. If you're working with ActiveRecord models, consider extending yii\rest\ActiveController
, which gives you index, view, create, update, and delete actions out of the box — just by setting the $modelClass
.
2. Configure URL rules for clean API endpoints
RESTful URLs are usually clean and resource-based. To map these URLs to your controllers, configure the urlManager
component in your config file (like config/web.php
):
'urlManager' => [ 'enablePrettyUrl' => true, 'enableStrictParsing' => true, 'showScriptName' => false, 'rules' => [ ['class' => 'yii\rest\UrlRule', 'controller' => 'user'], ], ]
This setup will automatically map:
-
GET /users
→indexAction
-
GET /users/123
→viewAction
-
POST /users
→createAction
- And so on…
You can also customize the pluralization or add extra actions if needed.
3. Customize actions as needed
If you're not using ActiveController
, you'll need to define your own actions. But even then, Yii makes it easy via action methods that return data arrays:
public function actionIndex() { $users = User::find()->all(); return $users; }
Yii automatically converts this into a JSON response. You don't have to manually call json_encode()
or handle headers unless you want to customize them.
Also, remember:
- Use status codes appropriately (
throw new \yii\web\HttpException(404, 'Not Found')
) - Handle user authentication with
behaviors()
if required - Return consistent response structures
4. Format responses consistently
While Yii handles JSON output by default, you might want to wrap your responses in a standard format for consistency across all API endpoints.
For example, instead of returning raw data like:
{ "id": 1, "name": "John" }
You could return:
{ "status": "success", "data": { "id": 1, "name": "John" } }
To do this, use a wrapper method or override serializeData()
in a custom controller class.
A simple way:
protected function verbs() { Return [ 'index' => ['GET'], ]; } public function actionIndex() { $data = User::find()->all(); return ['status' => 'success', 'data' => $data]; }
That way, no matter what kind of data you return from an action, it follows a predictable structure.
Basically, creating RESTful APIs in Yii involves choosing the right controller type, configuring clean URLs, defining or customizing actions, and ensuring consistent output. It's not complicated, but getting the structure right early helps avoid messy refactoring later.
The above is the detailed content of How do I create RESTful APIs using Yii controllers?. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undress AI Tool
Undress images for free

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

YiiassetbundlesorganizeandmanagewebassetslikeCSS,JavaScript,andimagesinaYiiapplication.1.Theysimplifydependencymanagement,ensuringcorrectloadorder.2.Theypreventduplicateassetinclusion.3.Theyenableenvironment-specifichandlingsuchasminification.4.Theyp

In the MVC framework, the mechanism for the controller to render views is based on the naming convention and allows explicit overwriting. If redirection is not explicitly indicated, the controller will automatically find a view file with the same name as the action for rendering. 1. Make sure that the view file exists and is named correctly. For example, the view path corresponding to the action show of the controller PostsController should be views/posts/show.html.erb or Views/Posts/Show.cshtml; 2. Use explicit rendering to specify different templates, such as render'custom_template' in Rails and view('posts.custom_template') in Laravel

When saving data to the database in the Yii framework, it is mainly implemented through the ActiveRecord model. 1. Creating a new record requires instantiation of the model, loading the data and verifying it before saving; 2. Updating the record requires querying the existing data before assignment; 3. When using the load() method for batch assignment, security attributes must be marked in rules(); 4. When saving associated data, transactions should be used to ensure consistency. The specific steps include: instantiating the model and filling the data with load(), calling validate() verification, and finally performing save() persistence; when updating, first obtaining records and then assigning values; when sensitive fields are involved, massassignment should be restricted; when saving the associated model, beginTran should be combined

TocreateabasicrouteinYii,firstsetupacontrollerbyplacingitinthecontrollersdirectorywithpropernamingandclassdefinitionextendingyii\web\Controller.1)Createanactionwithinthecontrollerbydefiningapublicmethodstartingwith"action".2)ConfigureURLstr

The method of creating custom operations in Yii is to define a common method starting with an action in the controller, optionally accept parameters; then process data, render views, or return JSON as needed; and finally ensure security through access control. The specific steps include: 1. Create a method prefixed with action; 2. Set the method to public; 3. Can receive URL parameters; 4. Process data such as querying the model, processing POST requests, redirecting, etc.; 5. Use AccessControl or manually checking permissions to restrict access. For example, actionProfile($id) can be accessed via /site/profile?id=123 and renders the user profile page. The best practice is

AYiidevelopercraftswebapplicationsusingtheYiiframework,requiringskillsinPHP,Yii-specificknowledge,andwebdevelopmentlifecyclemanagement.Keyresponsibilitiesinclude:1)Writingefficientcodetooptimizeperformance,2)Prioritizingsecuritytoprotectapplications,

AYiideveloper'skeyresponsibilitiesincludedesigningandimplementingfeatures,ensuringapplicationsecurity,andoptimizingperformance.QualificationsneededareastronggraspofPHP,experiencewithfront-endtechnologies,databasemanagementskills,andproblem-solvingabi

TouseActiveRecordinYiieffectively,youcreateamodelclassforeachtableandinteractwiththedatabaseusingobject-orientedmethods.First,defineamodelclassextendingyii\db\ActiveRecordandspecifythecorrespondingtablenameviatableName().Youcangeneratemodelsautomatic
