&tag(Swift/ネットワーク); *目次 [#aced81fd] #contents *関連ページ [#y9a9e7fb] *参考情報 [#kfef58df] *HTTP [#z3728046] **HTTPリクエストの基本 [#r59c47f1] -ボタンを押したときURLにリクエストを送信して結果をデバッグ出力するサンプル。 #pre{{ @IBAction func getButtonClicked(sender: UIButton) { guard let url = NSURL(string:"http://www.softantenna.com/") else { print("invalid url") return } let urlSession = NSURLSession.sharedSession() let task = urlSession.dataTaskWithURL(url, completionHandler: { (data, response, error) in if let res = response as? NSHTTPURLResponse { print("responseCode=\(res.statusCode)") } if let nsstr = NSString(data: data!, encoding: NSUTF8StringEncoding) { let str = String(nsstr) print("文字列=\(str)") } }) task.resume() } }} **HTTPリクエストの改善例 [#e448d00e] -エラーハンドリングを追加、エンコーディングの判別を追加したサンプル -[[サーバからのResponseを意識して対応 〜 swift - Qiita:http://qiita.com/nofrmm/items/dc89601658241b007e7d#%E3%81%95%E3%81%84%E3%81%94%E3%81%AB]]にあるようになぜかgoogle.comはshift_jisエンコーディングで返してくる。そのままだと「NSString(data: data!, encoding: NSUTF8StringEncoding) 」がnilを返すので注意。 #pre{{ @IBAction func getButtonClicked(sender: UIButton) { // let urlString = "http://www.softantenna.com/" let urlString = "http://www.google.com/" //encodingがなぜかshift_jis guard let url = NSURL(string: urlString) else { print("invalid url") return } let urlSession = NSURLSession.sharedSession() let task = urlSession.dataTaskWithURL(url, completionHandler: { (data, response, error) in var encoding = NSUTF8StringEncoding if let res = response as? NSHTTPURLResponse { print("responseCode=\(res.statusCode)") if let textEncName = res.textEncodingName { encoding = CFStringConvertEncodingToNSStringEncoding(CFStringConvertIANACharSetNameToEncoding(textEncName)) } } guard let data = data else { print("invalid data") return } if let nsstr = NSString(data: data, encoding: encoding) { let str = String(nsstr) print("文字列=\(str)") } else { print("空文字列") } }) task.resume() } }} **Basic/Digest認証する [#v01aa978] -リクエストの生成。 #pre{{ guard let url = NSURL(string:urlString) else { return } let configuration = NSURLSessionConfiguration.defaultSessionConfiguration() let urlSession = NSURLSession.init(configuration: configuration, delegate: self, delegateQueue: nil) let task = urlSession.dataTaskWithURL(url, completionHandler: { (data, response, error) in if let res = response as? NSHTTPURLResponse { print(res.statusCode) } if let nsstr = NSString(data: data!, encoding: NSUTF8StringEncoding) { let str = String(nsstr) print("文字列=\(str)") } }) task.resume() }} -NSURLSessionTaskDelegateをselfに実装し、以下のdelegateメソッドを実装する。 #pre{{ func URLSession(session: NSURLSession, task: NSURLSessionTask, didReceiveChallenge challenge: NSURLAuthenticationChallenge, completionHandler: (NSURLSessionAuthChallengeDisposition, NSURLCredential?) -> Void) { if challenge.previousFailureCount > 0 { completionHandler(NSURLSessionAuthChallengeDisposition.CancelAuthenticationChallenge, nil) } else { let credential = NSURLCredential(user:"digestuser", password:"digestpass", persistence: .ForSession) completionHandler(NSURLSessionAuthChallengeDisposition.UseCredential,credential) }} *デバイスのローカルIPアドレスを取得する [#o1afa2d6] -[[ios - Swift - Get device's IP Address - Stack Overflow:http://stackoverflow.com/questions/30748480/swift-get-devices-ip-address]]に説明されている。 -ブリッジングヘッダー(参照:[[../Tips]])を追加し、以下を記述する #include <ifaddrs.h> -Swiftファイルを追加し、以下の関数を追加する。 #pre{{ func getIFAddresses() -> [String] { var addresses = [String]() // Get list of all interfaces on the local machine: var ifaddr : UnsafeMutablePointer<ifaddrs> = nil if getifaddrs(&ifaddr) == 0 { // For each interface ... for (var ptr = ifaddr; ptr != nil; ptr = ptr.memory.ifa_next) { let flags = Int32(ptr.memory.ifa_flags) var addr = ptr.memory.ifa_addr.memory // Check for running IPv4, IPv6 interfaces. Skip the loopback interface. if (flags & (IFF_UP|IFF_RUNNING|IFF_LOOPBACK)) == (IFF_UP|IFF_RUNNING) { if addr.sa_family == UInt8(AF_INET) || addr.sa_family == UInt8(AF_INET6) { // Convert interface address to a human readable string: var hostname = [CChar](count: Int(NI_MAXHOST), repeatedValue: 0) if (getnameinfo(&addr, socklen_t(addr.sa_len), &hostname, socklen_t(hostname.count), nil, socklen_t(0), NI_NUMERICHOST) == 0) { if let address = String.fromCString(hostname) { addresses.append(address) } } } } } freeifaddrs(ifaddr) } return addresses } }} -ネットインターフェイスが複数あったり、IPv4/IPv6アドレスが取得できたりするので、一意には定まらないことに注意。 -[[ios - Swift - Get device's IP Address - Stack Overflow:http://stackoverflow.com/questions/30748480/swift-get-devices-ip-address]]に、ネットファー区インターフェイスをen0に絞った版が掲載されているが、これでも一意には定まらない。