• 로그인
  • 장바구니에 상품이 없습니다.

home2 게시판 React 게시판 이미지 불러오기 404

이미지 불러오기 404

2 글 보임 - 1 에서 2 까지 (총 2 중에서)
  • 글쓴이
  • #113690

    Qqq
    참가자
        async function getIamge(filename){
            await axios.get(`http://localhost:8080/imageFiles/${filename}`)
            .then((action)=>{
                let data = action.data;
                let copy = [...images,data];
                setImages(copy);
            })
            .catch((error)=>{
                console.log('서버 응답 코드:', error.response.status);
                console.log('서버 응답 데이터:', error.response.data);
                console.log('서버 응답 헤더:', error.response.headers);
            })
        }
    
    이렇게 통신을 하면 서버에서 이미지를 반환해주는데 반환 된 이미지는 스테이트에 담아서 보여주려고 하고 있습니다.
    @GetMapping("/imageFiles/{filename}")
    @CrossOrigin(origins = "*")
    public ResponseEntity<Resource> downloadExecute(@PathVariable("filename") String filename) throws IOException {
        log.info("Full Path = {}", fileDir + filename);
        String str = URLEncoder.encode(filename, "UTF-8");
        Path path = Paths.get(fileDir + filename);
        Resource resource = new InputStreamResource(java.nio.file.Files.newInputStream(path));
        System.out.println("resource : "+ resource.getFilename());
        return ResponseEntity.ok()
                .header(HttpHeaders.CONTENT_TYPE, "application/octect-stream")
                .header(HttpHeaders.CONTENT_DISPOSITION, "attachment;filename="+str+";")
                .body(resource);
    }
    이게 이미지를 반환해주는 서버 측 코드입니다.
    포스트맨으로 똑같은 조건으로 요청을 하면 상태코드 200에 이미지도 잘 반환해 주는데
    리액트로 요청을 하면 404 Not Found를 반환하네요. 서버에서는 리액트와 통신하기위해 cors설정도 해놨는데 어떤게 문제가
    되는지 모르겠습니다. 
    
    
    
    #113698

    codingapple
    키 마스터
    아마 filename 변수에 뭔가가 없거나 안만들어놓은 서버 url로 요청했다는 뜻 같습니다 
    await이랑 .then은 둘 중 하나만 써도 됩니다
2 글 보임 - 1 에서 2 까지 (총 2 중에서)
  • 답변은 로그인 후 가능합니다.

About

현재 월 700명 신규수강중입니다.

  (09:00~20:00) 빠른 상담은 카톡 플러스친구 코딩애플 (링크)
  admin@codingapple.com
  이용약관
ⓒ Codingapple, 강의 예제, 영상 복제 금지
top

© Codingapple, All rights reserved. 슈퍼로켓 에듀케이션 / 서울특별시 강동구 고덕로 19길 30 / 사업자등록번호 : 212-26-14752 온라인 교육학원업 / 통신판매업신고번호 : 제 2017-서울강동-0002 호 / 개인정보관리자 : 박종흠