React Native - 在 WebView 中使用 cookie 进行身份验证

Shu*_*ury 3 cookies android webview ios react-native

我已经为 React Native 应用程序提供了几个 API。一个端点用于身份验证,它返回一个允许访问其他 API 的 cookie。

cookie 具有以下结构:

{"auth":"ok","instance":"private","cookies":{"SSOsess":"300|c6dc6d70vfvbf0891004364665f24b77","RTBk":"300|451706342c67a37dfe5dede0b5d22469","ph03RPNCiscoASA":"application.api.urlweb.com","ph04RPNCiscoASA":"application.client.urlweb.com"}}
Run Code Online (Sandbox Code Playgroud)

经过一些格式化后,cookie 就可以发送了,如下所示:

SSOsess=300%7Cc6dc6d70vfvbf0891004364665f24b77; RTBk=300%7C451706342c67a37dfe5dede0b5d22469;
ph03RPNCiscoASA=application.api.urlweb.com;
ph04RPNCiscoASA=application.client.urlweb.com;
Run Code Online (Sandbox Code Playgroud)

React Native 应用程序中的一些WebView内容可以访问使用最初提供的一些 API 的网站的某些受限部分。

我怎样才能将cookie发送到WebView?我知道 React Native 有一些属性可用于将 cookie 注入到 WebView 中,例如injectedJavaScriptinjectedJavaScriptBeforeContentLoaded但这些属性到底应该包含什么?

我尝试通过以下方式发送但不起作用:

<WebView source={{ uri: 'http://urlweb.com' }}
               style={{width: 600, height: 400}}
               injectedJavaScriptBeforeContentLoaded={jsInjectedCode}
/>
Run Code Online (Sandbox Code Playgroud)

在哪里

jsInjectedCode = 'document.cookie = '+'SSOsess=300%7Cc6dc6d70vfvbf0891004364665f24b77; RTBk=300%7C451706342c67a37dfe5dede0b5d22469;
    ph03RPNCiscoASA=application.api.urlweb.com;
    ph04RPNCiscoASA=application.client.urlweb.com;'
Run Code Online (Sandbox Code Playgroud)

Muh*_*man 6

你可以像这样将 cookies 字符串传递到Cookie内部DOCSheader

import React, {Component} from 'react';
import {StyleSheet, View} from 'react-native';
import {WebView} from 'react-native-webview';

export default class App extends Component {
  render() {
    const cookiesString="cookie1=asdf; cookie2=dfasdfdas";   //here you can put your cookies
    return (
      <View style={styles.container}>
        <WebView
          source={{
            uri: `${domain}`,
            headers: {
              Cookie: cookiesString,
            },
          }}
          style={styles.WebViewStyle}
        />
      </View>
    );
  }
}

const styles = StyleSheet.create({
  container: {
    flex: 1,
    backgroundColor: '#FFF',
  },
  WebViewStyle: {
    flex: 1,
    resizeMode: 'cover',
  },
});
Run Code Online (Sandbox Code Playgroud)