【发布时间】:2017-04-19 06:34:03
【问题描述】:
我已经建立了一个模型User,并创建了一个控制器来获取一些值:
<?php
namespace App\Http\Controllers;
use Dingo\Api\Routing\Helpers;
use Illuminate\Routing\Controller;
use App\Models\User;
class UserController extends Controller
{
use Helpers;
public function index()
{
$users = User::all();
return $users;
}
}
但是当我运行这个时,json 值会返回两次:
{
"users": [
{
"0": "Firstname Lastname",
"1": "Accusantium commodi repellat quia eos. Cumque debitis qui deserunt aspernatur harum vitae aut.",
"2": 1,
"3": "2016-12-04 21:56:59",
"4": "2016-12-04 21:56:59",
"name": "Firstname Lastname",
"profile": "Accusantium commodi repellat quia eos. Cumque debitis qui deserunt aspernatur harum vitae aut.",
"house_id": 1,
"created_at": "2016-12-04 21:56:59",
"updated_at": "2016-12-04 21:56:59"
},
}
但是,奇怪的是:上面的响应是当我的 User 模型中有一个空的 $visible[] 数组时。但是,当我将$visible 设置为包含例如name 和profile 时,这两个值都只显示一次。这里有什么问题?为什么会出现两次?
【问题讨论】:
-
你使用
return $users->toJson();的结果是什么? -
没区别,值又返回了两次。
-
你的
Users模型结构是什么? -
您是否在数据库连接选项中设置了
PDO::FETCH_BOTH(查看您的config/database.php文件)? -
否,但在我的数据库配置中设置
'fetch' => PDO::FETCH_CLASS,可以解决问题!
标签: php json laravel laravel-5 laravel-5.3