首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何从https://jsonplaceholder.typicode.com/posts‘中获取和保存REST数据?

如何从https://jsonplaceholder.typicode.com/posts‘中获取和保存REST数据?
EN

Stack Overflow用户
提问于 2022-03-31 20:00:45
回答 1查看 767关注 0票数 -1

https://jsonplaceholder.typicode.com/posts是json数据链接。我想获取、获取并将这些数据保存在数据库中。我收到的所有帮助都是关于使用foreach方法在Blade模板中获取和显示数据。我没有找到任何关于保存这些数据的解决方案(我指的是一次数据库中的全部100个数据)。我只能保存一个数据,因为我从那个API链接中获得的数据是二维的(我指的是其他索引数组中的数组)。下面给出了控制器代码,用于只保存一个数据,而不是将整个数据保存为一个对象或数组。

代码语言:javascript
复制
<?php
namespace App\Http\Controllers;
use App\Models\apipost;
use Illuminate\Support\Facades\Http;
class postController extends Controller
{
  public function index(){
      $response=json_decode(Http::get('https://jsonplaceholder.typicode.com/posts'));
         $apipost=new apipost();
         $apipost->userId=$response[0]->userId;
         $apipost->id=$response[0]->id;
         $apipost->title=$response[0]->title;
         $apipost->body=$response[0]->body;
         $apipost->save();
          return redirect()->to('/');
     }
}
EN

回答 1

Stack Overflow用户

发布于 2022-03-31 20:56:31

我猜您的表具有与响应相同的列,因此您可以尝试如下:

代码语言:javascript
复制
  public function index()
  {
     $response = Http::get('https://jsonplaceholder.typicode.com/posts')->json();

     foreach ($response as $post) {
        apipost::create($post);
     }

     return redirect()->to('/')
  }

->json()将在数组中转换您的响应。您可以在这里看到文档:https://laravel.com/docs/9.x/http-client#making-requests

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/71698515

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档