<output id="qn6qe"></output>

    1. <output id="qn6qe"><tt id="qn6qe"></tt></output>
    2. <strike id="qn6qe"></strike>

      亚洲 日本 欧洲 欧美 视频,日韩中文字幕有码av,一本一道av中文字幕无码,国产线播放免费人成视频播放,人妻少妇偷人无码视频,日夜啪啪一区二区三区,国产尤物精品自在拍视频首页,久热这里只有精品12

      Android網(wǎng)絡(luò)請求(2)

      Android網(wǎng)絡(luò)請求(2)

      在android網(wǎng)絡(luò)開發(fā)中,除get請求外常見的還有post、put、delete這三種,接下來我們將詳細講解這三種請求及參數(shù)

      GET請求

      我們使用過get請求了,對于我們的日常生活中g(shù)et請求毫無疑問是最常用的請求方式,大部分的瀏覽器搜索都是通過get請求,如在百度上搜索"花",那么我們在瀏覽器上的地址欄中就能看到一串鏈接

      https://www.baidu.com/s?wd=%E8%8A%B1&rsv_spt=1&rsv_iqid=0xc02e78cd00039b5a&issp=1&f=8&rsv_bp=1&rsv_idx=2&ie=utf-8&tn=baiduhome_pg&rsv_enter=1&rsv_dl=tb&rsv_sug3=5&rsv_sug1=1&rsv_sug7=100&rsv_sug2=0&rsv_btype=i&inputT=1533&rsv_sug4=2173
      

      在這串鏈接中https是傳輸協(xié)議,www是一個子域,也是萬維網(wǎng)的縮寫,baidu是二級域名,com是一級域名,s是訪問路徑,以問號開始每一個參數(shù)都是以=賦值,以&分割,等號前是參數(shù)名,等號后是參數(shù)值。

      對于日常瀏覽中,通過get請求往往是請求一個瀏覽器頁面,實際上是請求一串?dāng)?shù)據(jù),因為get請求一般只用于查詢數(shù)據(jù)并不會對數(shù)據(jù)庫中的數(shù)據(jù)產(chǎn)生任何影響,所以日常開發(fā)中g(shù)et請求的使用是非常頻繁的。

      get請求的使用方式上一章已經(jīng)說過了,就不再演示了。

      POST請求

      post我們在瀏覽器上沒安裝插件時無法完成的,我們可以下載postman或在在線調(diào)試網(wǎng)站中進行post請求測試。在安全性上post請求要比get請求更加安全,同時不會暴露我們所攜帶的參數(shù)。但是post請求也并不絕對安全,它同樣能夠被抓包軟件抓取數(shù)據(jù),如果對安全性有要求,那么還需要對數(shù)據(jù)進行加密。

      post請求一般用于登陸驗證,創(chuàng)建訂單等對安全性和身份驗證有一定需求的場景。現(xiàn)在常見的post請求四大方式有:

      ? (1)、application/x-www-form-urlencoded

      ? (2)、multipart/form-data

      ? (3)、application/json

      ? (4)、text/xml

      而在安卓開發(fā)中最常見的是第三個application/json,將它設(shè)置在頭文件中是告訴服務(wù)端我們請求時所發(fā)送的參數(shù)是以json格式發(fā)送的。關(guān)于json是什么以及其它三種方式感興趣的可以去找一找相關(guān)資料。

      那么我們開始創(chuàng)建我們的post請求吧。

      編寫請求方法

      public static String post(String src,String json){
              HttpURLConnection connection = null;
              BufferedReader reader = null;
              StringBuilder response = null;
              try{
                  URL url = new URL(src);//新建URL
                  connection = (HttpURLConnection)url.openConnection();//發(fā)起網(wǎng)絡(luò)請求
      
                  connection.setConnectTimeout(8000);//連接最大時間
                  connection.setReadTimeout(8000);//讀取最大時間
      
      //            最大的差別就是修改了請求方式添加了請求頭文件數(shù)據(jù)以及通過OutputStreamWriter發(fā)送了攜帶的json數(shù)據(jù)
      
                  connection.setRequestMethod("POST");//請求方式
                  connection.setRequestProperty("Content-Type", "application/json");
                  OutputStreamWriter out = new OutputStreamWriter(connection.getOutputStream());
                  out.write(json);
                  out.flush();
                  out.close();
      
      
                  InputStream in = connection.getInputStream();
                  reader = new BufferedReader(new InputStreamReader(in));//寫入reader
                  response = new StringBuilder();
                  String line;
                  while((line = reader.readLine()) != null){
                      response.append(line);
                  }
              }catch (Exception e){//異常拋出
                  e.printStackTrace();
              }finally {
                  if(reader != null){
                      try{
                          reader.close();//io流開了要關(guān),不然容易內(nèi)存泄露
                      }catch (IOException e){
                          e.printStackTrace();
                      }
                  }
                  if(connection != null){
                      connection.disconnect();//同理,關(guān)閉http連接
                  }
              }
              return response.toString();
          }
      

      那么我們?nèi)ピ囼炓幌逻@個請求吧,我們登錄試一試,攜帶我們的賬號密碼,看看會返回什么。

      String json = "{\"username\":\"test01\",\"password\":\"123456\"}";
              new Thread(new Runnable() {
                  @Override
                  public void run() {
                      String post = InterNet.post("http://xxx.xxx.xxx/xxx-xx/xxx/login", json);//這串網(wǎng)址請自行使用其它可發(fā)送post請求的鏈接
                      System.out.println(post);
                  }
              }).start();
      

      通過我們?nèi)斯?gòu)造一個json數(shù)據(jù),新建線程進行訪問并打印,我們得到

      因為我們使用的賬號密碼并不存在所以登錄失敗了,我們可以使用自己的賬號密碼去嘗試登錄自己想測試的網(wǎng)站,當(dāng)然有些網(wǎng)站的登錄需要二級驗證,這個我們暫且不講。

      PUT請求

      put請求常用于修改數(shù)據(jù),如用戶信息,密碼等。使用的方法與post請求相似,只需要修改請求方式post改為put即可,一般需要攜帶用戶認證信息token,用于確認是哪個用戶需要修改自身的信息。在請求中,使用它一般只是修改信息,所以對于post請求來講,它更加安全,post請求創(chuàng)建用戶時是會創(chuàng)建數(shù)據(jù)的,put請求不會。

      也不演示怎么寫了,直接把上面的post請求拿過來修改connection.setRequestMethod("POST");為PUT即可。

      DELETE請求

      put請求的請求方式與post相識,那么delete請求的請求方式也與get請求相識,也是在get請求的基礎(chǔ)上修改connection.setRequestMethod("GET");為DELETE即可。

      DELETE請求一般用于刪除表中的數(shù)據(jù)。也是可以攜帶數(shù)據(jù)的。如用戶身份驗證信息token之類的。

      總結(jié)

      相信看到這,大家也知道了,四種請求方法對應(yīng)數(shù)據(jù)庫的增刪改查,但也有些后端開發(fā)人員喜歡所有的請求都通過post方式,所以大家不要固定思維,請求方式只是便于我們更好理解以及規(guī)范開發(fā),并非一定要通過get查詢,通過post增加,也可以通過delete增加數(shù)據(jù),主要看后端開發(fā)人員是怎樣規(guī)定的。

      四種請求類型中post請求是對數(shù)據(jù)最安全的,但對數(shù)據(jù)庫就不那么友好,因為它會增加數(shù)據(jù)庫中的數(shù)據(jù),可能會導(dǎo)致意外的錯誤,同樣,這些不是我們該關(guān)系的,是服務(wù)端開發(fā)人員該去規(guī)劃和設(shè)計的。

      好了,四種請求方式都講完了。接下來我們來講講安卓開發(fā)中最常用的網(wǎng)絡(luò)框架---okhttp

      posted @ 2022-11-22 16:41  高同學(xué),你好  閱讀(690)  評論(0)    收藏  舉報
      主站蜘蛛池模板: 国产成人精品日本亚洲| 精品人妻少妇嫩草av专区| 无套后入极品美女少妇| 日本熟妇人妻xxxxx人hd| 国产喷水1区2区3区咪咪爱AV| 欧美成人黄在线观看| 嫩草院一区二区乱码| 民丰县| 天天天做夜夜夜做无码| 国产日韩综合av在线| 国产老头多毛Gay老年男| 亚洲国产成人久久一区久久| 在线观看美女网站大全免费| 人妻少妇456在线视频| 乌鲁木齐市| 国产精品高清一区二区三区| 在线a级毛片无码免费真人| 国产精品三级在线观看无码| 国产极品粉嫩尤物一线天| 在线精品国精品国产尤物| 国产在线98福利播放视频| 亚洲大尺度无码无码专线| 无人区码一码二码三码区| 亚洲女同精品中文字幕| 国产不卡免费一区二区| 久久久精品94久久精品| 国产成人 综合 亚洲欧洲| 亚洲色拍拍噜噜噜最新网站| 色综合久久中文综合久久激情| 97久久超碰亚洲视觉盛宴| 少妇愉情理伦片高潮日本 | 毛片av在线尤物一区二区| 最新日韩精品中文字幕| 通州区| 性视频一区| 好姑娘高清影视在线观看| 精品视频不卡免费观看| a级免费视频| 日本一区不卡高清更新二区| 永德县| 日本亚洲一区二区精品久久|