質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.47%
Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。

Q&A

0回答

1195閲覧

laravel react axios を使用して画像をstorageに保存したい

IRU212

総合スコア0

Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。

0グッド

1クリップ

投稿2022/09/20 11:08

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

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

IRU212

2022/09/21 05:50

解決しました
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.47%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問