[TIL] 서버로 부터 받은 Byte Data, React에서 다운 받기

2024. 11. 19. 14:15·Front End/React
목차
  1. 상황
728x90
반응형

본 글은 TIL(Today I Learned) 로 공부 내역에 대한 포스팅입니다.

 

상황

서버로부터 Binary Data를 받아야 하는 상황에서 React 프론트 엔드는 이에 대한 처리 방식에 대한 정리

 

아래는 예시 백엔드 소스 코드이다.

# Flask 서버로 예시를 들자면 아래와 같은 상황이다.
import io

@app.route('/GetDataFromServer', methods=['GET'])
def GetDataFromServer():
    return Response(io.BytesIO())

 

그에 대한 리액트 프론트 엔드 서버 소스 코드이다.

setLoading(true); // 로딩을 실행한다.

axios.get('/GetDataFromServer', {responseType: 'blob'})
.then((response) => new Blob([response.data]) // Blob 객체를 통해 받은 데이터 Blob 데이터로 변환
.then((blob) => {
    const link = document.createElement('a');
    link.href = window.URL.createObjectURL(blob); // Blob 데이터를 다운로드 받을 수 있는 URL 형식으로 변환
    link.setAttribute('download', `Filename`);
    document.body.appendChild(link);
    link.click();
    link.remove();

    URL.revokeObjectURL(link.href);
})
.catch((error) => {
    console.error(error);
})
.finally(() => {
    // 모든 로직이 종료 후 로딩 종료
    setLoading(false);
})

 

클라이언트에게 보이지 않는 <a> 태그를 생성해 Blob URL을 href 속성으로 설정. 그 후 해당 Anchor를 클릭하고 삭제하는 로직을 가진다.

728x90
반응형

'Front End > React' 카테고리의 다른 글

[React] 리액트에서 클립보드 사용하기  (0) 2024.10.13
[React] State와 Select Tag Binding.  (0) 2024.10.13
[React] Title, Favicon 변경하는 법  (0) 2024.09.20
  1. 상황
'Front End/React' 카테고리의 다른 글
  • [React] 리액트에서 클립보드 사용하기
  • [React] State와 Select Tag Binding.
  • [React] Title, Favicon 변경하는 법
Dev.Poinguinie
Dev.Poinguinie
게임, 코딩 블로그 입니다. 여러 일상적인 글도 올려요! 많이 봐주세요! 감사합니다.
    250x250
  • Dev.Poinguinie
    펭귄교수
    Dev.Poinguinie
  • 공지사항

    • 티스토리 스킨 변경
    • 파이썬 코딩 강의 공지사항
    • 분류 전체보기
      • 새티스팩토리
        • 정보
        • 모드
        • 리뷰
      • 펠월드
        • 정보
        • 패치노트
      • 게임
        • 스팀 세일
        • 테라리아
        • 디펜서바이버
      • App
        • Kotlin
        • Flutter
      • Front End
        • HTML
        • JavaScript
        • React
      • Back End
        • Node.js
      • Docker
        • Docker 강의
        • Docker Project
      • 프로그래밍
        • AI
        • Chrome Extension
        • Markdown
        • Python
        • C++
        • Linux
        • Error
        • Tool
      • Computer Science
        • Algorithm
        • Network
      • 게임 프로그래밍
        • 유니티
      • 제작
        • 웹사이트
        • 기타 프로그램
      • 일상
        • 자작시
        • 노래 추천 및 정보
        • 블로그 운영
        • 내일의 모든 것
        • 오블완 챌린지
      • 리뷰
        • 식당 리뷰
        • IT 리뷰
  • 링크

    • 새티스 팩토리 모드
    • 깃허브 블로그
    • 깃허브 프로필
  • 최근 글

  • 반응형
  • hELLO· Designed By정상우.v4.10.3
Dev.Poinguinie
[TIL] 서버로 부터 받은 Byte Data, React에서 다운 받기

개인정보

  • 티스토리 홈
  • 포럼
  • 로그인
상단으로

티스토리툴바

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.