应用请求标头angular 6

时间:2018-05-17 18:05:07

标签: angular angular6

我对angular相当新,我使用的是最新版本。

我正在尝试执行帖子请求,但我遇到了CORS问题。我认为问题是因为我的请求标头中没有内容类型,我想将其添加到我的代码中。

在以前的版本中,此方法可以使用但不再适用。如何在Angular 6中正确应用标题?

我收到以下错误

  

"类型的参数' {header:any; }'不能分配给' RequestOptionsArgs'类型的参数。"

import { Injectable } from '@angular/core';
import { environment } from '../environments/environment';

import { User } from './user';
import { Http } from '@angular/http';
import { HttpClient, HttpHeaders, HttpErrorResponse } from '@angular/common/http';
import { Observable } from 'rxjs';
import { map, catchError } from "rxjs/operators";



const API_URL = environment.apiUrl;

@Injectable({
  providedIn: 'root'
})
export class ApiService {

  constructor(private http: Http) {

  }

  public createUser(user: User): Observable<User> {
    let getHeaders: HttpHeaders = new HttpHeaders({
      'Content-Type': 'application/json'
    });
    return this.http
     .post(API_URL + '/users', user, {header: getHeaders}).pipe(
        map(response => {
          return new User(response.json());
        }), catchError(this.handleError)
      )
  }

1 个答案:

答案 0 :(得分:4)

app / json会自动应用于HttpClient请求,因此您无需执行此操作。

话虽如此,您使用的是错误的Http导入。 应该是:

if()else{}