"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > 다른 원본에서 이미지를 로드할 때 `canvas.toDataURL()`이 보안 예외를 발생시키는 이유는 무엇입니까?

다른 원본에서 이미지를 로드할 때 `canvas.toDataURL()`이 보안 예외를 발생시키는 이유는 무엇입니까?

2024년 11월 13일에 게시됨
검색:855

Why Does `canvas.toDataURL()` Throw a Security Exception When Loading Images from a Different Origin?

canvas.toDataURL()에서 보안 예외가 발생하는 이유는 무엇입니까?

HTML 캔버스로 작업할 때 다음과 같은 경우 당황스러운 보안 예외가 발생할 수 있습니다. toDataURL() 메서드를 사용하여 캔버스의 base64 데이터 URL을 검색하려고 시도합니다. 이 오류의 원인을 살펴보고 해결책을 찾아보겠습니다.

toDataURL() 메서드를 사용하면 캔버스 콘텐츠를 base64로 인코딩된 문자열로 변환할 수 있으며, 이는 이미지를 저장하거나 공유하는 데 유용할 수 있습니다. 그러나 캔버스 요소가 "원본이 부정한" 것으로 간주되는 경우 이 방법으로 보안 예외가 발생한다는 점을 이해하는 것이 중요합니다.

HTML 사양에 따르면 캔버스 요소에 로드된 이미지가 포함되어 있으면 원본이 부정한 것으로 간주됩니다. 웹페이지 자체가 아닌 다른 서버에서. 코드 조각에서 이미지는 웹페이지와 다른 출처인 "www.ansearch.com"에서 로드됩니다.

이 보안 제한은 교차 출처 콘텐츠 오염을 방지하기 위해 적용됩니다. 악성 웹사이트는 다른 웹사이트의 이미지에 액세스하고 이를 수정하여 보안 위험을 초래할 수 있습니다. 따라서 toDataURL()을 사용하여 원본이 깨끗하지 않은 캔버스를 base64 문자열로 변환하려고 시도하면 SECURITY_ERR 예외가 발생합니다.

이 문제를 해결하려면 캔버스에 사용된 이미지가 웹페이지와 동일한 출처에서 로드됩니다. 이는 자체 서버에서 이미지를 호스팅하거나 동일한 원본에서 이미지를 제공하는 CDN을 사용하는 것을 의미합니다. 일치하는 원본에서 이미지가 로드되면 toDataURL() 메서드가 오류 없이 작동해야 합니다.

최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3