laravel用户列表分页和模糊搜索api

一、用户列表分页和模糊搜索api

1.1、创建用户控制器

运行命令创建资源控制器:php artisan make:controller Admin/UserController --api

--api 用于api的资源控制器。会忽略createedit页面的方法。

在这里插入图片描述
UserController.php控制器默认就会为我们创建5个方法:
在这里插入图片描述

1.2、创建transform

app文件夹下创建一个Transformers文件夹,写入UserTransformer.php

<?php 

namespace App\Transformers;

use App\Models\User;
use League\Fractal\TransformerAbstract;

class UserTransformer extends TransformerAbstract {
    public function transform(User $user) {
        return [
            'id' => $user->id,
            'name' => $user->name,
            'email' => $user->email,
            'created_at' => $user->created_at,
            'updated_at' => $user->updated_at,
        ];
    }
}

1.3、创建用户资源路由

routes/admin.php下创建用户资源路由:

<?php

use App\Http\Controllers\Admin\UserController;

$api = app('Dingo\Api\Routing\Router');

$api->version('v1', function ($api) {
   // 路由分组
   $api->group(['prefix' => 'admin'], function ($api) {
       // 需要登陆的路由
        $api->group(['middleware' => 'api.auth'], function ($api) {
            /**
             * 用户管理
             */
            // 禁用用户/启用用户
            $api->patch('users/{user}/lock', [UserController::class, 'lock']);

            // 用户管理资源路由
            $api->resource('users', UserController::class, [
                'only' => ['index', 'show']
            ]);
        });
   });
});

dingo/api中使用patch更新某些资源。

手动创建禁用和启用用户路由users/{user}/lock,并在UserController.php中创建对应方法。

使用resource会主动忽略createedit这两个方法。

使用第三个参数数组,only的话只指定使用的控制器方法。

1.4、修改用户方法(分页和模糊搜索)

UserController.php

<?php

namespace App\Http\Controllers\Admin;

use App\Http\Controllers\BaseController;
use App\Models\User;
use App\Transformers\UserTransformer;
use Illuminate\Http\Request;

class UserController extends BaseController
{
    /**
     * 禁用用户
     */
    public function lock()
    {
        //
    }

    /**
     * 用户列表
     */
    public function index(Request $request)
    {
        $name = $request -> input('name');
        $email = $request -> input('email');

        $users = User::when($name, function($query) use ($name) {
            $query->where('name', 'like', "%$name%");
        }) 
        -> when($email, function ($query) use ($email) {
            $query->where('email', $email);
        }) 
        -> paginate(2);
        return $this->response()->paginator($users, new UserTransformer());
    }

    /**
     * Store a newly created resource in storage.
     *
     * @param  \Illuminate\Http\Request  $request
     * @return \Illuminate\Http\Response
     */
    public function store(Request $request)
    {
        //
    }

    /**
     * Display the specified resource.
     *
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function show($id)
    {
        //
    }

    /**
     * Update the specified resource in storage.
     *
     * @param  \Illuminate\Http\Request  $request
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function update(Request $request, $id)
    {
        //
    }

    /**
     * Remove the specified resource from storage.
     *
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function destroy($id)
    {
        //
    }
}

when(keywords, callback)有两个参数:参数1如果变量存在,则执行我们的回调函数。

在使用闭包的时候外部变量不能传入,使用use进行传入外部变量。

paginate表示每页几条数据,前端可以通过传递query传参page来表示请求第几页。
模糊搜索用like,完全一样搜索则不加。

1.5、效果

在这里插入图片描述

在学习的php的路上,如果你觉得本文对你有所帮助的话,那就请关注点赞评论三连吧,谢谢,你的肯定是我写博的另一个支持。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

你华还是你华

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值