【问题标题】:Implementing HTTP proxy over SSL using CONNECT method from iPhone Applications使用 iPhone 应用程序中的 CONNECT 方法通过 SSL 实现 HTTP 代理
【发布时间】:2015-02-06 17:01:31
【问题描述】:

我正在开发客户端-服务器解决方案,其中我的 iPhone 应用程序使用 SSL 连接通过 TCP/IP 连接到服务器。我想确保 SSL 上的所有流量都通过 HTTP 代理服务器。

我们可以在设置 -> WiFi 详细信息 -> HTTP 代理(手动/自动)中指定 iPhone 上的 HTTP 代理信息。当我们这样做时,所有的 HTTP 流量都会通过上面提到的代理服务器。 (例如所有 Safari 流量,甚至是来自所有应用的 HTTP 流量。)

但我的问题是 SSL over TCP/IP 没有通过代理服务器。 iPhone SDK 具有 kCFStreamPropertySOCKSProxy 属性集来配置 NSStream 以供 SOCKS 使用,如下所述,但我看不到在 CFSocket/NSStream 上配置 HTTP 代理服务器的规定。处理此问题的最佳方法是什么。

 CFReadStreamRef readStream;
 CFWriteStreamRef writeStream;
 CFStreamCreatePairWithSocketToHost(kCFAllocatorDefault, (CFStringRef)ipAddress, port, &readStream, &writeStream);
 CFDictionaryRef proxyDict = CFNetworkCopySystemProxySettings();
 CFMutableDictionaryRef socksConfig = CFDictionaryCreateMutableCopy(NULL, 0, proxyDict);
 CFDictionarySetValue(socksConfig, kCFStreamPropertySOCKSProxyHost, (CFStringRef)@"proxy-ip");
 CFDictionarySetValue(socksConfig, kCFStreamPropertySOCKSProxyPort, (__bridge CFNumberRef)[NSNumber numberWithInteger:proxy-port]);
 CFDictionarySetValue(socksConfig, kCFStreamPropertySOCKSVersion, kCFStreamSocketSOCKSVersion5);
 CFDictionarySetValue(socksConfig, NSStreamSOCKSProxyUserKey, (CFStringRef)@"proxy-username");
 CFDictionarySetValue(socksConfig, NSStreamSOCKSProxyPasswordKey, (CFStringRef)@"proxy-password");
 CFReadStreamSetProperty(readStream, kCFStreamPropertySOCKSProxy, socksConfig);
 CFWriteStreamSetProperty(writeStream, kCFStreamPropertySOCKSProxy, socksConfig);
 CFRelease(proxyDict);

更新:看起来只有一种方法可以做到这一点,通过代理到服务器的 HTTP CONNECT 并将连接用于常规 SSL 流量。但我仍在寻找 iPhone 的实现。

谢谢

【问题讨论】:

    标签: iphone ssl tcp-ip proxy-server http-tunneling


    【解决方案1】:

    我终于找到了答案。在套接字上发送以下数据,并使用同一个套接字创建 TCP 连接。

     [[NSString stringWithFormat:@"CONNECT %@:%d HTTP/1.1\nProxy-Connection: Keep-Alive\n\n", @"10.10.10.10", 80] dataUsingEncoding:NSUTF8StringEncoding] ;
    

    【讨论】:

    • “在套接字上发送数据”是什么意思,如何建立连接?可以分享一下代码吗?
    • 请问我可以在哪里使用这些数据?
    最近更新 更多