react native https網(wǎng)絡(luò)請求

使用實(shí)例

1聪建、使用get方式進(jìn)行網(wǎng)絡(luò)請求略贮,例如:

fetch('http://nero-zou.com/test', {  
    method: 'GET'
}).then(function(response) {
    //獲取數(shù)據(jù),數(shù)據(jù)處理
}).catch(function(err) {
    //錯誤處理
});

2氧腰、使用post方式進(jìn)行網(wǎng)絡(luò)請求,例如:

let param = {user:'xxx',phone:'xxxxxx'};
fetch(url, {  
    method: 'post',
    body: JSON.stringify(param)
}).then(function(response) {
    //獲取數(shù)據(jù),數(shù)據(jù)處理
});

3刨肃、其它寫法,例如:

try {
       fetch(url, {  
            method: 'post',
            body: JSON.stringify(param)
        }).then(function(response) {
            //獲取數(shù)據(jù),數(shù)據(jù)處理
        });  
    } catch(e) {
         //捕獲異常消息    
    }

4箩帚、帶header 或其它參數(shù)

fetch(url, {
  method: 'POST',
  headers: {
    'Accept': 'application/json',
    'Content-Type': 'application/json',
  },
  body: JSON.stringify({
    firstParam: 'yourValue',
    secondParam: 'yourOtherValue',
  })
})

怎樣進(jìn)行封裝

基本上要求是寫個基礎(chǔ)的函數(shù),其它在進(jìn)行網(wǎng)絡(luò)請求時都調(diào)用這個函數(shù)真友。即使以后不使用fetch直接將這個基礎(chǔ)函數(shù)修改,不用修改其它的地方就可以實(shí)現(xiàn)紧帕。

基礎(chǔ)函數(shù)的模型一般是這樣的

function sendNetRequest(...props) {
  this.url = props.shift(1);
  this.options = props.shift(1);   
  return fetch(this.url, Object.assign({}, this.options))
  .then((response) =>return response.json());
}

封裝各個接口

//封裝login 接口
 function  postLogin(userName,password) {  
    let loginParam= {user:userName,password:password};    
    var loginApiPort = "mlogin";//login 對應(yīng)的接口
    //下面的baseURL=https://XXXXX.com 
    return sendNetRequest(`${baseURL}/${loginApiPort}`, {
      method: 'post',
      body: JSON.stringify(loginParam),
      headers: {
           'Content-Type': 'application/x-www-form-urlencoded',
       },
    });
  }
  //...其它一系列接口的封裝

調(diào)用實(shí)例

try {
         postLogin(user,password)
         .then((response) => {
            //獲取數(shù)據(jù),數(shù)據(jù)處理
         })
      } catch(e) {
        //捕獲異常消息  
      }

這樣就大功告成了盔然,下面是遇到的常見問題

常見問題

1桅打、請求時,出現(xiàn)異常

header里面的Content-Type設(shè)置為‘a(chǎn)pplication/x-www-form-urlencoded’愈案,如果還是報(bào)錯問server端參數(shù)是什么格式 挺尾,然后設(shè)置Content-Type的值即可.

2、響應(yīng)時站绪,出現(xiàn)異常

上述封裝容易出現(xiàn)的問題在response.json()這一句中遭铺,如果response==null就會拋出異常,建議先判斷response是否為null恢准,如果為null再進(jìn)行特殊處理魂挂。

3、fetch設(shè)置超時的時間

fetch本身目前沒有設(shè)置超時時間的屬性馁筐,只能機(jī)制來進(jìn)行設(shè)置涂召。fetch函數(shù)在各個平臺的實(shí)現(xiàn),如果你看到源代碼的話肯定會覺得能設(shè)置超時而且很容易敏沉,但是它封裝的時候并沒有把 這個作為一個屬性來設(shè)置.因此只能結(jié)合promise機(jī)制使用setTimeout來設(shè)置超時的時間果正。

4、https盟迟,如果server端是無效證書來進(jìn)行https請求的時候出現(xiàn)的錯誤

SSLHandshake: Received fatal alert: certificate_expired

或者是

SSLHandshake: Remote host closed connection during handshake 
…

(1)在android暫時無解 秋泳,只能用http,因?yàn)樗荒芨淖儙炖锩娴暮瘮?shù)队萤。如果非要支持https 轮锥,只能將你的工程目錄 + node_modules/react-native/android/com/facebook/react/react-native/0.36.0/react-native-0.36.0-sources.jar!/com/facebook/react/modules/network/OkHttpClientProvider.java

其他rn版本的文件目錄可以推測要尔,總的來說是修改reactnativenetwork庫里面的OkHttpClientProvider.Java這個文件舍杜。OkHttpClientProvider.java中找到下述代碼

return new OkHttpClient.Builder()
      .connectTimeout(0, TimeUnit.MILLISECONDS)
      .readTimeout(0, TimeUnit.MILLISECONDS)
      .writeTimeout(0, TimeUnit.MILLISECONDS)
      .cookieJar(new ReactCookieJarContainer())
      .build();

改為:

return new OkHttpClient.Builder()
            .sslSocketFactory(sslContext.getSocketFactory())
            .hostnameVerifier(new HostnameVerifier() {
                @Override
                public boolean verify(String hostname, SSLSession session) {
                    return true; //忽略所有的認(rèn)證,直接返回了true
                }
            })
            .connectTimeout(0, TimeUnit.MILLISECONDS)
            .readTimeout(0, TimeUnit.MILLISECONDS)
            .writeTimeout(0, TimeUnit.MILLISECONDS)
            .cookieJar(new ReactCookieJarContainer())
            .build();

(2)iOS 端 赵辕,用xcode打開ios目錄下的工程既绩,找到infor.plist,并添加屬性

<key>NSAppTransportSecurity</key>
    <dict>
          <key>NSAllowsArbitraryLoads</key>
          <true/>
    </dict>

肯定還是報(bào)錯 还惠,找到React native的networking 庫(Libraries -> RCTNetworking -> RCTHTTPRequestHandler.mm -> #pragma mark NSURLSession delegate)饲握,在庫里面添加NSURLSession delegate函數(shù)處理ssl證書認(rèn)證的相關(guān)代碼,設(shè)置為都為pass蚕键,你可以根據(jù)是否是debug模式來選擇是不是pass 救欧,如果是release 版建議不要這樣做。
如這個函數(shù)

//根據(jù)你自己的邏輯處理這個函數(shù)锣光,加點(diǎn)判斷千萬別直接pass,有安全隱患,如果都pass了還不如用http省的麻煩笆怠。
//只要請求的地址是HTTPS的, 就會調(diào)用這個代理方法
//challenge:質(zhì)詢
//NSURLAuthenticationMethodServerTrust:服務(wù)器信任
-(void)URLSession:(NSURLSession *)session task:(NSURLSessionTask *)task didReceiveChallenge:(NSURLAuthenticationChallenge *)challenge completionHandler:(void (^)(NSURLSessionAuthChallengeDisposition, NSURLCredential * _Nullable))completionHandler
{
    NSLog(@"%@",challenge.protectionSpace);

    if (![challenge.protectionSpace.authenticationMethod isEqualToString:@"NSURLAuthenticationMethodServerTrust"]) return;
    /*
     NSURLSessionAuthChallengeUseCredential 使用證書
     NSURLSessionAuthChallengePerformDefaultHandling  忽略證書 默認(rèn)的做法
     NSURLSessionAuthChallengeCancelAuthenticationChallenge 取消請求,忽略證書
     NSURLSessionAuthChallengeRejectProtectionSpace 拒絕,忽略證書
     */

    NSURLCredential *credential = [NSURLCredential credentialForTrust:challenge.protectionSpace.serverTrust];

    completionHandler(NSURLSessionAuthChallengeUseCredential,credential);
}

實(shí)例

BaseServiceApiNet.js文件

const baseURL = "https://api.app.net";
function fetchAction(...props) {
  this.url = props.shift(1);
  this.options = props.shift(1);
  return fetch(this.url, Object.assign({}, this.options))
  .then((response) =>response.json());
}
export default {
  getTest() {
    var apiPort = "stream/0/posts/stream/global";
    return fetchAction(`${baseURL}/${apiPort}`, {
      method: 'get',
      headers: {
        'Content-Type': 'application/x-www-form-urlencoded',
      },
    });
  }
};

index.ios.js文件

import React, { Component } from 'react';
import {
  AppRegistry,
  StyleSheet,
  Text,
  View,
  ActivityIndicator
} from 'react-native';
import BaseServiceApiNet from './BaseServiceApiNet';
export default class ZXJNetDemo extends Component {
  constructor(props){
    super(props);
    this.state ={
      isLoading:false,
      resultJson:null
    };
  }
  sendTestRequest(){
    if(this.state.isLoading==true){
      return;
    }
    this.setState({
      resultJson:null,
      isLoading:true
    });
    try {
        BaseServiceApiNet.getTest()
        .then((response) => {
           let data = response.meta;
           this.setState({
             resultJson:data==null?null:JSON.stringify(data),
             isLoading:false
           });
           console.log("返回?cái)?shù)據(jù):"+JSON.stringify(data));
        })
    } catch(e) {
      alert(e);
      this.setState({
         isLoading:false
      });
    }
  }
  render() {
    return (
      <View style={styles.container}>
        <ActivityIndicator  animating={this.state.isLoading}  />
        <Text style={styles.welcome} onPress={this.sendTestRequest.bind(this)}>
          測試網(wǎng)絡(luò)
        </Text>
        <Text style={styles.instructions}>
        {this.state.resultJson}
        </Text>
      </View>
    );
  }
}

const styles = StyleSheet.create({
  container: {
    flex: 1,
    justifyContent: 'center',
    alignItems: 'center',
    backgroundColor: '#F5FCFF',
  },
  welcome: {
    fontSize: 20,
    textAlign: 'center',
    margin: 10,
  },
  instructions: {
    textAlign: 'center',
    color: '#333333',
    marginBottom: 5,
  },
});

AppRegistry.registerComponent('ZXJNetDemo', () => ZXJNetDemo);

運(yùn)行結(jié)果


參考:
http://blog.csdn.net/qq_16086969/article/details/53522980#t11
http://www.cnblogs.com/liugengqun/p/5141482.html

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市誊爹,隨后出現(xiàn)的幾起案子蹬刷,更是在濱河造成了極大的恐慌瓢捉,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,968評論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件办成,死亡現(xiàn)場離奇詭異泡态,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)迂卢,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,601評論 2 382
  • 文/潘曉璐 我一進(jìn)店門某弦,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人冷守,你說我怎么就攤上這事刀崖。” “怎么了拍摇?”我有些...
    開封第一講書人閱讀 153,220評論 0 344
  • 文/不壞的土叔 我叫張陵亮钦,是天一觀的道長。 經(jīng)常有香客問我充活,道長蜂莉,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,416評論 1 279
  • 正文 為了忘掉前任混卵,我火速辦了婚禮映穗,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘幕随。我一直安慰自己蚁滋,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,425評論 5 374
  • 文/花漫 我一把揭開白布赘淮。 她就那樣靜靜地躺著辕录,像睡著了一般。 火紅的嫁衣襯著肌膚如雪梢卸。 梳的紋絲不亂的頭發(fā)上走诞,一...
    開封第一講書人閱讀 49,144評論 1 285
  • 那天,我揣著相機(jī)與錄音蛤高,去河邊找鬼蚣旱。 笑死,一個胖子當(dāng)著我的面吹牛戴陡,可吹牛的內(nèi)容都是我干的塞绿。 我是一名探鬼主播,決...
    沈念sama閱讀 38,432評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼恤批,長吁一口氣:“原來是場噩夢啊……” “哼异吻!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起开皿,我...
    開封第一講書人閱讀 37,088評論 0 261
  • 序言:老撾萬榮一對情侶失蹤涧黄,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后赋荆,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體笋妥,經(jīng)...
    沈念sama閱讀 43,586評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,028評論 2 325
  • 正文 我和宋清朗相戀三年窄潭,在試婚紗的時候發(fā)現(xiàn)自己被綠了春宣。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,137評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡嫉你,死狀恐怖月帝,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情幽污,我是刑警寧澤嚷辅,帶...
    沈念sama閱讀 33,783評論 4 324
  • 正文 年R本政府宣布,位于F島的核電站距误,受9級特大地震影響簸搞,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜准潭,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,343評論 3 307
  • 文/蒙蒙 一趁俊、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧刑然,春花似錦寺擂、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,333評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至武鲁,卻和暖如春爽雄,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背沐鼠。 一陣腳步聲響...
    開封第一講書人閱讀 31,559評論 1 262
  • 我被黑心中介騙來泰國打工挚瘟, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人饲梭。 一個月前我還...
    沈念sama閱讀 45,595評論 2 355
  • 正文 我出身青樓乘盖,卻偏偏與公主長得像,于是被迫代替她去往敵國和親憔涉。 傳聞我的和親對象是個殘疾皇子订框,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,901評論 2 345

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

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 171,522評論 25 707
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)兜叨,斷路器穿扳,智...
    卡卡羅2017閱讀 134,601評論 18 139
  • React Native優(yōu)秀博客衩侥,以及優(yōu)秀的Github庫列表(很多英文資料源自于[awesome-react-n...
    董董董董董董董董董大笨蛋閱讀 10,588評論 4 162
  • 大學(xué)的時候最流行玩CS茫死,CS是Counter-Strike的縮寫,那么CS為什么翻譯成“反恐精英”呢履羞? 提到cou...
    xinxingo閱讀 5,860評論 0 1
  • 三更捧書卷峦萎,略識丙與丁。 俗物愧李杜忆首,不解東坡情爱榔。 謝女猶詠絮,易安作夜吟糙及。 南山護(hù)菊人详幽,暫且采菱荇。 飄飄天地間...
    陳迂閱讀 344評論 1 1