似乎不知道如何设置令牌在我的请求头



我正在遵循一本书教程,我目前正在为应用程序构建身份验证。每当我正确登录时,我似乎无法将令牌设置回请求。我得到的错误是:

Failed to execute 'setRequestHeader' on 'XMLHttpRequest': 'function () {
        return $window.localStorage.getItem('token');
    }' is not a valid HTTP header field value.

如有任何帮助,不胜感激

authService.js

angular.module('authService', [])
// ===================================================
// auth factory to login and get information
// inject $http for communicating with the API
// inject $q to return promise objects
// inject AuthToken to manage tokens
// ===================================================
.factory('Auth', function($http, $q, AuthToken) {
	// create auth factory obj
	var authFactory = {};
	// login user
	authFactory.login = function(username, password) {
		// return promise obj and its data
		return $http.post('/api/authenticate', {
			username: username,
			password: password
		})
		.success(function(data) {
			console.log(data);
			AuthToken.setToken(data.token);
			return data;
		});
	};
	
	// logout user by clearing token
	authFactory.logout = function() {
		AuthToken.setToken();
	};
	
	// check if user is logged in
	// checks for local token
	authFactory.isLoggedIn = function() {
		if (AuthToken.getToken())
			return true;
		else
			return false;
	};
	
	// get logged in user
	authFactory.getUser = function() {
		if (AuthToken.getToken())
			return $http.get('/api/me', { cache : true});
		else
			return $q.reject({ message : 'User has no token.'});
	};
	
	
	
	return authFactory;
})
// ===================================================
// factory for handling tokens
// inject $window to store token client-side
// 
// 
// ===================================================
.factory('AuthToken', function($window) {
	var authTokenFactory = {};
	
	// get token out of local storage
	authTokenFactory.getToken = function() {
		return $window.localStorage.getItem('token');
	};
	// function to set token or clear token
	 // if a token is passed, set the token
	 // if there is no token, clear it from local storage
	 
	 authTokenFactory.setToken = function(token) {
		 if (token)
		 	$window.localStorage.setItem('token', token);
		else
			$window.localStorage.removeItem('token');
	 };
	
	return authTokenFactory;
})
// ===================================================
// application configuration to integrate token into requests
// ===================================================
.factory('AuthInterceptor', function($q, $location, AuthToken) {
	var interceptorFactory = {};
	
	// this will happen on all http requests
	interceptorFactory.request = function(config) {
		// grab token
		var token = AuthToken.getToken;
		// if token exists add it to the header as x-access-token
		if (token)
			config.headers['x-access-token'] = token;
			
			return config;
	};
	
	// happens on response errors
	interceptorFactory.responseError = function(response) {
		// if 403 from server
		if (response.status == 403) {
			AuthToken.setToken();
			$location.path('/login')
		}
		//return the errors from server as promise
		return $q.reject(response);
	};
	
	return interceptorFactory;
});

app.js

var app = angular.module('userApp', [ 
	'ngAnimate', 'app.routes', 'authService', 'mainCtrl', 'userCtrl', 'userService']);
// app config to integrate token into req
app.config(function($httpProvider) {
	// attach our auth interceptor to the http reqs
	$httpProvider.interceptors.push('AuthInterceptor');
});
app.controller('mainController', function($http) {
	// Bind this to view / vm-view model
	var vm = this;
	
	// define variables and objects on this
	// this lets them be available to our views
	// define a basic variable
	vm.message = 'Hey! Message';
	
	$http.get('/api/users')
	.then(function(data) {
		// bind users to vm.users
		vm.users = data.users;
	});	
});

在自定义拦截器工厂

 interceptorFactory.request = function(config) {
            // grab token
            var token = AuthToken.getToken;
            // if token exists add it to the header as x-access-token
            if (token)
                config.headers['x-access-token'] = token;
                return config;
        };

change AuthToken.getToken; to AuthToken.getToken();

,你的错误是很明显,你传递函数到头,而不是值

Failed to execute 'setRequestHeader' on 'XMLHttpRequest': 'function () {
        return $window.localStorage.getItem('token');
    }' is not a valid HTTP header field value.

相关内容

  • 没有找到相关文章

最新更新