Laravel API - 通过 o2m 关系显示单个文件

Posted

技术标签:

【中文标题】Laravel API - 通过 o2m 关系显示单个文件【英文标题】:Laravel API - Showing individual file through o2m relationship 【发布时间】:2021-02-23 19:54:40 【问题描述】:

所以我有两个模型 User 和 File,它们以一对多的关系连接。

我已经对 API 路由和控制器进行了排序,以索引所有用户、显示特定用户并索引该特定用户上传的所有文件。我不知道如何编写允许此路由 127.0.0.1:8001/api/2/files/1 显示第二个用户上传的第一个文件的逻辑。所以/2(seconduser)/files(显示全部)/1(只显示1个文件)

这是我的 API 代码:

Route::group(["prefix" => "/"], function () 
    Route::get("", [Users::class, "index"]); //show all users

    Route::group(["prefix" => "user"], function () 
        Route::get("", [Users::class, "show"]); //show specific user

        Route::group(["prefix" => "/files"], function () 
            Route::get("", [Files::class, "index"]); //show all files

            Route::group(["prefix" => "file"], function () 
                Route::get("", [Files::class, "show"]); //trying to show specific file
            );
        );
    );
);

文件控制器

<?php

namespace App\Http\Controllers\API;

use App\Http\Controllers\Controller;
use Illuminate\Http\Request;
use App\Models\User;
use App\Models\File;

class Files extends Controller

    /**
     * Display a listing of the resource.
     *
     * @return \Illuminate\Http\Response
     */
    public function index(User $user)
    
        return $user->files;    
    


    /**
     * Display the specified resource.
     *
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function show(User $user, File $file)
    
        
    

用户控制器

<?php

namespace App\Http\Controllers\API;

use App\Http\Controllers\Controller;
use Illuminate\Http\Request;
use App\Models\User;

class Users extends Controller

    /**
     * Display a listing of the resource.
     *
     * @return \Illuminate\Http\Response
     */
    public function index()
    
        return User::all();
    

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

【问题讨论】:

这是一种非常奇怪的方式来声明你的路由。 artisan route:list -c 对这些路线显示什么?你也能澄清问题吗?你在找什么? return $file;? 请编辑您的问题以包含此信息,不要将其放入 cmets。 我仍然不清楚问题是什么。您在 URL 中指定了一个文件 ID,该文件被放入 $file 变量中。与用户相同。 Users::show()做同样的事情有什么问题??? 这与您在此处显示的代码不一致,其中 $file 是参数 2。 【参考方案1】:

这就是典型的路由声明的样子。请注意,用户 ID 与文件请求无关,因此文件端点与用户端点分开。

Route::get("/users",              [Users::class, "index"]);
Route::get("/users/user",       [Users::class, "show"]);
Route::get("/users/user/files", [Files::class, "index"]);
Route::get("/files/file",       [Files::class, "show"]);

然后在您的控制器方法中,您只是返回一个列表或单个项目,主要是在您的原始代码中。请注意,如果您要返回 API 数据,您应该明确地return JSON。

<?php

namespace App\Http\Controllers\API;

use App\Http\Controllers\Controller;
use Illuminate\Http\Request;
use App\Models\User;
use App\Models\File;

class Files extends Controller

    /**
     * Display a listing of the resource.
     *
     * @return \Illuminate\Http\JsonResponse
     */
    public function index(User $user)
    
        return response()->json($user->files);    
    


    /**
     * Display the specified resource.
     *
     * @param  int  $id
     * @return \Illuminate\Http\JsonResponse
     */
    public function show(File $file)
    
        return response()->json($file);
        // or perhaps something like this?
        return response()
            ->download($file->path, $file->name, ["Content-Type" => $file->type]);
    

<?php

namespace App\Http\Controllers\API;

use App\Http\Controllers\Controller;
use Illuminate\Http\Request;
use App\Models\User;

class Users extends Controller

    /**
     * Display a listing of the resource.
     *
     * @return \Illuminate\Http\JsonResponse
     */
    public function index()
    
        return response()->json(User::all());
    

    /**
     * Display the specified resource.
     *
     * @param  int  $id
     * @return \Illuminate\Http\JsonResponse
     */
    public function show(User $user)
    
        return response()->json($user);
    

【讨论】:

以上是关于Laravel API - 通过 o2m 关系显示单个文件的主要内容,如果未能解决你的问题,请参考以下文章

laravel中通过api发送关系请求

Laravel 4:如果通过查询关系存在关系,则选择行

在laravel api中对关系资源进行分页

Laravel:从关系而不是整个对象返回属性

Laravel Eloquent - 通过用户模型上的方法对用户关系进行排序

Laravel API JSON 自定义和表关系