在 Ionic 应用程序中一起使用 CORS 和 CSRF

2024-02-19

我正在开发一个 Android 应用程序,使用离子框架 http://ionicframework.com/基于我开发的 AngularJS 网站Jhipster https://jhipster.github.io/。由于我的 Web 应用程序中已经运行了服务器代码,因此我选择 Ionic 作为 UI 并在需要时调用服务器,但我的开发环境中遇到了一些问题。

  1. 当我使用离子服务运行我的应用程序时,我需要使用CORS https://pt.wikipedia.org/wiki/Cross-origin_resource_sharing向服务器发出请求。
  2. 我的 Web 应用程序是使用 CSRF 令牌和 Spring Security 开发的

我在用着Apache CORS 过滤器 https://tomcat.apache.org/tomcat-7.0-doc/config/filter.html#CORS_Filter这样配置:

private void initCORSFilter(ServletContext servletContext, EnumSet<DispatcherType> disps) {
    FilterRegistration.Dynamic corsFilter = servletContext.addFilter("cors", new CorsFilter());
    Map<String, String> parameters = new HashMap<>();
    parameters.put("cors.allowed.origins", "http://localhost:3000");
    parameters.put("cors.allowed.headers", "x-auth-token, x-requested-with, Content-Type, Accept, cache-control, x-csrf-token, Origin, Access-Control-Request-Method, Access-Control-Request-Headers");
    parameters.put("cors.allowed.methods", "POST, PUT, GET, DELETE");
    parameters.put("cors.exposed.headers", "Access-Control-Allow-Origin, Access-Control-Allow-Credentials");
    parameters.put("cors.support.credentials", "true");
    corsFilter.setInitParameters(parameters);
    corsFilter.addMappingForUrlPatterns(disps, true, "/*");
}

然后我用了角度 csrf 跨域 https://github.com/pasupulaphani/angular-csrf-cross-domain帮助处理跨域 csrf 请求的插件:

.config(function ($urlRouterProvider,csrfCDProvider) {
    $urlRouterProvider.otherwise('/');
    //enable CSRF
    csrfCDProvider.setHeaderName('X-CSRF-TOKEN');
    csrfCDProvider.setCookieName('CSRF-TOKEN');
});

然后我尝试向本地服务器发送发布请求:

angular.module('consamiApp')
.factory('Register', function ($resource) {
    //globalURL is https://localhost:8080
    return $resource(globalURL+'api/register', {}, {
    });
});
.
.
.
createAccount: function (account, callback) {
    var cb = callback || angular.noop;

    return Register.save(account,
        function () {
            return cb(account);
        },
        function (err) {
            this.logout();
            return cb(err);
    }.bind(this)).$promise;
}

但是我在 Firefox 控制台中收到此消息:

跨域锁定请求:同源策略(Same Origin Policy)阻止读取远程资源https://localhost:8080/api/register https://localhost:8080/api/register。 (原因:CORS 标头“Access-Control-Allow-Origin”不存在)

新的信息

当我提交正在测试的表单时,AngularJs 向服务器发出 2 个 CORS 请求:OPTIONS 和 POST,请求的结果是 200 OK 和 403 Forbidden。这些是 2 个请求和响应的标头:

选项请求标头:

Host: localhost:8080
User-Agent: Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:38.0) Gecko/20100101 Firefox/38.0
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Language: pt-BR,pt;q=0.8,en-US;q=0.5,en;q=0.3
Accept-Encoding: gzip, deflate
Origin: http://localhost:3000
Access-Control-Request-Method: POST
Access-Control-Request-Headers: content-type
Connection: keep-alive
Pragma: no-cache
Cache-Control: no-cache

选项答案标题:

Access-Control-Allow-Origin: http://localhost:3000
Content-Length: 0
Date: Tue, 30 Jun 2015 22:07:58 GMT
Server: Apache-Coyote/1.1
Set-Cookie: JSESSIONID=485A653AEAC8B8756DD3057BBF7FB862; Path=/; Secure; HttpOnly
CSRF-TOKEN=e8b3396c-63b2-47bf-9ad6-c1454628eb3b; Path=/
X-Application-Context: application:dev:8080
access-control-allow-credentials: true
access-control-allow-headers: origin,access-control-request-headers,x-requested-with,x-csrf-token,content-type,access-control-request-method,cache-control,x-auth-token,accept
access-control-allow-methods: POST
access-control-max-age: 1800

POST 请求标头:

Host: localhost:8080
User-Agent: Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:38.0) Gecko/20100101 Firefox/38.0
Accept: application/json, text/plain, */*
Accept-Language: pt-BR,pt;q=0.8,en-US;q=0.5,en;q=0.3
Accept-Encoding: gzip, deflate
Content-Type: application/json;charset=utf-8
Referer: http://localhost:3000/
Content-Length: 109
Origin: http://localhost:3000
Cookie: _ga=GA1.1.123103160.1428358695; connect.sid=s%3AwD4KP4WBfhGO0JpFND3LpCzW.augts9fos9NMaZw%2B7XrNuilgaM8ocwSxaEUeDlIaVJ4; JSESSIONID=93200F4F4AFCEB28F10B130841808621
Connection: keep-alive
Pragma: no-cache
Cache-Control: no-cache

发布答案标题:

Content-Type: application/json;charset=UTF-8
Date: Tue, 30 Jun 2015 22:07:58 GMT
Server: Apache-Coyote/1.1
Transfer-Encoding: chunked

有什么我没注意到的吗?这Ionic 官方博客 http://blog.ionic.io/handling-cors-issues-in-ionic/说我在部署应用程序时不应该担心 CORS 问题,但至少对于测试来说,我确实需要解决这个问题。你能给我一些选择吗?


您安装并配置了吗cordova插件白名单 https://github.com/apache/cordova-plugin-whitelist从 Cordova 5.0.0 开始,CORS 查询是必需的

安装它:

cordova plugin add cordova-plugin-whitelist

配置config.xml

您可以使用 * 保留当前设置或更改更多限制性规则

添加 html 策略在index.html 上,您还应该添加一个策略。 要授权一切,这里是:

 <meta http-equiv="Content-Security-Policy" content="default-src *;
 style-src 'self' 'unsafe-inline'; script-src 'self' 'unsafe-inline'
 'unsafe-eval'"

要验证您是否已正确安装该插件,请使用以下命令将其签入您的 cordova 插件:

cordova plugins 

您将在其中看到 cordova-plugin-whitelist。

其次,您可能需要添加withCredentials给你的$http(因此 $resource)查询:

  .config(function($httpProvider) {
        $httpProvider.defaults.withCredentials = true;
    });
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

在 Ionic 应用程序中一起使用 CORS 和 CSRF 的相关文章

随机推荐