我使用Apigility创建了一个API。
我正在尝试为我正在使用API构建的前端应用程序设置身份验证系统。
我正在尝试为我正在使用API构建的前端应用程序设置身份验证系统。
但是我用于此认证系统的所有角度认证模块与Apigility oAuth 2实现不匹配:
> https://github.com/lynndylanhurley/ng-token-auth该模块的问题是它不允许CORS。但是它允许使用角色代码所在的服务器上的代理发送CORS请求,这是使用Guzzle在PHP中编写的。但是,代理ng-token-auth发送请求两次,即使所有验证数据都为false。
> https://github.com/sahat/satellizer此模块需要实现JWT,但在Apigility Authentication部分中,我没有看到任何文档。
我需要一个帮助来完成我的项目。
我将尝试给出一个完整的方法,我如何使
ng-token-auth与ZF2一起工作。首先,ng-token-auth使用ruby模块工作正常。所以要使它与ZF2工作:
//HttpProvider $httpProvider.defaults.useXDomain = true; $httpProvider.defaults.headers.common['Access-Control-Request-Method'] = "POST,GET,PUT,DELETE"; $httpProvider.defaults.headers.common['Origin'] = "http://xxxxxxxxxxxxxxx"; $httpProvider.defaults.headers.common['Accept'] = "application/json"; $httpProvider.defaults.headers.common['Content-Type'] = "application/json; text/html"; delete $httpProvider.defaults.headers.common['X-Requested-With'];
使用ZFCORS解决ZF2上的CORS问题,如@josilber和@ sven-lauterbach answer中所述
ZF2发送的格式响应,以使用这些代码行与ng-token-auth一起使用
$http.defaults.transformResponse = function(value,headerGetters){ var response_header = headerGetters(),response_data = JsonHelper.IsJsonString(value) ? JSON.parse(value) : value; if(response_data){ if(response_data.access_token) response_header['access_token'] = response_data.access_token; if(response_data.expires_in){ var now = new Date().getTime(); response_header['expires_in'] = now + ( parseInt(response_data.expires_in,10) * 1000 ); } if(response_data.token_type) response_header['token_type'] = response_data.token_type; if(response_data.refresh_token) response_header['refresh_token'] = response_data.refresh_token; if(response_data.scope) response_header['scope'] = response_data.scope; return response_data; } };
可能这不是在AngularJS中转换响应的最佳方法,但它解决了格式化OAuth2响应的问题,该功能与ng-token-auth
最后,要使用验证令牌向服务器发送请求,并自动刷新令牌,则需要更改ng-token-auth的某些行为。我使用AngularJS上的装饰图案来解决这些代码片段的问题:
在app.js中
//Change behavior of oauth2 module $provide.decorator("$auth",function($delegate,ApiAuthService){ return ApiAuthService($delegate); });
ApiAuthService是由这段代码定义的工厂:
AuthProviderService.factory('ApiAuthService',['MeService',function( MeService ){ return function($delegate){ return { initialize: function(){ return $delegate.initialize(); },apiUrl: function(configName){ },retrieveData: function(key){ return $delegate.retrieveData(key); },getConfig: function(name){ return $delegate.getConfig(name); },getExpiry: function(){ return $delegate.getExpiry(); },setAuthHeaders: function(h){ return $delegate.setAuthHeaders(h); },/*persistData: function(key,val,configName){ return $delegate.persistData(key,configName); },*/ rejectDfd: function(reason){ $delegate.rejectDfd(reason); },invalidateTokens: function(){ return $delegate.invalidateTokens(); },submitLogin: function(params,opts){ return $delegate.submitLogin(params,opts); },validateUser: function(opts){ result = $delegate.validateUser(opts); return result; },deleteData: function(key){ return $delegate.deleteData(key); } }; }; }]).config(['$httpProvider',function($httpProvider) { $httpProvider.interceptors.push([ '$injector',function($injector) { return { request: function(req) { $injector.invoke([ '$http','$auth',function($http,$auth) { var key,_ref,_results = []; if (req.url.match($auth.apiUrl())) { _ref = $auth.retrieveData('auth_headers'); //Inject value into body of request for (key in _ref) { //Set Authorization request header. if(key.match('access_token')){ if(req.headers){ req.headers['Authorization'] = 'Bearer ' + _ref[key]; }else{ req.headers = {'Authorization': 'Bearer ' + _ref[key]}; } } if(req.headers[key]){ delete req.headers[key]; } } return _results; } } ]); return req; } }; } ]); }]);
最后我的ng-token-auth配置是:
//OAuth2 Module configs $authProvider.configure([ { "default": { apiUrl: API_URL,tokenValidationPath: '/me',signOutUrl: '/oauth',emailRegistrationPath: '/oauth',accountUpdatePath: '/oauth',accountDeletePath: '/oauth',confirmationSuccessUrl: window.location.href,passwordResetPath: '/oauth',passwordUpdatePath: '/oauth',passwordResetSuccessUrl: window.location.href,emailSignInPath: '/oauth',forceHardRedirect: true,storage: 'localStorage',proxyIf: function() { return false; },proxyUrl: 'proxy',authProviderPaths: { github: '/auth/github',facebook: '/auth/facebook',google: '/auth/google' },tokenFormat: { "access_token" : "{{ token }}","token_type" : "Bearer","refresh_token": "{{ clientId }}","expires_in" : "{{ expiry }}","scope" : "{{ uid }}" },parseExpiry: function(headers) { var expires_in = parseInt(headers['expires_in'],10) || null; return expires_in; },handleLoginResponse: function(response) { //Patch for persistant data as library retreive auth data from header. return response; },handleAccountResponse: function(response) { return response; },handleTokenValidationResponse: function(response) { return response; } } } ]);
@JerinKAlexander我希望这些步骤将帮助您找到更好的方式来解决您的问题。