Oauth 使用BreezeJS OData数据服务传递授权承载令牌
我如何告诉Breeze在使用OData数据服务时包含授权承载令牌头Oauth 使用BreezeJS OData数据服务传递授权承载令牌,oauth,odata,breeze,Oauth,Odata,Breeze,我如何告诉Breeze在使用OData数据服务时包含授权承载令牌头 //Configured breeze to use OData breeze.config.initializeAdapterInstance('dataService', 'OData'); //Configured breeze to use AngularJS ajax var instance = breeze.config.initializeAdapterInstance('ajax', 'angular', t
//Configured breeze to use OData
breeze.config.initializeAdapterInstance('dataService', 'OData');
//Configured breeze to use AngularJS ajax
var instance = breeze.config.initializeAdapterInstance('ajax', 'angular', true);
//Tried passing authorization bearer token header using setHttp with no success
//NOTE: $http setup with $http.defaults.headers.common['Authorization'] = 'Bearer...'
instance.setHttp($http);
//Tried passing authorization bearer token header using ajax settings with no success
instance.defaultSettings = {
headers: {
'Authorization': 'Bearer...'
},
};
//Fiddler shows no authorization bearer token header for following query
var manager = new breeze.EntityManager('/odata/');
var query = breeze.EntityQuery.from('Customers');
return manager.executeQuery(query).to$q(querySucceeded, queryFailed);
我不知道你是否解决了你的问题。这对我很有用:
function configureBreeze() {
// configure to use the model library for Angular
breeze.config.initializeAdapterInstance("modelLibrary", "backingStore", true);
var accessToken = Security.user.access_token;
if (Security.user.access_token) {
// get the current default Breeze AJAX adapter & add header required for the Web API bearer token mechanism
var ajaxAdapter = breeze.config.getAdapterInstance("ajax");
ajaxAdapter.defaultSettings = {
headers: {
'Authorization': 'Bearer ' + accessToken
},
};
}
}
它是对asp.net MVC4的datacontext.js脚本中的configureBreeze方法的修改
希望有帮助。我也有同样的问题。在查看了针对oData的breeze数据服务之后,我认为它只是忽略了ajax提供程序,因为它使用datajs来执行请求。所以
instance.setHttp($http)代码>不起作用。我最终覆盖了datajs中的默认request
方法,如下所示:
var base = window.OData.request;
window.OData.request = function (request, success, error, handler, httpClient, metadata) {
angular.extend(request.headers, { Authorization: $rootScope.token });
return base(request, success, error, handler, httpClient, metadata);
};
微风网站上有一个示例(在ODataAjax下):
但这并不使用oData数据服务。我想这就是问题中所描述的问题的原因你解决过你的问题吗?我也有同样的问题
var oldClient = OData.defaultHttpClient;
var myClient = {
request: function (request, success, error) {
request.headers.Authorization = authorization;
return oldClient.request(request, success, error);
}
};
OData.defaultHttpClient = myClient;
//instance.defaultSettings = {
// headers: {
// 'Authorization': 'Bearer...'
// },
//};
instance.headers['Authorization'] = 'Bearer...';