>  기사  >  웹 프론트엔드  >  로컬(파일 프로토콜) AJAX 요청을 지원하도록 Chrome 구성(그래픽 튜토리얼)

로컬(파일 프로토콜) AJAX 요청을 지원하도록 Chrome 구성(그래픽 튜토리얼)

亚连
亚连원래의
2018-05-22 11:30:482550검색

이 글에서는 주로 로컬(파일 프로토콜) AJAX 요청을 지원하도록 Chrome을 구성하는 방법을 자세히 소개합니다. 관심 있는 친구들은

문제가 무엇인지

를 참조하세요. 완전한 프로젝트를 개발하는 대신 몇 가지 간단한 데모를 작성할 때 일반적인 작업은 다음과 같습니다.

• 새 폴더 만들기
• 필요한 파일 만들기
• Sublime(또는 다른 편집기)에서 DEMO 코딩을 완료합니다.
• 브라우저에서 직접 데모를 실행하려면 HTML 파일을 두 번 클릭하세요.

이 시점에서 데모에 AJAX 작업이 있으면 브라우저는 오류를 보고합니다:

XMLHttpRequest가 파일을 로드할 수 없습니다: // /Users/iceStone/Documents/Learning/angular/demo/angular-moviecat/movie/view.html 교차 출처 요청은 프로토콜 체계(http, data, chrome, chrome-extension, https, chrome)에만 지원됩니다. -extension -resource.

이유는 매우 간단합니다. 브라우저(Webkit 커널)의 보안 정책에 따라 파일 프로토콜로 액세스하는 응용 프로그램은 XMLHttpRequest 개체를 사용할 수 없습니다.

교차 출처 요청은 http, data, chrome, chrome-extension, https, chrome-extension-resource.resource와 같은 프로토콜 체계에 대해서만 지원됩니다.

이 작업은 Firefox 브라우저와 같은 일부 브라우저에서 허용됩니다. 이는 Filefox가 지원함을 의미합니다. 파일 프로토콜에 따른 AJAX 요청.


Solution

제가 개인적으로 가장 좋아하는 Chrome으로서 강력합니다. 상상할 수 있고 거의 불가능하다는 점 외에는 말할 것도 없습니다. 따라서 지원되어야 합니다.

Windows:

• Chrome의 바로가기 속성을 설정하고 "target" 뒤에 --allow-file-access-from-files를 추가하고 앞에 공백이 있다는 점을 확인한 후 Chrome을 다시 엽니다.


Mac:

•브라우저는 터미널을 통해서만 열 수 있습니다. 터미널을 열고 다음 명령을 입력합니다. open -a “Google Chrome” –args –disable-web-security 그러면 차단할 수 있습니다. secure access [ –args: 이 매개변수는 선택사항]


추가 설명

장기적으로는 반드시 HTTP를 통해 애플리케이션에 액세스해야 하므로 HTTP 서버 소프트웨어를 구성해야 합니다. 그러나 이제 막 시작하는 일부 학생들에게는 HTTP 서버(예: Apache, IIS 등)를 설정하는 것이 번거롭고 어려운 일입니다.

•IDE를 사용하는 학생들에게는 할 말이 없습니다. 웹 개발에 사용되는 모든 IDE에는 http 서버가 내장되어 있으므로 별도로 구성할 필요가 없습니다.
•Sublime Text와 같은 가벼운 편집기를 좋아하는 학생들을 위해 기본적으로 HTTP 서버가 내장되어 있지 않습니다.


다음으로 Sublime 플러그인 Sublime Server를 추천합니다. 이 플러그인은 정적 파일을 제공할 수 있습니다. HTTP 서버 구체적인 용도 방법은 다음과 같습니다.

•Google을 직접 설치하지 않는 Package Control(Sublime의 플러그인 관리 도구)을 설치합니다
•Command+Shift+P 또는 Ctrl+Shift+P를 사용하여 명령을 엽니다. 패널에서 Package Control 진입: Install Package

•잠깐 기다리세요(플러그인 제공업체의 서버에 연결되므로 상대적으로 느리고 벽 뒤에 있을 수 있음). SublimeServer

를 검색하세요. •설치가 완료된 후 , 도구 → SublimeServer → SublimeServer 시작
으로 이동합니다. •폴더를 열어 Sublime을 사용해야 합니다. 그렇지 않으면 SublimeServer를 정상적으로 사용할 수 없습니다.
•HTML 파일을 열고 마우스 오른쪽 버튼 클릭 메뉴에서 View in SublimeServer를 선택하면 HTTP를 통해 브라우저에서 파일에 액세스할 수 있습니다.
•이 옵션이 회색이면 SublimeServer 도구가 시작되지 않은 것입니다. → SublimeServer → SublimeServer 시작


이 시점에서 이미 Sublime에서 HTTP 서버를 사용할 수 있습니다.

가능한 문제

SublimeServer 시작을 클릭할 수 없는 경우 현재 포트 8080이 사용 중일 수 있습니다. (SublimeServer는 기본적으로 포트 8080을 사용합니다.)


해결책

은 구성 파일을 열고 포트를 변경하는 것입니다. 다른 포트로:

다음은 내 구성입니다.


{
  "attempts": 5,
  "autorun": false, // 是否在启动Sublime时自动启动SublimeServer
  "defaultExtension": ".html",
  "interval": 500,
  "mimetypes":
  {
    "": "application/octet-stream",
    ".c": "text/plain",
    ".h": "text/plain",
    ".py": "text/plain"
  },
  "port": 2016 // 端口号
}

물론 다른 편집기에도 비슷한 플러그인이 있습니다.

위 내용은 모두를 위해 제가 정리한 내용입니다. 앞으로 모든 사람에게 도움이 되기를 바랍니다.

관련 기사:

AJAX 페이징 효과의 간단한 구현(그래픽 튜토리얼)


Ajax 또는 Easyui와 같은 프레임워크 사용 시 Json-lib 처리 솔루션(그래픽 튜토리얼)


Ajax 구현 목록 무한 로딩 및 보조 드롭다운 옵션 효과


위 내용은 로컬(파일 프로토콜) AJAX 요청을 지원하도록 Chrome 구성(그래픽 튜토리얼)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.