- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我想制作一个能够发现并连接到本地网络上的对等点的应用程序,因此我决定使用 bonjour 框架快速实现它。
但是,我无法使用 Swift 使 Bonjour 正常工作,而且我也不知道为什么。这是我用来测试此服务的代码:
import Foundation
let BM_DOMAIN = "local"
let BM_TYPE = "_helloworld._tcp."
let BM_NAME = "hello"
let BM_PORT : CInt = 6543
/// Netservice
let nsns = NSNetService(domain: BM_DOMAIN,
type: BM_TYPE, name: BM_NAME, port: BM_PORT)
let nsnsdel = BMNSDelegate() //see bellow
nsns.delegate = nsnsdel
nsns.publish()
/// Net service browser.
let nsb = NSNetServiceBrowser()
let nsbdel = BMBrowserDelegate() //see bellow
nsb.delegate = nsbdel
nsb.searchForServicesOfType(BM_TYPE, inDomain: BM_DOMAIN)
println("press enter")
// this prevents the app from quitting instantly.
NSFileHandle.fileHandleWithStandardInput().availableData
委托(delegate)是胶水代码,它简单地打印每次对控制台的调用。
class BMNSDelegate : NSObject, NSNetServiceDelegate {
func netServiceWillPublish(sender: NSNetService!) {
println("netServiceWillPublish:sender");
}
// .....and so on for the 8 other methods.....
}
class BMBrowserDelegate : NSObject, NSNetServiceBrowserDelegate {
func netServiceBrowserWillSearch(aNetServiceBrowser: NSNetServiceBrowser!){
println("netServiceBrowserWillSearch")
}
// .....and so on for the 6 other methods.....
}
这是此示例代码的输出:
netServiceWillPublish:sender
netServiceBrowserWillSearch
press enter
如果我使用 Bonjour browser ,我可以看到该服务已正确发布。但是,除了 **WillPublish
之外,两个委托(delegate)中的回调都没有被调用 :-(
经过大量调试(并阅读了 stackoverflow 上的内容)后,我不明白为什么它不起作用。有任何想法吗 ?
(我使用的是 Mac OS X 10.9.3 和 xcode 6.0 beta build 6A215l)
最佳答案
如果没有您的完整代码,可能很难确定您的问题是什么。我怀疑您将变量/常量声明为函数的局部变量。当它们超出范围时,对服务的引用也超出范围。这就是为什么您尝试从 STDIN 请求输入的阻塞调用(让事情卡在那里)。根据 Apple 文档,netService 和 netServiceBrowser 都与默认运行循环隐式关联,因此您也不需要显式地这样做。显式关联一个 run loop 会导致程序卡住,这不是你想要的。此代码创建以下输出
netServiceWillPublish:<NSNetService 0x14522e00> local _helloworld._tcp. hello
netServiceBrowserWillSearch
netServiceDidPublish:<NSNetService 0x14522e00> local. _helloworld._tcp. hello
netServiceDidFindService
并且不会被阻塞或处于阻止程序正常运行的运行循环中。在 AppDelegate.swift 中
class AppDelegate: UIResponder, UIApplicationDelegate {
var window: UIWindow?
var nsns:NSNetService?
var nsnsdel:BMNSDelegate?
var nsb:NSNetServiceBrowser?
var nsbdel:BMBrowserDelegate?
func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool {
// Override point for customization after application launch.
let BM_DOMAIN = "local"
let BM_TYPE = "_helloworld._tcp."
let BM_NAME = "hello"
let BM_PORT : CInt = 6543
/// Netservice
nsns = NSNetService(domain: BM_DOMAIN,
type: BM_TYPE, name: BM_NAME, port: BM_PORT)
nsnsdel = BMNSDelegate() //see bellow
nsns?.delegate = nsnsdel
nsns?.publish()
/// Net service browser.
nsb = NSNetServiceBrowser()
nsbdel = BMBrowserDelegate() //see bellow
nsb?.delegate = nsbdel
nsb?.searchForServicesOfType(BM_TYPE, inDomain: BM_DOMAIN)
//println("press enter")
// this prevents the app from quitting instantly.
// NSRunLoop.currentRunLoop().run()
// NSFileHandle.fileHandleWithStandardInput().availableData
return true
}
以及其他地方的委托(delegate)回调...
class BMNSDelegate : NSObject, NSNetServiceDelegate {
func netServiceWillPublish(sender: NSNetService!) {
println("netServiceWillPublish:\(sender)");
}
func netService(sender: NSNetService, didNotPublish errorDict: [NSObject : AnyObject]) {
println("didNotPublish:\(sender)");
}
func netServiceDidPublish(sender: NSNetService) {
println("netServiceDidPublish:\(sender)");
}
func netServiceWillResolve(sender: NSNetService) {
println("netServiceWillResolve:\(sender)");
}
func netService(sender: NSNetService, didNotResolve errorDict: [NSObject : AnyObject]) {
println("netServiceDidNotResolve:\(sender)");
}
func netServiceDidResolveAddress(sender: NSNetService) {
println("netServiceDidResolve:\(sender)");
}
func netService(sender: NSNetService, didUpdateTXTRecordData data: NSData) {
println("netServiceDidUpdateTXTRecordData:\(sender)");
}
func netServiceDidStop(sender: NSNetService) {
println("netServiceDidStopService:\(sender)");
}
func netService(sender: NSNetService,
didAcceptConnectionWithInputStream inputStream: NSInputStream,
outputStream stream: NSOutputStream) {
println("netServiceDidAcceptConnection:\(sender)");
}
}
class BMBrowserDelegate : NSObject, NSNetServiceBrowserDelegate {
func netServiceBrowser(netServiceBrowser: NSNetServiceBrowser,
didFindDomain domainName: String,
moreComing moreDomainsComing: Bool) {
println("netServiceDidFindDomain")
}
func netServiceBrowser(netServiceBrowser: NSNetServiceBrowser,
didRemoveDomain domainName: String,
moreComing moreDomainsComing: Bool) {
println("netServiceDidRemoveDomain")
}
func netServiceBrowser(netServiceBrowser: NSNetServiceBrowser,
didFindService netService: NSNetService,
moreComing moreServicesComing: Bool) {
println("netServiceDidFindService")
}
func netServiceBrowser(netServiceBrowser: NSNetServiceBrowser,
didRemoveService netService: NSNetService,
moreComing moreServicesComing: Bool) {
println("netServiceDidRemoveService")
}
func netServiceBrowserWillSearch(aNetServiceBrowser: NSNetServiceBrowser!){
println("netServiceBrowserWillSearch")
}
func netServiceBrowser(netServiceBrowser: NSNetServiceBrowser,
didNotSearch errorInfo: [NSObject : AnyObject]) {
println("netServiceDidNotSearch")
}
func netServiceBrowserDidStopSearch(netServiceBrowser: NSNetServiceBrowser) {
println("netServiceDidStopSearch")
}
}
关于swift - 在 Swift 应用程序上使用 NSNetService 和 NSNetServiceBrowser,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24618952/
我正在使用 NSNetServices 进行简单的 bonjour 广播。当我在应用程序启动/退出时启动和停止 bonjour 共享时,一切都运行良好。但是,如果我使用 stop 方法调用关闭 bon
我在 Mac 应用程序中托管服务并与 iOS 应用程序连接。虽然 iOS 应用程序会找到该服务,但该服务不包含任何地址,因此我无法连接套接字。 这是我在 Mac 上的托管代码: - (void)sta
我正在尝试在 iOS 设备和 Mac 之间建立 Bonjour 连接。发现彼此效果很好,但我在使用 setTXTRecordData: 时遇到问题.它总是失败(BOOL 返回 NO)... _serv
我正在创建一款可以通过 Wi-Fi 在 iPhone 上玩的棋盘游戏。 当设备A邀请设备B玩时(尝试解析B发布的NSNetService),设备B可以接受或拒绝。 如果 B 拒绝,A 就会收到通知,一
我正在开发一个供我自己使用的小型 iOS 应用程序(至少最初是这样),我想我会使用 Bonjour 来配置两个 iOS 设备之间的网络。我的服务器的接口(interface)定义 NSNetServi
我需要找到一种方法来观察我的应用何时停止通过 bonjour 发布服务。这通常发生在设备接到电话或某些此类中断时。 背景: 我正在使用 GCDAsyncSocket 在同一网络中的 2 台设备之间为播
我正在开发无线应用程序,我的问题如下所示:1)是否有可能使用 NSNetServices 在设备之间来回发送数据,如点对点,Apple 的 Bonjour 示例仅适用于本地网络,这意味着如果 NSNe
dictionary(fromTXTRecord:) 的输入来自网络,可能来自应用程序外部,甚至是设备。然而,Apple 的 docs 说: ... Fails an assertion if txt
我正在尝试使用 NSNetService 在 iPhone 应用程序和 Mac 应用程序之间建立通信。 到目前为止,我已将 Mac 应用程序设置为发布 iPhone 应用程序可以发现的 NSNetSe
请原谅我的 iPhone/Objective-C 新手身份! 我已经使用 NSNetServiceBrowser 找到了我的 HTTP 服务器,但现在我只想找到该服务的 IP 地址和端口。 我的委托(
我正在使用 NSNetService 通过 Bonjour 进行广播。但是当我想停止它时,我使用[netService stop],其中netService是我的NSNetService。它只是不会停
我对 Objective-C/Cocoa 有点陌生,我正在尝试编写一个 bonjour 服务器客户端应用程序。因为我没有太多经验,所以如果您的回复还可以包括如何操作的解释,而不仅仅是代码,我将不胜感激
我正在尝试模仿 iPhoto 共享,并已使用 iPhoto 服务名称“_dpap._tcp”发布该服务。 iPhoto 看到我的虚假“共享”,但它呈灰色。我正在观察网络流量,看看 iPhoto 是否正
最近,我在解析 NSNetService 时遇到了问题。 我发布了一个类型为 _http._tcp. 的 NSNetService,就像一个 http 服务器。否则,在另一台设备上,我开始搜索这项服务
我一直在尝试在 iOS 上制作一个简单的应用程序,它将接收消息,然后根据该消息执行操作(目前我只想通过 NSLog 显示它) .我可以连接到该服务,但该服务似乎从未收到任何东西。这是我的 .h 文件:
我有一个代码 CocoaHTTPServer它使用 Bonjour 发布服务。而 tt 为此使用 NSNetService。 如果您定义域“.local”,它工作正常(在 OS X 和 iOS 上)。
在 iOS 上,我正在使用 bonjour 查找其他设备,以便我可以在两者之间传输数据。我计划将 NSNetService 用于 bonjour,将 CocoaAsyncSocket 用于流媒体。 在
我正在制作一个包含两个组件的应用程序,一个 iPhone 组件和一个 Mac 组件。他们应该通过 bonjour 相互交流。我在Mac端使用以下代码来查找服务的端口: NSSocketPort *so
在我的 iPhone 应用程序中,我正在发布 bonjour 服务并使用以下委托(delegate)方法: - (void)netServiceDidPublish:(NSNetService *)n
我正在为 iPhone 和 iPad 开发一款 3D Wi-Fi 多人游戏,而不使用任何游戏引擎。我引用了“ radio 话 ” 的设备连接示例本地Wi-Fi多人游戏 (示例代码链接:WiTap)
我是一名优秀的程序员,十分优秀!