Android網路請求(2) 在android網路開發中,除get請求外常見的還有post、put、delete這三種,接下來我們將詳細講解這三種請求及參數 GET請求 我們使用過get請求了,對於我們的日常生活中get請求毫無疑問是最常用的請求方式,大部分的瀏覽器搜索都是通過get請求,如在百度上 ...
Android網路請求(2)
在android網路開發中,除get請求外常見的還有post、put、delete這三種,接下來我們將詳細講解這三種請求及參數
GET請求
我們使用過get請求了,對於我們的日常生活中get請求毫無疑問是最常用的請求方式,大部分的瀏覽器搜索都是通過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是傳輸協議,www是一個子域,也是萬維網的縮寫,baidu是二級功能變數名稱,com是一級功能變數名稱,s是訪問路徑,以問號開始每一個參數都是以=賦值,以&分割,等號前是參數名,等號後是參數值。
對於日常瀏覽中,通過get請求往往是請求一個瀏覽器頁面,實際上是請求一串數據,因為get請求一般只用於查詢數據並不會對資料庫中的數據產生任何影響,所以日常開發中get請求的使用是非常頻繁的。
get請求的使用方式上一章已經說過了,就不再演示了。
POST請求
post我們在瀏覽器上沒安裝插件時無法完成的,我們可以下載postman或在線上調試網站中進行post請求測試。在安全性上post請求要比get請求更加安全,同時不會暴露我們所攜帶的參數。但是post請求也並不絕對安全,它同樣能夠被抓包軟體抓取數據,如果對安全性有要求,那麼還需要對數據進行加密。
post請求一般用於登陸驗證,創建訂單等對安全性和身份驗證有一定需求的場景。現在常見的post請求四大方式有:
(1)、application/x-www-form-urlencoded
(2)、multipart/form-data
(3)、application/json
(4)、text/xml
而在安卓開發中最常見的是第三個application/json,將它設置在頭文件中是告訴服務端我們請求時所發送的參數是以json格式發送的。關於json是什麼以及其它三種方式感興趣的可以去找一找相關資料。
那麼我們開始創建我們的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();//發起網路請求
connection.setConnectTimeout(8000);//連接最大時間
connection.setReadTimeout(8000);//讀取最大時間
// 最大的差別就是修改了請求方式添加了請求頭文件數據以及通過OutputStreamWriter發送了攜帶的json數據
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流開了要關,不然容易記憶體泄露
}catch (IOException e){
e.printStackTrace();
}
}
if(connection != null){
connection.disconnect();//同理,關閉http連接
}
}
return response.toString();
}
那麼我們去試驗一下這個請求吧,我們登錄試一試,攜帶我們的賬號密碼,看看會返回什麼。
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);//這串網址請自行使用其它可發送post請求的鏈接
System.out.println(post);
}
}).start();
通過我們人工構造一個json數據,新建線程進行訪問並列印,我們得到
因為我們使用的賬號密碼並不存在所以登錄失敗了,我們可以使用自己的賬號密碼去嘗試登錄自己想測試的網站,當然有些網站的登錄需要二級驗證,這個我們暫且不講。
PUT請求
put請求常用於修改數據,如用戶信息,密碼等。使用的方法與post請求相似,只需要修改請求方式post改為put即可,一般需要攜帶用戶認證信息token,用於確認是哪個用戶需要修改自身的信息。在請求中,使用它一般只是修改信息,所以對於post請求來講,它更加安全,post請求創建用戶時是會創建數據的,put請求不會。
也不演示怎麼寫了,直接把上面的post請求拿過來修改connection.setRequestMethod("POST");為PUT即可。
DELETE請求
put請求的請求方式與post相識,那麼delete請求的請求方式也與get請求相識,也是在get請求的基礎上修改connection.setRequestMethod("GET");為DELETE即可。
DELETE請求一般用於刪除表中的數據。也是可以攜帶數據的。如用戶身份驗證信息token之類的。
總結
相信看到這,大家也知道了,四種請求方法對應資料庫的增刪改查,但也有些後端開發人員喜歡所有的請求都通過post方式,所以大家不要固定思維,請求方式只是便於我們更好理解以及規範開發,並非一定要通過get查詢,通過post增加,也可以通過delete增加數據,主要看後端開發人員是怎樣規定的。
四種請求類型中post請求是對數據最安全的,但對資料庫就不那麼友好,因為它會增加資料庫中的數據,可能會導致意外的錯誤,同樣,這些不是我們該關係的,是服務端開發人員該去規劃和設計的。