&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に絞った版が掲載されているが、これでも一意には定まらない。

トップ   編集 差分 履歴 添付 複製 名前変更 リロード   新規 一覧 検索 最終更新   ヘルプ   最終更新のRSS