fengxiang
2018-05-28 b076f355b7b438b45e430cbd1c441ef5ff34b6fe
登录过期相应
1 files modified
35 ■■■■ changed files
src/app/core/net/default.interceptor.ts 35 ●●●● patch | view | raw | blame | history
src/app/core/net/default.interceptor.ts
@@ -7,22 +7,44 @@
import { of } from 'rxjs/observable/of';
import { ErrorObservable } from 'rxjs/observable/ErrorObservable';
import { mergeMap, catchError } from 'rxjs/operators';
import { NzMessageService } from 'ng-zorro-antd';
import { NzMessageService, NzModalService } from 'ng-zorro-antd';
import { _HttpClient } from '@delon/theme';
import { environment } from '@env/environment';
import { LoginService } from '@business/services/http/login.service';
import { Subject } from 'rxjs/Subject';
import { error } from 'protractor';
import { debug } from 'util';
/**
 * 默认HTTP拦截器,其注册细节见 `app.module.ts`
 */
@Injectable()
export class DefaultInterceptor implements HttpInterceptor {
    constructor(private injector: Injector) {}
    private unLoginHandle: Subject<HttpErrorResponse> = new Subject<HttpErrorResponse>();
    constructor(private injector: Injector) {
         this.unLoginHandle.debounceTime(100).subscribe(event => {
             if (!!event.error) {
                  let errorMsg = '';
                  const erroCode = <number>event.error['errorCode'];
                  switch (erroCode) {
                     case 10: errorMsg = '未登录,请登录'; break;
                     case 11: errorMsg = '登录过期,请重新登录'; break;
                     case 12: errorMsg = '账号过期,请联系供应商'; break;
                  }
                  this.model.info({
                    title: errorMsg,
                    onOk: () => this.goTo('/passport/login')
                  });
             }
         });
    }
    get msg(): NzMessageService {
        return this.injector.get(NzMessageService);
    }
    get model(): NzModalService {
        return this.injector.get(NzModalService);
    }
    private goTo(url: string) {
        setTimeout(() => this.injector.get(Router).navigateByUrl(url));
    }
@@ -45,7 +67,8 @@
                // }
                break;
            case 401: // 未登录状态码
                this.goTo('/passport/login');
            // this.goTo('/passport/login');
                this.unLoginHandle.next(<HttpErrorResponse>event);
                break;
            case 403:
            case 404:
@@ -69,9 +92,9 @@
        }        
        // 统一加上服务端前缀
        let url = req.url;
        if (!url.startsWith('https://') && !url.startsWith('http://')&& !url.startsWith('assets')) {
        if (!url.startsWith('https://') && !url.startsWith('http://') && !url.startsWith('assets')) {
            // url = environment.SERVER_URL + url;
            url = environment.SERVER_BASH_URL+url;
            url = environment.SERVER_BASH_URL + url;
        }
        const newReq = req.clone({