Tag: Swift/ネットワーク

目次

関連ページ

参考情報

HTTP

HTTPリクエストの基本

  • ボタンを押したときURLにリクエストを送信して結果をデバッグ出力するサンプル。
        @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リクエストの改善例

  • エラーハンドリングを追加、エンコーディングの判別を追加したサンプル
  • サーバからのResponseを意識して対応 〜 swift - Qiitaにあるようになぜかgoogle.comはshift_jisエンコーディングで返してくる。そのままだと「NSString(data: data!, encoding: NSUTF8StringEncoding) 」がnilを返すので注意。
        @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認証する

  • リクエストの生成。
            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メソッドを実装する。
        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アドレスを取得する

  • ios - Swift - Get device's IP Address - Stack Overflowに説明されている。
  • ブリッジングヘッダー(参照:../Tips)を追加し、以下を記述する
    #include <ifaddrs.h>
  • Swiftファイルを追加し、以下の関数を追加する。
    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に、ネットファー区インターフェイスをen0に絞った版が掲載されているが、これでも一意には定まらない。

トップ   編集 凍結 差分 バックアップ 添付 複製 名前変更 リロード   新規 一覧 検索 最終更新   ヘルプ   最終更新のRSS
Last-modified: 2016-04-13 (水) 16:48:04