В угловом 5, когда я вышел из системы от одного пользователя и вошел в систему от другого пользователя, он отображает учетные данные предыдущего пользователя вместо текущего пользователя, пока я не обновлю страницу. Я использую localstorage.clear()
метод. Все еще не работает.
Здесь это функция входа в систему
login(userLogin: LoginModel) {
const objectToSend = JSON.stringify(userLogin);
const headers = new Headers();
headers.append('Content-Type', 'application/json');
headers.append('withCredentials', 'true');
// tslint:disable-next-line:max-line-length
return this.http.post( this.appURL+'/api/auth/login', objectToSend, { headers: headers }).pipe(
map((response: Response) => {
// login successful if there's a jwt token in the response
const response_token = response.json();
console.log(response_token);
const accessToken = response_token.auth_token;
if (accessToken == null) {
throw new Error('Received accessToken was empty');
}
// let refreshToken: string = response_token.refresh_token;
const expiresIn: number = response_token.expires_in;
const tokenExpiryDate = new Date();
tokenExpiryDate.setSeconds(tokenExpiryDate.getSeconds() + expiresIn);
const accessTokenExpiry = tokenExpiryDate;
localStorage.setItem('auth_token', response_token.auth_token);
localStorage.setItem('role', response_token.role);
this.loggedIn = true;
this._authNavStatusSource.next(true);
this.router.navigate(['/orderhistory']);
return true;
}));
}
А это функция выхода из системы
logout() {
localStorage.removeItem('auth_token');
localStorage.removeItem('role');
localStorage.clear();
sessionStorage.clear();
this.loggedIn = false;
this._authNavStatusSource.next(false);
}
это компонент, в котором роль пользователя не обновляется соответствующим образом.
@Component({
selector: 'app-order',
templateUrl: './order.component.html',
styleUrls: ['./order.component.scss']
})
export class OrderComponent implements OnInit {
form: FormGroup;
currentRole: string;
constructor(private formBuilder: FormBuilder,
private route: ActivatedRoute,
private router: Router,
private userService: UserService, private http: HttpClient) {
}
ngOnInit() {
this.form = this.formBuilder.group({
quantity: [null, Validators.required],
prescription: [null],
});
this.currentRole = this.userService.Role;
}
and this is the template. and this role is not updating after logout
<form [formGroup]="form" class="form-horizontal">
<span *ngIf="currentRole =='administrator'">
<div class="form-group row">
<label class="col-md-3 col-form-label">Client Name</label>
<div class="col-md-3">
<label class="col-form-label">{{orderModel.clientName}}</label>
</div>
</div>
</span>
<span>{{currentRole}}</span>
<form>