2017-12-17 31 views
0

SEOを使用するために、角度2+アプリケーションのサーバー側レンダリングを追加しようとしました。角度ユニバーサルでauth0を使用する方法

auth0-jsを使用しているため、問題が発生しました。

コンソール出力は、以下である:

ERROR { TypeError: Cannot read property 'location' of undefined at WebAuth.parseHash (C:\Dev\frontend\node_modules\auth0-js\src\web-auth\index.js:138:53) at e.handleAuthentication (C:\Dev\frontend\dist\server.js:8:523298) at new e (C:\Dev\frontend\dist\server.js:8:161974) at createClass (C:\Dev\frontend\node_modules\@angular\core\bundles\core.umd.js:12509:20) at createDirectiveInstance (C:\Dev\frontend\node_modules\@angular\core\bundles\core.umd.js:12) at createViewNodes (C:\Dev\frontend\node_modules\@angular\core\bundles\core.umd.js:13815:53) at createRootView (C:\Dev\frontend\node_modules\@angular\core\bundles\core.umd.js:13704:5) at Object.createProdRootView [as createRootView] (C:\Dev\frontend\node_modules\@angular\core\ s\core.umd.js:14397:12) at ComponentFactory_.create (C:\Dev\frontend\node_modules\@angular\core\bundles\core.umd.js:1 6) at ComponentFactoryBoundToModule.create (C:\Dev\frontend\node_modules\@angular\core\bundles\c d.js:4070:29) __zone_symbol__currentTask: ZoneTask { _zone: Zone { _properties: [Object], _parent: [Object], _name: 'angular', _zoneDelegate: [Object] }, runCount: 0, _zoneDelegates: null, _state: 'notScheduled', type: 'microTask', source: 'Promise.then', data: undefined, scheduleFn: undefined, cancelFn: null, callback: [Function], invoke: [Function] } } Unhandled Promise rejection: Cannot read property 'location' of undefined ; Zone: <root> ; Task: Promise.then ; Value: { TypeError: Cannot read property 'location' of undefined at WebAuth.parseHash (C:\Dev\frontend\node_modules\auth0-js\src\web-auth\index.js:138:53) at e.handleAuthentication (C:\Dev\frontend\dist\server.js:8:523298) at new e (C:\Dev\frontend\dist\server.js:8:161974) at createClass (C:\Dev\frontend\node_modules\@angular\core\bundles\core.umd.js:12509:20) at createDirectiveInstance (C:\Dev\frontend\node_modules\@angular\core\bundles\core.umd.js:12 354:37) at createViewNodes (C:\Dev\frontend\node_modules\@angular\core\bundles\core.umd.js:13815:53) at createRootView (C:\Dev\frontend\node_modules\@angular\core\bundles\core.umd.js:13704:5) at Object.createProdRootView [as createRootView] (C:\Dev\frontend\node_modules\@angular\core\ bundles\core.umd.js:14397:12) at ComponentFactory_.create (C:\Dev\frontend\node_modules\@angular\core\bundles\core.umd.js:1 1299:46) at ComponentFactoryBoundToModule.create (C:\Dev\frontend\node_modules\@angular\core\bundles\c ore.umd.js:4070:29) __zone_symbol__currentTask: ZoneTask { _zone: Zone { _properties: {}, _parent: null, _name: '<root>', _zoneDelegate: [Object] }, runCount: 0, _zoneDelegates: null, _state: 'notScheduled', type: 'microTask', source: 'Promise.then', data: undefined, scheduleFn: undefined, cancelFn: null, callback: [Function], invoke: [Function] } } TypeError: Cannot read property 'location' of undefined at WebAuth.parseHash (C:\Dev\frontend\node_modules\auth0-js\src\web-auth\index.js:138:53) at e.handleAuthentication (C:\Dev\frontend\dist\server.js:8:523298) at new e (C:\Dev\frontend\dist\server.js:8:161974) at createClass (C:\Dev\frontend\node_modules\@angular\core\bundles\core.umd.js:12509:20) at createDirectiveInstance (C:\Dev\frontend\node_modules\@angular\core\bundles\core.umd.js:12 354:37) at createViewNodes (C:\Dev\frontend\node_modules\@angular\core\bundles\core.umd.js:13815:53) at createRootView (C:\Dev\frontend\node_modules\@angular\core\bundles\core.umd.js:13704:5) at Object.createProdRootView [as createRootView] (C:\Dev\frontend\node_modules\@angular\core\ bundles\core.umd.js:14397:12) at ComponentFactory_.create (C:\Dev\frontend\node_modules\@angular\core\bundles\core.umd.js:1 1299:46) at ComponentFactoryBoundToModule.create (C:\Dev\frontend\node_modules\@angular\core\bundles\c ore.umd.js:4070:29) 

Iはauth0例からデフォルトのコードを使用する:

public handleAuthentication(): void { 
this.auth0.parseHash((err, authResult) => { 
    if (authResult && authResult.accessToken && authResult.idToken) { 
    window.location.hash = ''; 
    this.setSession(authResult); 
    this.router.navigate(['/']); 
    } else if (err) { 
    this.router.navigate(['/']); 
    console.log(err); 
    alert(`Error: ${err.error}. Check the console for further details.`); 
    } 
}); 

}

UPDATE:

をIユニバーサル角度添加しました私の正式なサービスにつきました。

は今、私はできるだけ早く私はローカルホストを開くと、次の新しいエラーを取得:4200:

ERROR { Error: Uncaught (in promise): Error 
at resolvePromise (C:\Dev\frontend\node_modules\zone.js\dist\zone-node.js:824:31) 
at resolvePromise (C:\Dev\frontend\node_modules\zone.js\dist\zone-node.js:795:17) 
at C:\Dev\frontend\node_modules\zone.js\dist\zone-node.js:873:17 
at ZoneDelegate.invokeTask (C:\Dev\frontend\node_modules\zone.js\dist\zone-node.js:425:31) 
at Object.onInvokeTask (C:\Dev\frontend\node_modules\@angular\core\bundles\core.umd.js:4783:33) 
at ZoneDelegate.invokeTask (C:\Dev\frontend\node_modules\zone.js\dist\zone-node.js:424:36) 
at Zone.runTask (C:\Dev\frontend\node_modules\zone.js\dist\zone-node.js:192:47) 
at drainMicroTaskQueue (C:\Dev\frontend\node_modules\zone.js\dist\zone-node.js:602:35) 
at ZoneTask.invokeTask (C:\Dev\frontend\node_modules\zone.js\dist\zone-node.js:503:21) 
at Server.ZoneTask.invoke (C:\Dev\frontend\node_modules\zone.js\dist\zone-node.js:488:48) rejection: { [Error] 
__zone_symbol__currentTask: 
    ZoneTask { 
    _zone: [Object], 
    runCount: 0, 
    _zoneDelegates: null, 
    _state: 'notScheduled', 
    type: 'microTask', 
    source: 'Promise.then', 
    data: undefined, 
    scheduleFn: undefined, 
    cancelFn: null, 
    callback: [Function], 
    invoke: [Function] } }, promise: ZoneAwarePromise { 
__zone_symbol__state: 0, 
__zone_symbol__value: { [Error] __zone_symbol__currentTask: [Object] } }, zone: Zone { 
_properties: { isAngularZone: true }, 
_parent: 
    Zone { 
    _properties: {}, 
    _parent: null, 
    _name: '<root>', 
    _zoneDelegate: [Object] }, 
_name: 'angular', 
_zoneDelegate: 
    ZoneDelegate { 
    _taskCounts: [Object], 
    zone: [Circular], 
    _parentDelegate: [Object], 
    _forkZS: null, 
    _forkDlgt: null, 
    _forkCurrZone: [Object], 
    _interceptZS: null, 
    _interceptDlgt: null, 
    _interceptCurrZone: [Object], 
    _invokeZS: [Object], 
    _invokeDlgt: [Object], 
    _invokeCurrZone: [Circular], 
    _handleErrorZS: [Object], 
    _handleErrorDlgt: [Object], 
    _handleErrorCurrZone: [Circular], 
    _scheduleTaskZS: [Object], 
    _scheduleTaskDlgt: [Object], 
    _scheduleTaskCurrZone: [Circular], 
    _invokeTaskZS: [Object], 
    _invokeTaskDlgt: [Object], 
    _invokeTaskCurrZone: [Circular], 
    _cancelTaskZS: [Object], 
    _cancelTaskDlgt: [Object], 
    _cancelTaskCurrZone: [Circular], 
    _hasTaskZS: [Object], 
    _hasTaskDlgt: [Object], 
    _hasTaskDlgtOwner: [Circular], 
    _hasTaskCurrZone: [Circular] } }, task: ZoneTask { 
_zone: 
    Zone { 
    _properties: [Object], 
    _parent: [Object], 
    _name: 'angular', 
    _zoneDelegate: [Object] }, 
runCount: 0, 
_zoneDelegates: null, 
_state: 'notScheduled', 
type: 'microTask', 
source: 'Promise.then', 
data: undefined, 
scheduleFn: undefined, 
cancelFn: null, 
callback: [Function], 
invoke: [Function] } } 

誰かがこの問題を解決する方法のアイデアを持っていますか?

感謝

答えて

1
サーバ側で

ウィンドウ、文書および他のブラウザのオブジェクトがdefiendされていません。

サーバー側またはクライアント側の場合にのみ実行できるプラットフォーム固有のコードを追加できます。

https://github.com/angular/universal#universal-gotchas

注:私は、サンプルコードを見ていないが、OUはとにかく

+0

ザッツ正しいの後に「/」にナビゲートしている場合、私はハッシュをresettignはここに有用であることさえわかりません。私はあなたと同じ考えをしました。私はすでにuniversal-gotchasを追加しましたが、httpclientの要求はありません。 –

関連する問題