gpt4 book ai didi

angular ngrx-store-localstorage 在重新加载后不存储数据

转载 作者:太空狗 更新时间:2023-10-29 17:06:43 24 4
gpt4 key购买 nike

我正在尝试使用 ngrx-store-localstorage 将 ngrx 集成到我的身份验证过程中,以跨浏览器 session 存储 token 。

当我登录时,我可以看到存储中 token 的值,如

{"token":{"token":"e5cb6515-149c-44df-88d1-4ff16ff4169b","expiresIn":10385,"expiresAt":1512082478397},"authenticated":true,"error":false}

但是当我编辑一个页面并重新加载应用程序时,我得到了

{"token":null,"authenticated":false,"error":false}

代码操作

import { Action } from '@ngrx/store';

import { AuthenticationTokenInterface } from '../authentication.interface';

export const LOGIN = 'LOGIN';
export const LOGIN_SUCCESS = 'LOGIN_SUCCESS';
export const LOGIN_FAILED = 'LOGIN_FAILED';
export const LOGOUT = 'LOGOUT';
export const SET_TOKEN = 'SET_TOKEN';

export class Login implements Action {
readonly type = LOGIN;
constructor(public payload: {username: 'string',password: 'string'}) {}
}

export class LoginSuccess implements Action {
readonly type = LOGIN_SUCCESS;
}

export class LoginFailed implements Action {
readonly type = LOGIN_FAILED;
}

export class Logout implements Action {
readonly type = LOGOUT;
}

export class SetToken implements Action {
readonly type = SET_TOKEN;

constructor(public payload: AuthenticationTokenInterface) {}
}

export type AuthenticationActions = Login | LoginSuccess | LoginFailed | Logout | SetToken;

效果

@Injectable()
export class AuthenticationEffects {
@Effect()
login$ = this.actions$.ofType(AuthenticationActions.LOGIN)
.pipe(
mergeMap((action: AuthenticationActions.Login) => {
return this.authenticationService.login(action.payload)
.pipe(
mergeMap((token:AuthenticationTokenInterface) => {
this.router.navigate(['/main/dashboard']);
return [
{ type: AuthenticationActions.LOGIN_SUCCESS },
{ type: AuthenticationActions.SET_TOKEN, payload: token }
]
}),
catchError(() => {
return of({ type: AuthenticationActions.LOGIN_FAILED })
})
)
})
);
@Effect({dispatch: false})
logout$ = this.actions$.ofType(AuthenticationActions.LOGOUT)
.pipe(
switchMap(()=>{
this.router.navigate(['/logout']);
return this.authenticationService.logout();
})
);

constructor(
private actions$: Actions,
private router: Router,
private authenticationService: AuthenticationService
) {}
}

reducer

export interface State {
token: AuthenticationTokenInterface;
authenticated: boolean;
error: boolean;
}

const initialState: State = {
token: null,
authenticated: false,
error: false
};

export function authenticationReducer(
state = initialState,
action: AuthenticationActions.AuthenticationActions
):State {
switch (action.type) {
case (AuthenticationActions.LOGIN_SUCCESS):
return {
...state,
authenticated: true,
};
case (AuthenticationActions.LOGIN_FAILED):
return {
...state,
error: true
};
case (AuthenticationActions.LOGOUT):
return {
...state,
token: null,
authenticated: false
};
case (AuthenticationActions.SET_TOKEN):
return {
...state,
token: action.payload
};
default:
return state;
}
}

reducer (应用程序)

export interface AppState {
authentication: fromAuthentication.State
}

export const reducers: ActionReducerMap<AppState> = {
authentication: fromAuthentication.authenticationReducer
};

应用模块

export function localStorageSyncReducer(reducer: ActionReducer<any>): ActionReducer<any> {
return localStorageSync({keys: ['authentication']})(reducer);
}
const metaReducers: Array<MetaReducer<any, any>> = [localStorageSyncReducer];

imports: [
StoreModule.forRoot(
reducers,
{metaReducers}
),
EffectsModule.forRoot([AuthenticationEffects]),
]

最佳答案

您需要将 rehydrate 键添加到 localStorageSync 函数调用。

export function localStorageSyncReducer(reducer: ActionReducer<any>): ActionReducer<any> {
return localStorageSync(
{keys: ['authentication'],
rehydrate: true})(reducer);
}

参见:https://github.com/btroncone/ngrx-store-localstorage/blob/master/README.md了解详情。

关于angular ngrx-store-localstorage 在重新加载后不存储数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47581804/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com