Angular에서 Api 프록시를 사용하는 방법에 대한 간략한 분석
이 글은 Angular에서 Api 프록시를 사용하는 방법을 소개하고, angualr을 사용하여 프록시 API 도킹에 대한 주제를 설명하는 내용이 모든 분들께 도움이 되기를 바랍니다.
프론트엔드 개발자로서 우리는 종종 백엔드와 인터페이스합니다. 그런데 도킹 과정에서 항상 도메인 간 문제가 발생하는데 어떻게 해결해야 할까요?
이 문서에서는 angualr
을 사용하여 프록시 api
도킹 주제를 설명합니다. [추천 관련 튜토리얼: "angualr
来讲解代理 api
对接的话题。【相关教程推荐:《angular教程》】
首先我们先来了解下,什么跨域。
跨域
简单理解:当一个请求的协议、域名(ip地址)、端口
三部分任意一个
当前页面的 url
不同就是跨域。
以我的站点 https://jimmyarea.com
为例:
被请求的地址 | 是否跨域 | 原因 |
---|---|---|
jimmyarea.com | 是 | 协议不同 |
jimmyarea.cn | 是 | 地址不同 |
https://127.0.0.1:9000 | 是 | 地址和端口号不同 |
代理
这个时候,我们可以通过代理,本地联调不同环境的 api
地址。
首先,我们在项目的根目录上新建一个文件 proxy.conf.json
。
我们以接口请求 https://jimmyarea.com/api/public/article?page=-1
为例子:
{ "/api": { "target": "https://jimmyarea.com/", "changeOrigin": true, "secure": false, "pathRewrite": { "^/api": "/api" } } }
target
是代理的地址,pathRewrite
是对代理的前缀的重写。
完成了代理文件之后,需要开启代理。我们在 package.json
中添加多一条命令行,表明是开发环境调试使用。
"script": { "dev": "ng serve --proxy-config=proxy.conf.json", }
执行 npm run dev
启动项目并带上代理。每次代理文件更改,需要重新启动下该命令行~
验证
我们新建一个 article
的服务,其中 article.service.ts
文件内容如下:
import { Injectable } from '@angular/core'; // http 客户端 import { HttpClient } from '@angular/common/http' @Injectable({ providedIn: 'root' }) export class ArticleService { constructor( private http: HttpClient ) { } // 获取文章列表 getArticleList() { return this.http.get('/api/public/article', { // 返回类型 responseType: 'json', // 请求的参数 params: { page: -1 } }) } }
上面的请求,在页面上地址是 http://localhost:4200/api/public/article?page=-1
,其实访问的是地址 https://jimmyarea.com/api/public/article?page=-1
。我们可以在 user-list.component.ts
angular Tutorial
간단한 이해:
요청에프로토콜, 도메인 이름(IP 주소) 및 포트<가 세 개 있는 경우 /code> 현재 일부 <code>모든
페이지의 url
이 다른 경우 이는 교차 도메인 을 의미합니다.
내 사이트 https://jimmyarea.com
를 예로 들어 보겠습니다.
요청된 주소 | < th> 크로스 도메인 여부이유 | |
---|---|---|
jimmyarea.com | 예 | < td>프로토콜이 다릅니다|
jimmyarea.cn | 예 | 주소가 다릅니다 |
예 | 주소와 포트번호가 다릅니다 |
api
주소를 로컬에서 디버깅할 수 있습니다. 다른 환경. 🎜🎜먼저 프로젝트의 루트 디렉터리에 proxy.conf.json
이라는 새 파일을 만듭니다. 🎜🎜인터페이스 요청 https://jimmyarea.com/api/public/article?page=-1
을 예로 들어 보겠습니다. 🎜ngOnInit():void { this.articleService.getArticleList().subscribe({ next: (data: any) => { console.log(data) }, error: () => {} }) // ... }
target
은 주소입니다. 프록시의 pathRewrite
는 프록시 접두사를 다시 작성합니다. 🎜🎜프록시 파일을 완성한 후에는 프록시를 활성화해야 합니다. package.json
에 명령줄을 하나 더 추가하여 개발 환경에서 디버깅에 사용됨을 나타냅니다. 🎜rrreee🎜npm run dev
를 실행하여 프로젝트를 시작하고 에이전트를 가져옵니다. 프록시 파일이 변경될 때마다 명령줄을 다시 시작해야 합니다~🎜🎜🎜확인🎜🎜🎜새 문서
를 만듭니다. > 서비스, article.service.ts
파일 내용은 다음과 같습니다: 🎜rrreee🎜위 요청, 페이지의 주소는 http://localhost:4200/api/public /article?page= -1
, 실제로 접속된 주소는 https://jimmyarea.com/api/public/article?page=-1
입니다. user-list.comComponent.ts
에서 호출하여 확인할 수 있습니다. 🎜rrreee🎜프로그램이 실행된 후 콘솔에서 다음 네트워크 요청을 볼 수 있습니다. 🎜🎜🎜🎜🎜🎜Good Job, Bro.🎜 백엔드에서 제공한 주소를 완벽하게 프록시하고 디버깅할 수 있으며, 프록시는 두 개 이상의 주소를 프록시할 수 있습니다. 독자는 여러 개의 프록시 주소를 작성하여 확인할 수 있습니다~🎜🎜[끝]🎜🎜더 많은 프로그래밍 관련 지식을 보려면 🎜프로그래밍 소개🎜를 방문하세요! ! 🎜위 내용은 Angular에서 Api 프록시를 사용하는 방법에 대한 간략한 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











기사는 JavaScript 라이브러리 작성, 게시 및 유지 관리, 계획, 개발, 테스트, 문서 및 홍보 전략에 중점을 둡니다.

이 기사는 브라우저에서 JavaScript 성능을 최적화하기위한 전략에 대해 설명하고 실행 시간을 줄이고 페이지로드 속도에 미치는 영향을 최소화하는 데 중점을 둡니다.

프론트 엔드 개발시 프론트 엔드 열지대 티켓 인쇄를위한 자주 묻는 질문과 솔루션, 티켓 인쇄는 일반적인 요구 사항입니다. 그러나 많은 개발자들이 구현하고 있습니다 ...

이 기사는 브라우저 개발자 도구를 사용하여 효과적인 JavaScript 디버깅, 중단 점 설정, 콘솔 사용 및 성능 분석에 중점을 둡니다.

기술 및 산업 요구에 따라 Python 및 JavaScript 개발자에 대한 절대 급여는 없습니다. 1. 파이썬은 데이터 과학 및 기계 학습에서 더 많은 비용을 지불 할 수 있습니다. 2. JavaScript는 프론트 엔드 및 풀 스택 개발에 큰 수요가 있으며 급여도 상당합니다. 3. 영향 요인에는 경험, 지리적 위치, 회사 규모 및 특정 기술이 포함됩니다.

이 기사는 소스 맵을 사용하여 원래 코드에 다시 매핑하여 미니어링 된 JavaScript를 디버그하는 방법을 설명합니다. 소스 맵 활성화, 브레이크 포인트 설정 및 Chrome Devtools 및 Webpack과 같은 도구 사용에 대해 설명합니다.

Console.log 출력의 차이의 근본 원인에 대한 심층적 인 논의. 이 기사에서는 Console.log 함수의 출력 결과의 차이점을 코드에서 분석하고 그에 따른 이유를 설명합니다. � ...

엔트리 레벨 타입 스크립트 자습서를 마스터 한 후에는 TypeScript를 지원하고 JavaScript로 컴파일하는 IDE에서 자신의 코드를 작성할 수 있어야합니다. 이 튜토리얼은 TypeScript의 다양한 데이터 유형으로 뛰어납니다. JavaScript에는 NULL, UNDEFINED, BOOLEAN, 번호, 문자열, 기호 (ES6에 의해 소개 됨) 및 객체의 7 가지 데이터 유형이 있습니다. TypeScript는이 기반으로 더 많은 유형을 정의 하며이 튜토리얼은이 모든 튜토리얼을 자세히 다룹니다. 널 데이터 유형 JavaScript와 마찬가지로 Null in TypeScript
