PacketTunnelProvider网络扩展名不叫Swift 3

时间:2017-03-09 17:14:49

标签: ios swift networking vpn

我正在尝试将PacketTunnerProvider网络扩展添加到我的项目中。方法startTunnelWithOptions(options:[String:NSObject] ?, completionHandler:(NSError?) - > Void)永远不会被调用

但是,我能够使用providerBundleIdentifier的网络扩展包ID成功建立VPN连接

这是我用来建立连接的代码

let vpnManager = NETunnelProviderManager.shared()

 func initVPNTunnelProviderManager() {

    let config = NETunnelProviderProtocol()

    config.providerBundleIdentifier = self.tunnelBundleId
    config.providerConfiguration = ["lol": 1]
    config.serverAddress = self.serverAddress
    config.username = self.username
    config.passwordReference = passwordRef

    vpnManager.loadFromPreferences {
        (error: Error?) in

        self.vpnManager.protocolConfiguration = vpnProtocol
        self.vpnManager.localizedDescription = "Connect_1.0.0"
        self.vpnManager.isEnabled = true

        self.vpnManager.saveToPreferences {
            (error: Error?) in
            do {
                try self.vpnManager.connection.startVPNTunnel()
            } catch let error as NSError {
                print("Error: \(error.localizedDescription)")
            }
        }
    }
}

这是我的PacketTunnel权利文件

`<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
    <key>com.apple.developer.networking.vpn.api</key>
    <array>
        <string>allow-vpn</string>
    </array>
    <key>com.apple.security.application-groups</key>
    <array>
        <string>group.touchcore.Connectionapp</string>
    </array>
    <key>keychain-access-groups</key>
    <array>
        <string>$(AppIdentifierPrefix)touchcore.Connectionapp.PacketTunnel</string>
    </array>
    <key>com.apple.developer.networking.networkextension</key>
    <array>
        <string>packet-tunnel-provider</string>
        <string>app-proxy-provider</string>
        <string>content-filter-provider</string>
    </array>
</dict>
</plist>`

1 个答案:

答案 0 :(得分:3)

  

方法startTunnelWithOptions(options:[String:NSObject] ?, completionHandler:(NSError?) - &gt; Void)永远不会被调用

     

但是,我能够使用providerBundleIdentifier的网络扩展包ID成功建立VPN连接

你究竟是什么意思永远不会被称为?如果您能够成功建立连接,则会调用startTunnelWithOptions

如果您正在尝试确定它是什么&#39;通过使用NSLog()进行调用,请记住,只有将调试器连接到提供程序而不是容器应用程序时才会显示在调试日志中。

这很困难,因为提供程序已初始化,并且在您有机会附加调试程序之前调用startTunnelWithOptions函数。

在这种情况下,一个有用的工作是睡眠,以便给调试器提供附加时间。

- (void) startTunnelWithOptions:(NSDictionary *) options
          completionHandler:(void (^)(NSError *)) completionHandler
{

    // Give debugger time to attach, 10 seconds is usually enough
    // Comment this out before you release the app or else you 
    // will be stuck with a 10 second delay on all connections.
    sleep(10); 

    // Continue with execution
    . . .
}

然后,当您初始化PacketTunnelProvider时,它将等待10秒,然后在startTunnelWithOptions函数内完全输入逻辑。

因此,在XCode的这段时间内,您可以转到Debug->Attach To Process->YourVPNProviderProcess并等待它完全初始化。

Attach the debugger to a running process