Swfit 之NetworkingRequest-dataParse

Swfit_Networking_Request-data_Parse

使用系統(tǒng)方法請求天氣接口

<!--接口-->

 func getWeatherResponse() -> Void {
 <!--URL去阿里云墨跡天氣注冊,會提供code剪撬,token-->
        let url: String = "http://freecityid.market.alicloudapi.com/whapi/json/alicityweather/briefforecast3days"
        let code  = "f3026e20bd8a474e9453a63873cb9e34"
        let bodys: String = "cityId=2&token=677282c2f1b3d718152c4e25ed434bc4"
        <!--設(shè)置頭部-->
        let header:HTTPHeaders = ["Authorization" : "APPCODE \(code) ",
            "Content-Type" : "application/x-www-form-urlencoded; charset=UTF-8"
        ]
        <!--設(shè)置request-->
        let request = NSMutableURLRequest.init(url: NSURL.init(string: url)! as URL)
        request.httpMethod = "POST"
        request.addValue("APPCODE \(code)", forHTTPHeaderField: "Authorization")
        request.addValue("application/x-www-form-urlencoded; charset=UTF-8", forHTTPHeaderField:  "Content-Type")
        
        let data = bodys.data(using: String.Encoding.utf8)
        request.httpBody = data
        
        let session = URLSession.init(configuration: URLSessionConfiguration.default)
        let tast = session.dataTask(with: request as URLRequest) { (datas, responses, error) in
            let dict: NSDictionary = try! JSONSerialization.jsonObject(with: datas ?? Data.init(), options: JSONSerialization.ReadingOptions.mutableLeaves) as! NSDictionary
            print(dict)
            <!--json數(shù)據(jù)解析-->
            let pDataDict: NSDictionary = dict.object(forKey: "data") as! NSDictionary
            let pForecastArray: NSArray = pDataDict.object(forKey: "forecast") as! NSArray
            let pCityDict: NSDictionary = pDataDict.object(forKey: "city") as! NSDictionary
            let pCity: City = City.init()
            
            pCity.cityId = pCityDict.object(forKey: "cityId") as! Int
            pCity.pname = pCityDict.object(forKey: "pname") as! String
            pCity.counname = pCityDict.object(forKey: "counname") as! String
            pCity.name = pCityDict.object(forKey: "name") as! String
            pCity.secondaryname = pCityDict.object(forKey: "secondaryname") as! String
            
            var forecastArray: [ForeCast] = NSMutableArray.init() as! [ForeCast]
            
            for m in pForecastArray {
                let pForecastDict = m as!NSDictionary
                let pForecast: ForeCast = ForeCast.init()
                pForecast.conditionDay = pForecastDict.object(forKey: "conditionDay") as! String
                pForecast.conditionIdDay = pForecastDict.object(forKey: "conditionIdDay") as! String
                pForecast.conditionIdNight = pForecastDict.object(forKey: "conditionIdNight") as! String
                pForecast.conditionNight = pForecastDict.object(forKey: "conditionNight") as! String
                pForecast.predictDate = pForecastDict.object(forKey: "predictDate") as! String
                pForecast.tempDay = pForecastDict.object(forKey: "tempDay") as! String
                pForecast.tempNight = pForecastDict.object(forKey: "tempNight") as! String
                pForecast.updatetime = pForecastDict.object(forKey: "updatetime") as! String
                pForecast.windDirDay = pForecastDict.object(forKey: "windDirDay") as! String
                pForecast.windDirNight = pForecastDict.object(forKey: "windDirNight") as! String
                pForecast.windLevelDay = pForecastDict.object(forKey: "windLevelDay") as! String
                pForecast.windLevelNight = pForecastDict.object(forKey: "windLevelNight") as! String
                forecastArray.append(pForecast)
            }
            let pData = Datas.init(city: pCity, forecast: forecastArray)
            let pForecastModel = ForecastModel.init(data: pData)
            print(pForecastModel)
        }
        tast.resume()
        
    }
    
<!--數(shù)據(jù)model-->

class ForecastModel: NSObject {
    var data = Datas(city: City.init(), forecast: [ForeCast.init()])
    init(data: Datas) {
        self.data = data
    }
}

class Datas: NSObject {
    var city = City()
    var forecast:[ForeCast] = []
    init(city: City, forecast:[ForeCast]) {
        self.city = city
        self.forecast = forecast
    }
}

class City: NSObject {
    var cityId: Int = 0
    var counname: String = ""
    var name: String = ""
    var pname: String = ""
    var secondaryname: String = ""
}
class ForeCast: NSObject {
    var conditionDay: String = ""
    var conditionIdDay: String = ""
    var conditionIdNight: String = ""
    var conditionNight: String = ""
    var predictDate: String = ""
    var tempDay: String = ""
    var tempNight: String = ""
    var updatetime: String = ""
    var windDirDay: String = ""
    var windDirNight: String = ""
    var windLevelDay: String = ""
    var windLevelNight: String = ""
}

使用第三方AlamofireObjectMapper

<!--接口-->

func getWeatherResponse() -> Void {
        let url: String = "http://freecityid.market.alicloudapi.com/whapi/json/alicityweather/briefforecast3days"
        let dic = ["cityId" : "1098",
                   "token" : "677282c2f1b3d718152c4e25ed434bc4"
        ]
        let code  = "f3026e20bd8a474e9453a63873cb9e34"
        let header:HTTPHeaders = ["Authorization" : "APPCODE \(code) ",
            "Content-Type" : "application/x-www-form-urlencoded; charset=UTF-8"
        ]
        Alamofire.request(url, method: HTTPMethod.post, parameters: dic, encoding: URLEncoding.default, headers: header).responseObject {(response: DataResponse<RESModel>) in
            self.resModel = response.result.value
            print(self.resModel!)
            
        }
    }
    
<!--數(shù)據(jù)model-->
import ObjectMapper

class RESModel: Mappable {
    var data: pData?
    required init?(map: Map) {
        
    }
    
    func mapping(map: Map) {
        data <- map["data"]
    }
    
    
}

class pData: Mappable {
    var forecast: [pForecast]?
    var city: pCity?
    
    
    required init?(map: Map) {
        
    }
    
    func mapping(map: Map) {
        forecast <- map["forecast"]
        city <- map["city"]
    }
    
    
}


class pForecast: Mappable {
    
    var conditionDay: String?
    var conditionIdDay: String?
    var conditionIdNight: String?
    var conditionNight: String?
    var humidity: String?
    var predictDate: String?
    var tempDay: String?
    var tempNight: String?
    var updatetime: String?
    var windDegreesDay: String?
    var windDegreesNight: String?
    var windDirDay: String?
    var windDirNight: String?
    var windLevelDay: String?
    var windLevelNight: String?
    
    
    required init?(map: Map) {
        
    }
    
    func mapping(map: Map) {
        conditionDay <- map["conditionDay"]
        conditionIdDay <- map["conditionIdDay"]
        conditionIdNight <- map["conditionIdNight"]
        conditionNight <- map["conditionNight"]
        humidity <- map["humidity"]
        predictDate <- map["predictDate"]
        tempDay <- map["tempDay"]
        tempNight <- map["tempNight"]
        updatetime <- map["updatetime"]
        windDegreesDay <- map["windDegreesDay"]
        windDegreesNight <- map["windDegreesNight"]
        windDirDay <- map["windDirDay"]
        windDirNight <- map["windDirNight"]
        windLevelDay <- map["windLevelDay"]
        windLevelNight <- map["windLevelNight"]
    }
    
    
}
class pCity: Mappable {
    
    var cityId: Int?
    var ianatimezone: String?
    var name: String?
    var pname: String?
    var counname: String?
    var secondaryname: String?
    var timezone: String?
    required init?(map: Map) {
        
    }
    
    func mapping(map: Map) {
        cityId <- map["cityId"]
        ianatimezone <- map["ianatimezone"]
        name <- map["name"]
        pname <- map["pname"]
        counname <- map["counname"]
        secondaryname <- map["secondaryname"]
        timezone <- map["timezone"]
    }  
}

如何獲取墨跡天氣接口

1.png
2.png
3.png
4.png

直通車:https://github.com/princeSmall/Swfit_Networking_Request-data_Parse

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌炎码,老刑警劉巖试躏,帶你破解...
    沈念sama閱讀 217,907評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異溜族,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)垦沉,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,987評論 3 395
  • 文/潘曉璐 我一進(jìn)店門煌抒,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人厕倍,你說我怎么就攤上這事寡壮。” “怎么了讹弯?”我有些...
    開封第一講書人閱讀 164,298評論 0 354
  • 文/不壞的土叔 我叫張陵况既,是天一觀的道長。 經(jīng)常有香客問我组民,道長棒仍,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,586評論 1 293
  • 正文 為了忘掉前任臭胜,我火速辦了婚禮莫其,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘庇楞。我一直安慰自己榜配,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,633評論 6 392
  • 文/花漫 我一把揭開白布吕晌。 她就那樣靜靜地躺著蛋褥,像睡著了一般。 火紅的嫁衣襯著肌膚如雪睛驳。 梳的紋絲不亂的頭發(fā)上烙心,一...
    開封第一講書人閱讀 51,488評論 1 302
  • 那天,我揣著相機(jī)與錄音乏沸,去河邊找鬼淫茵。 笑死,一個胖子當(dāng)著我的面吹牛蹬跃,可吹牛的內(nèi)容都是我干的匙瘪。 我是一名探鬼主播,決...
    沈念sama閱讀 40,275評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼丹喻!你這毒婦竟也來了薄货?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,176評論 0 276
  • 序言:老撾萬榮一對情侶失蹤碍论,失蹤者是張志新(化名)和其女友劉穎谅猾,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體鳍悠,經(jīng)...
    沈念sama閱讀 45,619評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡税娜,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,819評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了藏研。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片敬矩。...
    茶點故事閱讀 39,932評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖遥倦,靈堂內(nèi)的尸體忽然破棺而出谤绳,到底是詐尸還是另有隱情占锯,我是刑警寧澤袒哥,帶...
    沈念sama閱讀 35,655評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站消略,受9級特大地震影響堡称,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜艺演,卻給世界環(huán)境...
    茶點故事閱讀 41,265評論 3 329
  • 文/蒙蒙 一却紧、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧胎撤,春花似錦晓殊、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,871評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至肿男,卻和暖如春介汹,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背舶沛。 一陣腳步聲響...
    開封第一講書人閱讀 32,994評論 1 269
  • 我被黑心中介騙來泰國打工嘹承, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人如庭。 一個月前我還...
    沈念sama閱讀 48,095評論 3 370
  • 正文 我出身青樓叹卷,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子骤竹,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,884評論 2 354