其他分享
首页 > 其他分享> > android-如何在react-native中为webView请求设置自定义标头

android-如何在react-native中为webView请求设置自定义标头

作者:互联网

我希望能够在Rails服务器端的ruby上检测到http请求来自我应用程序中的webView组件.该应用程序正在使用本机.特别是,我想区分来自应用程序的请求和来自ios设备上运行的移动Safari的请求.

我尝试在AppDelegate.m文件中设置以下内容

  NSURL *url = [NSURL URLWithString:@"http://localhost:3000/signin"];
  NSMutableURLRequest *request=[NSMutableURLRequest requestWithURL:url cachePolicy:NSURLRequestReloadIgnoringCacheData timeoutInterval:60];
  [request addValue:@"GolfMentor" forHTTPHeaderField:@"User-Agent"];
  [request addValue:@"GolfMentor" forHTTPHeaderField:@"X-MY-CUSTOM-HEADER"];
  NSLog(@"%@", [request allHTTPHeaderFields]);

控制台中的输出是

GolfMentor[63924:12437749] {
"User-Agent" = GolfMentor;
"X-MY-CUSTOM-HEADER" = GolfMentor;
}

因此,客户标头似乎已设置.但是,当我在Rails应用程序的ruby中查看请求标头时,没有自定义标头的迹象.看起来我的更改后来在react-native应用程序的执行中被覆盖.那么我应该在哪里以及如何设置自定义标题呢?我也有兴趣为该应用的android版本做同样的事情吗?

解决方法:

尝试将以下行添加到AppDelegate.m中以设置自定义用户代理

NSString *newAgent = @"GolfMentor";
NSDictionary *dictionnary = [[NSDictionary alloc] initWithObjectsAndKeys:newAgent, @"UserAgent", nil];
[[NSUserDefaults standardUserDefaults] registerDefaults:dictionnary];

可以找到更完整的答案和针对Android的解决方案here.

标签:react-native,webview,ios,ruby-on-rails,android
来源: https://codeday.me/bug/20191118/2030623.html