Search code examples
angularrequestintercept

intercept FormData from request body in angular


send

let formData = new FormData();
http.post - - - - - - - - - - - formData;

get

request = { body: FormData }

I want to do in angular intercept

if(FormData's value instanceof File) {
    pass without intercept
}

how can I do it?

or

request = { body : FileFormData(ex: FormData only for File) }


Solution

  • Use a HttpInterceptor

    import { Injectable } from '@angular/core';
    import {
      HttpEvent, HttpInterceptor, HttpHandler, HttpRequest
    } from '@angular/common/http';
    
    import { Observable } from 'rxjs';
    
    @Injectable()
    export class FormDataInterceptor implements HttpInterceptor {
    
      intercept(req: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {
        // FormData's value instanceof File, something along the lines of
        if(req.body instanceof File) {
            return next.handle(req);
        }
        // Do intended logic here
        return next.handle(req);
      }
    }
    

    Then register the interceptor: app.module.ts

    providers: [
       { provide: HTTP_INTERCEPTORS, useClass: FormDataInterceptor, multi: true }
    ]