teratail header banner
teratail header banner
質問するログイン新規登録

Q&A

解決済

1回答

1624閲覧

React+Java(Spring)+axiosを用いてアップロード機能を作成したいです。

nijima

総合スコア27

0グッド

0クリップ

投稿2022/02/22 08:39

0

0

急遽、ReactとJava、API通信にはaxiosを用いたアップロード機能を実装することになりました。

下記の記事を参考にしてフロント側のファイルを作成いたしました。
https://qiita.com/wanwanwan/items/62cfe2ad1ad9d767f133
ここから、Java(Spring)とやりとりしたいと考えているのですが、Springの知識が浅く、現在のところ下記Javaのコマンドまでしか書くことができません。

浅い知識と質問で大変申し訳ありません、
ここからどのようにJavaのコマンドを記述していくか、助言をいただけますでしょうか。
何卒、よろしくお願いいたします。

javaScript

1import { useState } from 'react'; 2import axios from 'axios'; 3 4export const Upload = () => { 5 const [image, setImage] = useState<any>(); 6 7 const getImage = (e: React.ChangeEvent<HTMLInputElement>) => { 8 if (!e.target.files) return; 9 const img: any = e.target.files[0]; 10 setImage(img); 11 }; 12 13 const submitImage = () => { 14 const header = { 15 headers: { 16 'Content-Type': 'application/json;charset=UTF-8', 17 'Access-Control-Allow-Origin': '*', 18 }, 19 }; 20 const data = new FormData(); 21 data.append('file', image); 22 const postImageUri = '任意のURL'; 23 axios 24 .post(postImageUri, data, header) 25 .then((res) => { 26 console.log(res.data) 27 }) 28 }; 29 30 return ( 31 <div> 32 <form> 33 <label htmlFor='img'>画像</label> 34 <input id='img' type='file' accept='image/*,.png,.jpg,.jpeg,.gif' onChange={getImage} /> 35 <input type='button' value='保存' onClick={submitImage} /> 36 </form> 37 </div> 38 ); 39}; 40

Java

1package jp.co.itfllc.merecycle.v1.controllers.dashboard; 2 3import org.springframework.http.HttpStatus; 4import org.springframework.web.bind.annotation.RequestMapping; 5import org.springframework.web.bind.annotation.ResponseStatus; 6import org.springframework.web.bind.annotation.RestController; 7import jp.co.itfllc.merecycle.v1.Constants; 8 9@RestController 10@RequestMapping(Constants.API_VERSION +"file/upload") 11@ResponseStatus(HttpStatus.OK) 12public class UploadFile { 13 14} 15

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

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

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

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

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

guest

回答1

0

自己解決

MultipartFileのライブラリを用いて解決できました。

投稿2022/02/25 06:11

nijima

総合スコア27

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.30%

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

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

質問する

関連した質問