无法在IOS上通过CORS发送凭据

问题描述

我遇到了难题,经过很长一段时间解决这个问题,我才来找你。

我有一个符合以下规范的Hybrid App:

-Ionic 3.9.2
-Angular 5.2.11
-Cordova Android 8.1.0 and iOS 5.1.1
-Cordova 8.0.0

我的应用程序向SOAP后端发出请求,该后端由受保护的cookie JSESSIONID(Tomcat服务器)保护。

我必须启用CORS,以便我的请求能够到达后端,这是Tomcat CORS过滤器:

<filter>
  <filter-name>CorsFilter</filter-name>
  <filter-class>org.apache.catalina.filters.CorsFilter</filter-class>
    <init-param>
        <param-name>cors.allowed.origins</param-name>
        <param-value>ionic://localhost,http://localhost</param-value>
    </init-param>
    <init-param>
        <param-name>cors.allowed.methods</param-name>
        <param-value>GET,POST,HEAD,OPTIONS,PUT</param-value>
    </init-param>
    <init-param>
        <param-name>cors.allowed.headers</param-name>
        <param-value>Content-Type,X-Requested-With,accept,Origin,Access-Control-Request-Method,Access-Control-Request-Headers,SOAPAction,Cache-Control</param-value>
    </init-param>
    <init-param>
        <param-name>cors.exposed.headers</param-name>
        <param-value>Access-Control-Allow-Origin,Access-Control-Allow-Credentials</param-value>
    </init-param>
    <init-param>
        <param-name>cors.support.credentials</param-name>
        <param-value>true</param-value>
    </init-param>
    <init-param>
        <param-name>cors.preflight.maxage</param-name>
        <param-value>10</param-value>
    </init-param>
</filter>
<filter-mapping>
  <filter-name>CorsFilter</filter-name>
  <url-pattern>/*</url-pattern>
</filter-mapping>

当我登录到后端时,服务器会设置一个cookie(JSESSION),该cookie用于发送后续请求以在安全WS中对后端进行身份验证。 这是用httpclient angular发出请求的代码(与后续请求相同)

 this.http.post(wsurl,xml,{
        withCredentials: true,responseType: 'text',headers: headers,observe: 'response'
      })
        .toPromise()
        .then(response => {})
        .catch(err =>{})

我的问题是,启用CORS后,后端无法在iOS / Safari上对我的后续请求进行身份验证(Android,Chrome可以正常运行)

但这是警察:

在iPhone 6 iOS v12.4.5上部署的应用程序的同一版本 工作正常。在具有iOS v 14和模拟器(任何版本)的iPhone X上不起作用。

后端返回此错误:

<?xml version="1.0" encoding="UTF-8"?>
<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
    <soapenv:Body>
        <soapenv:Fault>
            <faultcode>soapenv:Server.generalException</faultcode>
            <faultstring>User has not a valid M4Session</faultstring>
            <detail>
                <ns1:exceptionName xmlns:ns1="http://xml.apache.org/axis/">com.meta4.soapservices.exception.M4SoapException</ns1:exceptionName>
                <ns2:hostname xmlns:ns2="http://xml.apache.org/axis/">cd102015</ns2:hostname>
            </detail>
        </soapenv:Fault>
    </soapenv:Body>
</soapenv:Envelope>

我该如何解决?

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)