Retrofit之請求頭

《Retrofit之請求參數(shù)》,我們討論了請求的url參數(shù)、表單編碼以及使用請求主體發(fā)送數(shù)據(jù),但是處理API的請求我們還需要處理請求頭,來實現(xiàn)緩存、認證等操作。而在實際應用中,我們也通常會向請求頭添加平臺(Android or iOS)、app版本、操作系統(tǒng)版本、網(wǎng)絡(luò)類型等信息。

定義請求頭

Retrofit提供了兩種方式來定義HTTP請求頭:靜態(tài)和動態(tài)。

靜態(tài)請求頭

以獲取天氣的一個API接口為例,具體API詳見天氣查詢。這個接口請求要求一個apikey的請求頭以及一個citypinyi的url參數(shù)。

定義的接口如下:

public interface WeatherService {
    @Headers("apikey:b86c2269fe6588bbe3b41924bb2f2da2")
    @GET
    Call<WeatherWrapper> weather(@Url String url, @Query("cityname") String cityName);
}

使用@Headers來定義請求頭的鍵值對,也可以同時定義多個請求頭,如下:

@Headers({
    "key1:value1",
    "key2:value2"   
})

動態(tài)請求頭

動態(tài)請求頭以方法參數(shù)的形式存在,示例如下:

@GET
Call<WeatherWrapper> weather(@Header("apikey") String apikey, @Url String url, @Query("cityname") String cityName);

這樣,在發(fā)送請求(調(diào)用方法)時,就可以動態(tài)的定義apikey了。當然,這只是狹義上的動態(tài),只能改變請求頭的值,而不能動態(tài)決定發(fā)送什么請求頭。如果要動態(tài)的定義請求頭,可是使用@HeaderMap。示例如下:

@GET
Call<WeatherWrapper> weather(@HeaderMap Map<String, String> headers, @Url String url, @Query("cityname") String cityName);

在OkHttp的攔截器中管理請求頭

在上面,我們了解了如何使用Retrofit定義請求頭,回到文章開始我們所提及到的,我們通常會為每個API請求添加一些請求頭包含一些額外信息,如果在每個端點聲明都使用@Header來處理就麻煩了。如果你知道在《Retrofit之請求參數(shù)》中如何為每個請求添加相同的url參數(shù),我會很感動的。對,還是使用OkHttp的攔截器。對OkHttp攔截器不熟悉的,可以參考《OkHttp之攔截器》

《OkHttp之示例》中的"訪問Header"中可以了解到,OkHttp提供了兩種方式來添加請求頭字段及值:你可以使用相同的key來重寫已存在的請求頭,或者單純添加而不管是否已有這樣的鍵值對存在。

重寫請求頭

Request.Builder中有個.header(key, value)的方法來允許我們定義請求頭。如果這里之前已經(jīng)定義了一個相同鍵的請求頭,那么之前的則會被重寫。代碼示例如下:

okHttpClientBuilder.addInterceptor(new Interceptor() {
    @Override
    public Response intercept(Chain chain) throws IOException {
        Request original = chain.request();
        Request.Builder requestBuilder = original.newBuilder()
                .header("token", "xxx")
                .header("token", "yyy");
        Request request = requestBuilder.build();
        return chain.proceed(request);
    }
});

最終請求頭token的值會從"xxx"重寫為"yyy"。如果應用中用戶登錄會持有一個token,之后需要加入到請求中,當token改變時(可能是更改密碼造成),此時token就應該更新,這時候就應該使用到重寫請求頭的方式。

不重寫請求頭

如果說我們在定義請求頭而不想讓之前已定義的不被重寫,從而兩個都存在,那么可以使用addHeader()方法替代header()方法,就是這么簡單,根據(jù)你的情況去合理使用即可。

請求頭在項目中的應用

以我當前的項目來講,會通過OkHttp攔截器的方式來添加請求頭,具體代碼示例如下:

okHttpClientBuilder.addInterceptor(new Interceptor() {
    @Override
    public Response intercept(Chain chain) throws IOException {
        Request original = chain.request();
        Request.Builder requestBuilder = original.newBuilder()
                .header("platform", "platform")//平臺
                .header("sysVersion", "sysVersion")//系統(tǒng)版本號
                .header("device", "device")//設(shè)備信息
                .header("screen", "screen")//屏幕大小
                .header("uuid", "uuid")//設(shè)備唯一碼
                .header("version", "version")//app版本
                .header("apiVersion", "apiVersion")//api版本
                .header("token", "token")//令牌
                .header("channelId", "channelId")//渠道
                .header("networkType", "networkType");//網(wǎng)絡(luò)類型
        Request request = requestBuilder.build();
        return chain.proceed(request);
    }
});

至于你的項目,就看需求了。Ok,關(guān)于使用Retrofit定義請求頭就討論到這里。我們已經(jīng)討論了關(guān)于請求的url定義、參數(shù)以及請求頭,接下來得討論下請求的發(fā)送、取消以及復用了。

源碼地址:
https://github.com/FILWAndroid/DevJourney

關(guān)于源碼:

  1. 不只是本文涉及的代碼,會包含很多知識點的代碼,應該都會在我的簡書中進行介紹。
  2. 有可能代碼與本文中所貼出來的有差異,但應該都是我覺得更好的方式吧。
  3. 新浪微博相關(guān)的代碼運行顯示不出來結(jié)果,感興趣的可以參考新浪微博SDK,配置工程。
  4. 歡迎大家對我進行批評教育。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,461評論 6 532
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,538評論 3 417
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,423評論 0 375
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,991評論 1 312
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,761評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,207評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,268評論 3 441
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,419評論 0 288
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 48,959評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 40,782評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,983評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,528評論 5 359
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 44,222評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,653評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,901評論 1 286
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,678評論 3 392
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,978評論 2 374

推薦閱讀更多精彩內(nèi)容