我有一个恶作剧问题,在解决这个问题很长时间后我来找你。
我有一个具有以下规格的混合应用程序:
-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),用于将后续请求发送到后端以在安全 WS 中进行身份验证。
这是发出请求的代码httpclient angular
(后续请求同样)
this.http.post(wsurl, xml, {
withCredentials: true,
responseType: 'text',
headers: headers,
observe: 'response'
})
.toPromise()
.then(response => {})
.catch(err =>{})
我的问题是,启用 CORS 后,后端无法验证我在 iOS/safari 上的后续请求(安卓、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>
我怎样才能解决这个问题?