前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >iOS开发实战-NetworkExtension食用教程写在前面项目介绍项目准备我不是广告结语

iOS开发实战-NetworkExtension食用教程写在前面项目介绍项目准备我不是广告结语

作者头像
gwk_iOS
发布2018-08-23 10:54:21
7.6K1
发布2018-08-23 10:54:21
举报
文章被收录于专栏:coding...coding...

写在前面

之前由于一些关键字问题被简大叔给封锁了...我还是换成正常的来吧~鉴于此顺便给自己开了个 简单的wordpress博客有兴趣的可以去看看吧~~~ 最近闲来无事,又跟小伙伴搞起.自由冲浪.的项目,于是这个项目就来了.

项目介绍

运用Apple NetworkExtension框架(现在不用单独申请了哟),搭配NEKit 配置S最终实现....上网

  • 首先感谢zhuhaow的优秀框架NEKit帮我们做了很多网络相关的处理,原则上我们只用专注UI就可以很方便的在iOS OSX平台开发出一个简单的S客户端
  • 再来就是感谢称一称小哥的优秀Demo,该Demo几乎就是一个iOS平台的S客户端
  • 本项目为Swift项目
  • 根据NEKit的使用帮助,这边第三方类库管理工具我们使用Carthage
  • 本文已称一称小哥的Demo为主

项目准备

一.安装NEProviderTargetTemplates.pkg

由于未知原因苹果在mac OS 10.12中删除了这个文件,因此我们需要从10.11系统中提取或下载--百度网盘 安装完毕后,在新增build target中我们就可以看到多了AppProxy和 Package Tunnrl Provider。我们选择Package Tunnrl Provider

选择target

Package Tunnrl Provider

打开项目将2个Target的Capabilites中的PersonalV**和NetworkExtesions开关打开,注意是两个都开哦

打开PersonalV**和NetworkExtesions

二.连接V**

首先,我们需要在主程序中像系统生名一个ProviderManager,即设置V**中的栏目。

代码语言:javascript
复制
let manager = NETunnelProviderManager()
let conf = NETunnelProviderProtocol()
conf.serverAddress = "My V**"          //任意值,显示在设置-V**-Detial中
manager.protocolConfiguration = conf
manager.localizedDescription = "My V**"
manager.isEnabled = true               //使V**在系统中变为选中的状态

代码语言:javascript
复制
NETunnelProviderManager.loadAllFromPreferencesWithCompletionHandler{ 
    (managers, error) in
    guard let managers = managers else{return}
    let manager: NETunnelProviderManager
    if managers.count > 0 {
        manager = managers[0]
    }else{
        manager = self.createProviderManager()
    }
    // Todo
    // manager.saveToPreferences.......
}

三.简单配置extension

由于目前我使用的是Swift3.0,这时候我们需要修改Extension中的几个方法修改一下

代码语言:javascript
复制
//MARK: 启动V**时调用
func startTunnel(options: [String : NSObject]? = nil, completionHandler: @escaping (Error?) -> Swift.Void)

//MARK: 停止V**时调用
func stopTunnel(with reason: NEProviderStopReason, completionHandler: @escaping () -> Swift.Void) 

四.启动V**

启动V**很简单,只需对ProviderManager执行startV**TunnelWithOptions()方法即可

代码语言:javascript
复制
saveToPreferences{
   error in
   //出错处理
   manager.loadFromPreferences{
        if $0 != nil{print($0)}
        manager.startV**.........
    }
}

连接成功会manager.connection.status会发生相应改变,因此我们需要在按下连接按钮后监听status,从而知道目前V**的连接状态

代码语言:javascript
复制
 func addV**StatusObserver() {
     guard !observerAdded else{
         return
     }
     loadProviderManager { [unowned self] (manager) -> Void in
         if let manager = manager {
             self.observerAdded = true
             NotificationCenter.default.addObserver(forName: NSNotification.Name.NEV**StatusDidChange, object: manager.connection, queue: OperationQueue.main, using: { [unowned self] (notification) in
                 self.updateV**Status(manager: manager)
             })
         }
     }
 }

五.关于Debug调试

  • Extension debug不同于正常的程序,尽量使用NSlog代替print,即可在系统日志中查看到内容。同时,如果需要Debug,可通过Xcode->Debug->Attach To Process 选择你的Tunnel名进行debug 打开控制台console就能看到所有日志 筛选一下当前的target就能看到日志信息了

六.传SS递配置文件

我们需要在主程序中传递类似账号、密码、端口、加密方式等参数给我们的V**组件。

  • 主程序写入
代码语言:javascript
复制
let conf = ["port":1000,"method":"AES-256-CFB","password":"hello"]
let providerProtocol = manager.protocolConfiguration as! NETunnelProviderProtocol
providerProtocol.providerConfiguration = conf
manager.protocolConfiguration = orignConf

  • target读取
代码语言:javascript
复制
public var protocolConfiguration: NEV**Protocol { get }

guard let conf = (protocolConfiguration as! NETunnelProviderProtocol).providerConfiguration else{
    NSLog("[ERROR] No ProtocolConfiguration Found")
    exit(EXIT_FAILURE)
}
let address = conf["address"] as! String
let port = conf["port"] as! Int

七.导入NEKit

根据NEKit导入方法 直接导入即可 导入成功后记得copy framework哦,脚本copy和手动添加都是可行的

八.上架问题

90080,90087,90209,90125报错

在上架时如果直接使用会报错90080,90087,90209,90125等错误,这是由于NEKit中包含了x86_64, i386 架构,当然这个AppStore是不允许的,所以会在上传的时候报错 解决方法: Build Phases - New Run Script Phase

Build Phases - New Run Script Phase

添加如下代码

代码语言:javascript
复制
APP_PATH="${TARGET_BUILD_DIR}/${WRAPPER_NAME}"

# This script loops through the frameworks embedded in the application and

# removes unused architectures.

find "$APP_PATH" -name '*.framework' -type d | while read -r FRAMEWORK

do

FRAMEWORK_EXECUTABLE_NAME=$(defaults read "$FRAMEWORK/Info.plist" CFBundleExecutable)

FRAMEWORK_EXECUTABLE_PATH="$FRAMEWORK/$FRAMEWORK_EXECUTABLE_NAME"

echo "Executable is $FRAMEWORK_EXECUTABLE_PATH"

EXTRACTED_ARCHS=()

for ARCH in $ARCHS

do

echo "Extracting $ARCH from $FRAMEWORK_EXECUTABLE_NAME"

lipo -extract "$ARCH" "$FRAMEWORK_EXECUTABLE_PATH" -o "$FRAMEWORK_EXECUTABLE_PATH-$ARCH"

EXTRACTED_ARCHS+=("$FRAMEWORK_EXECUTABLE_PATH-$ARCH")

done

echo "Merging extracted architectures: ${ARCHS}"

lipo -o "$FRAMEWORK_EXECUTABLE_PATH-merged" -create "${EXTRACTED_ARCHS[@]}"

rm "${EXTRACTED_ARCHS[@]}"

echo "Replacing original executable with thinned version"

rm "$FRAMEWORK_EXECUTABLE_PATH"

mv "$FRAMEWORK_EXECUTABLE_PATH-merged" "$FRAMEWORK_EXECUTABLE_PATH"

done

添加代码

CFBundleShortVersionString报错

这是由于NEKit没有设置版本号 找到NEKit的framework将info.plist中的版本号

找到info.plist

修改版本号

九.Demo食用方法

  • 添加CommonCryptoframework

由于CommonCrypto框架的问题需要在Cartfile中添加 github "soffes/CommonCrypto"

  • 导入NEKit

按照demo上使用Carthage导入NEKit 运行carthage update --no-use-binaries --platform ios 关闭项目Capabilites中AppGroups开关 将entitlements中相关的 groups属性删除即可

结语

最后再次感谢NEKit?和称一称提供的Demo ?

很高兴App 已经过审, 有兴趣的可以玩玩牛牛数据 支持iPad哦 update: Mac版已成功上架牛牛数据Mac版~~

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2017.07.12 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 写在前面
  • 项目介绍
  • 项目准备
    • 一.安装NEProviderTargetTemplates.pkg
      • 二.连接V**
        • 三.简单配置extension
          • 四.启动V**
            • 五.关于Debug调试
              • 六.传SS递配置文件
                • 七.导入NEKit
                  • 八.上架问题
                    • 九.Demo食用方法
                    • 结语
                    领券
                    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档