laravel react axios を使用して画像をstorageに保存したい
postmanを使用してcontrolerは動いているか確認したところしっかりstorage内に画像が保存されたので、react側のaxiosでの画像送信の処理の書き方がわかりません
※githubのURLです
https://github.com/IRU212/web03
test.jsx
1 2```import axios from 'axios' 3import React, { useState } from 'react' 4 5function Test() { 6 7 const [title,setTitle] = useState() 8 const [image,setImage] = useState() 9 10 const handleSubmit = () => { 11 12 const data = new FormData() 13 file.append("title",title) 14 file.append("image",image) 15 16 axios.post("http://127.0.0.1:8000/api/test",data,{ 17 headers: { 18 'content-type': 'multipart/form-data', 19 } 20 }) 21 .then(response => { 22 console.log(response); 23 }) 24 .catch((res) => { 25 console.log(res.data) 26 }) 27 } 28 29 return ( 30 <div> 31 <form> 32 <p>ファイル送信</p> 33 <input type="text" placeholder="写真のタイトル" name='tite' onChange={event => setTitle(event.target.value)} /> 34 <input accept="image/*" multiple type="file" name='image' onChange={event => setImage(event.target.files[0])} /> 35 <button onClick={handleSubmit}>送信</button> 36 </form> 37 </div> 38 ) 39} 40 41export default Test
TestController.php
1<?php 2 3namespace App\Http\Controllers; 4 5use App\Models\Test; 6use Illuminate\Http\Request; 7 8class TestController extends Controller 9{ 10 public function store(Request $request){ 11 $test = new Test; 12 $file_name = $request->image->getClientOriginalName(); 13 $request->image->storeAs('public/image/',$file_name); 14 $test->title = $request->title; 15 $test->image = $file_name; 16 $test->save(); 17 return response()->json($test); 18 } 19} 20
Test.php
1<?php 2 3namespace App\Models; 4 5use Illuminate\Database\Eloquent\Factories\HasFactory; 6use Illuminate\Database\Eloquent\Model; 7 8class Test extends Model 9{ 10 protected $filable = 'tests'; 11 12 protected $table = [ 13 'image', 14 'title' 15 ]; 16} 17
あなたの回答
tips
プレビュー