Как добавить что-то в тело запроса внутри углового перехватчика? - PullRequest
0 голосов
/ 05 ноября 2018

Здесь я могу изменить заголовок, так как есть несколько учебных пособий, касающихся этой функции, но:

@Injectable()
export class MyFirstInterceptor implements HttpInterceptor {

    constructor(private currentUserService: CurrentUserService) { }

    intercept(req: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {
        console.log(JSON.stringify(req));

        const token: string = this.currentUserService.token;

        if (token) {
            req = req.clone({ headers: req.headers.set('Authorization', 'Bearer ' + token) });
        }

        if (!req.headers.has('Content-Type')) {
            req = req.clone({ headers: req.headers.set('Content-Type', 'application/json') });
        }

        req = req.clone({ headers: req.headers.set('Accept', 'application/json') });
        return next.handle(req);
    }
}

Но в моем случае есть токен, который мне нужен, чтобы добавить тело запроса вместо заголовка запроса, поэтому есть ли способ изменить тело.

Обновление: метод Mild Fuzz отлично работает для простого пост-запроса но я хотел бы добавить к запросу, если это запрос GET и тело, если оно позволяет добавить тело. И самое главное это сломалось, когда я пытался отправить данные формы. ...request.body удаляет данные формы и преобразует его в JSON объект, поэтому мое изображение исчезло.

Ответы [ 3 ]

0 голосов
/ 15 ноября 2018

Вот рабочий пример:

intercept(req: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {
        const clonedreq = req.clone({
            headers: req.headers.set("Authorization", "Bearer " + sessionStorage.getItem('userToken'))
        });
        return next.handle(clonedreq)
            .do(
            succ => {
                if(succ["status"] != null && succ["status"] != undefined){
                    this.loaderService.handleResponse('regular');
                }
             },
            err => {
                if (err.status === 401)
                    this.router.navigateByUrl('/Login');
                this.loaderService.handleResponse('regular');
            }
        );
}
0 голосов
/ 15 ноября 2018

Благодаря Mild Fuzz это было то, что я хотел, но в моем случае у меня были некоторые сложности, которые я смог решить с некоторой дополнительной головной болью. Вот моя последняя реализация:

  intercept(
    req: HttpRequest<any>, 
    next: HttpHandler
  ): Observable<HttpEvent<any>> {

    console.log('Intercepted!', req);
    const authService = this.injector.get(AuthService);
    const reqCloned =  this.handleBodyIn(req, localStorage.getItem('random_key'), 'random_key_added');
    const copiedReq = reqCloned;
    return next.handle(copiedReq);
  }
  handleBodyIn(req:HttpRequest<any>, tokenToAdd, tokenName) {
    if (req.method.toLowerCase() === 'post') {
      if (req.body instanceof FormData) {
        req =  req.clone({
          body: req.body.append(tokenName, tokenToAdd)
        })
      } else {
        const foo = {}; foo[tokenName] = tokenToAdd;
        req =  req.clone({
          body: {...req.body, ...foo}
        })
      }            
    } 
    if (req.method.toLowerCase() === 'get') {
      req = req.clone({
        params: req.params.set(tokenName, tokenName)
      });
    } 
    return req;    
  }
}

Вот ссылка редактора, если кто-то еще хочет проверить.

0 голосов
/ 05 ноября 2018
 req = req.clone({ 
  headers: req.headers.set('Accept', 'application/json'),
  body: {...req.body, hello: 'world' }});

как то так?

...