2016-07-19 7 views
2

Я хочу использовать aurelia-auth в своем приложении, а также иметь страницу входа, которая полностью отделена от остальной части приложения. Я следую учебному курсу по этой ссылке: https://auth0.com/blog/2015/08/05/creating-your-first-aurelia-app-from-authentication-to-calling-an-api/Маршрутизатор Aurelia не работает при перезагрузке root

Проблема, с которой я столкнулась, - после того, как я успешно выполнил вход и попытаюсь выполнить маршрутизацию в приложение, ни один из маршрутов не найден. Я получаю маршрут не найден независимо от того, что я набрал для URL-адреса перенаправления входа.

Вот мой код:

app.js:

... 
import { Router } from 'aurelia-router'; 
import { AppRouterConfig } from './router-config'; 
import { FetchConfig } from 'aurelia-auth'; 

... 

@inject(..., Router, AppRouterConfig, FetchConfig) 
export class App { 
    constructor(router, appRouterConfig, FetchConfig) { 
     this.router = router; 
     this.appRouterConfig = appRouterConfig; 
     this.fetchConfig = fetchConfig; 

     ... 
    } 

    activate() { 
     this.fetchConfig.configure(); 
     this.appRouterConfig.configure(); 
    } 

    ... 

} 

login.js:

import { AuthService } from 'aurelia-auth'; 
import { Aurelia } from 'aurelia-framework'; 
... 

@inject(..., Aurelia, AuthService) 
export class LoginScreen { 
    constructor(..., aurelia, authService) { 
     this.aurelia = aurelia; 
     this.authService = authService; 
     ... 
    } 

    login() { 
     return this.authService.login(this.username, this.password) 
      .then(response => { 
       console.log("Login response: " + response); 
       this.aurelia.setRoot('app'); 
      }) 
      .catch(error => { 
       this.loginError = error.response; 
       alert('login error = ' + error.response); 
      }); 
    } 

    ... 

} 

main.js:

import config from './auth-config'; 
import { AuthService } from 'aurelia-auth'; 
import { Aurelia } from 'aurelia-framework'; 
... 

export function configure(aurelia) { 
    aurelia.use 
     .defaultBindingLanguage() 
     .defaultResources() 
     .developmentLogging() 
     .router() 
     .history() 
     .eventAggregator() 
     ... 
     .plugin('aurelia-auth', (baseConfig) => { 
      baseConfig.configure(config); 
     }); 


    let authService = aurelia.container.get(AuthService); 
    aurelia.start() 
     .then(a => { 
      if (authService.isAuthenticated()) { 
       a.setRoot('app'); 
      } else { 
       a.setRoot('login'); 
      } 
     }); 
} 

Auth-конфигурации. js:

var config = { 
    baseUrl: 'http://localhost:3001', 
    loginUrl: 'sessions/create', 
    tokenName: 'id_token', 
    //loginRedirect: '#/home' //looks like aurelia-auth defaults to #/ which is fine for me 
} 

export default config; 

маршрутизатор-config.js:

import { AuthorizeStep } from 'aurelia-auth'; 
import { inject } from 'aurelia-framework'; 
import { Router } from 'aurelia-router'; 

@inject(Router) 
export class AppRouterConfig { 
    constructor(router) { 
     this.router = router; 
    } 

    configure() { 
     console.log('about to configure router'); 

     var appRouterConfig = function (config) { 
      config.title = 'My App'; 

      config.addPipelineStep('authorize', AuthorizeStep); 

      config.map([ 
       { 
        route: ['', 'home'], 
        name: 'home', 
        moduleId: '.components/home/home', 
        nav: true, 
        title: 'Home', 
        auth: true 
       }, 
       { 
        route: ['employees'], 
        name: 'employees', 
        moduleId: './components/employees/employees', 
        nav: true, 
        title: 'Employees', 
        auth: true 
       } 
      ]); 

      this.router.configure(appRouterConfig); 
     } 
    }; 
} 

При загрузке приложения, оно успешно идет на страницу входа в систему, и я смог успешно войти в систему, и он пытается перенаправить, но я получаю эту ошибку в консоль:

ERROR [app-router] Error: Route not found:/
    at AppRouter._createNavigationInstruction (http://127.0.0.1:8080/jspm_packages/npm/[email protected]/aurelia-router.js:1039:29) 
    at AppRouter.loadUrl (http://127.0.0.1:8080/jspm_packages/npm/[email protected]/aurelia-router.js:1634:19) 
    at BrowserHistory._loadUrl (http://127.0.0.1:8080/jspm_packages/npm/[email protected]/aurelia-history-browser.js:301:55) 
    at BrowserHistory.activate (http://127.0.0.1:8080/jspm_packages/npm/[email protected]/aurelia-history-browser.js:200:21) 
    at AppRouter.activate (http://127.0.0.1:8080/jspm_packages/npm/[email protected]/aurelia-router.js:1689:20) 
    at eval (http://127.0.0.1:8080/jspm_packages/npm/[email protected]/aurelia-router.js:1670:21) 
    at AppRouter.registerViewPort (http://127.0.0.1:8080/jspm_packages/npm/[email protected]/aurelia-router.js:1672:10) 
    at new RouterView (http://127.0.0.1:8080/jspm_packages/npm/[email protected]/router-view.js:112:19) 
    at Object.invokeWithDynamicDependencies (http://127.0.0.1:8080/jspm_packages/npm/[email protected]/aurelia-dependency-injection.js:329:20) 
    at InvocationHandler.invoke (http://127.0.0.1:8080/jspm_packages/npm/[email protected]/aurelia-dependency-injection.js:311:168)error @ aurelia-logging-console.js:54log @ aurelia-logging.js:37error @ aurelia-logging.js:70(anonymous function) @ aurelia-router.js:1637 
aurelia-logging-console.js:54 ERROR [app-router] Router navigation failed, and no previous location could be restored. 

Я вокруг прибегая к помощи совсем немного ответов на это, но с трудом найти хорошие ответы. У кого-нибудь есть идеи? Любая помощь приветствуется!

ответ

3

Я думаю, проблема в том, что вы настраиваете маршрутизатор внутри метода activate(). На мой взгляд, нет необходимости делать это.

Вы можете перемещаться по маршруту после сброса корневой компонент:

this.aurelia.setRoot('./login') 
    .then((aurelia) => { 
    aurelia.root.viewModel.router.navigateToRoute('someLoginRoute'); 
    }); 

Вы также можете использовать mapUnknownRoutes, что очень полезно:

configureRouter(config, router) { 
     config.title = "Super Secret Project"; 
     config.map([ 
      { route: [ '', 'screen-1'], moduleId: "./screen-1", nav: true, title: "Beginscherm" }, 
      { route: 'screen-2', name:'screen-2', moduleId: "./screen-2", nav: true, title: "Beginscherm" } 
     ]); 

     config.mapUnknownRoutes(instruction => { 
     return './screen-1'; 
     }); 

     this.router = router;   
    } 

Смотрите этот пример https://gist.run/?id=00b8b3745a480fb04184e8440e8be8c5. Обратите внимание на функции входа/выхода.

Надеюсь, это поможет!

+0

Я сейчас не на своем компьютере, чтобы опробовать ваш advicr, но где мне настроить маршрутизатор, если я не делаю этого в методе активации? – A2345sooted

+0

Не можете ли вы просто использовать метод configureRouter ?. Или, может быть, вызов функции в методе конструктора –

+0

Работает конструктор! Большое спасибо, сэр. Я стучал головой об этом. Еще новенький в аурелии. Я очень ценю эту помощь. Он работает сейчас. – A2345sooted

0

U может решить эту проблему путем перезагрузки или обновления приложения. после установки приложения т.е. a.setRoot ('приложение'); location.reload();

+0

это, кажется, не работает, но я не уверен, что я перезагружаюсь правильно или в нужном месте ... Я добавил document.location.reload() сразу после установки корневого приложения, я также попробовал положив его сразу после вызова configure на appRouterConfig ... я также попытался поместить его сразу после вызова this.router.configure в файле router-config.js – A2345sooted

+0

или вы можете настроить ur ruter, как config.mapUnknownRoutes (инструкция => { instruction.config.moduleId = '.компоненты/дома/дома '; инструкция по возврату; }) –