文章目录
- GET和POST的区别
- GET和POST的安全性
- GET方法的长度限制
- HTTP请求限制
- 创建安全配置文件
- 添加安全配置文件
- GET实现
- POST实现
- 注意
GET和POST的区别
- GET是从服务器上获得数据,而POST则是向服务器传递数据的
- GET是不安全的,一些操作会被第三方看到,而POST的所有操作多用户来说是不可见的
- GET传输的数据量小,主要是因为它受约于URL长度的限制,而POST可以传输大量的数据,所以在传文件的时候会用POST
- GET限制From表单的数据集的值必须为ASCLL字符,而POST支持整个ISO10646字符集
GET和POST的安全性
关于POST比GET更安全,体现在其数据在地址栏是不可见的角度
但是从传输角度来说,因为HTTP在网络上都是明文传输,所以在传输上它们都很容易被抓包来获取数据报文
想要安全传输需使用HTTPS
GET方法的长度限制
HTTP协议本身没有对URL的长度限制,对URL的限制大多是浏览器和服务器的原因
服务器处理长URL要消耗较多的资源,为了性能和安全(恶意构造长URL进行攻击)考虑,会给URL长度加以限制
HTTP请求限制
创建安全配置文件
- 在res文件夹下创建xml/network_security_config文件
- 增加cleartextTrafficPermitted属性,设为
true
添加安全配置文件
- AndroidManifest.xml中的Application申明
GET实现
请求的URL:http://www.imooc.com/api/teacher?type=3&cid=1
- 实例化一个URL对象
- 获取HttpURLConnection实例
- 设置和请求相关的属性
- 获取响应码
- 判断响应码并获取响应数据(响应正文)
private void get() {
try {
// HttpURLConnection
// 1.实例化一个URL对象
URL url = new URL("http://www.imooc.com/api/teacher?type=3&cid=1");
// 2.获取HttpURLConnection实例
HttpURLConnection conn = (HttpURLConnection) url.openConnection();
// 3.设置和请求相关的属性
/// 请求方式
conn.setRequestMethod("GET");
/// 请求超时时长
conn.setConnectTimeout(6000);
// 4.获取响应码 200:成功 404:未请求到指定资源 500:服务器异常
if (conn.getResponseCode() == HttpURLConnection.HTTP_OK) {
// 5.判断响应码并获取响应数据(响应正文)
/// 获取响应的流
InputStream in = conn.getInputStream();
byte[] b = new byte[1024];
int len = 0;
ByteArrayOutputStream baos = new ByteArrayOutputStream();
/// 在循环中读取输入流
while ((len = in.read(b)) > -1) {// in.read()返回是int类型数据,代表实际读到的数据长度
// 将字节数组里面的内容写入缓存流
// 参数1:待写入的数组 参数2:起点 参数3:长度
baos.write(b, 0, len);
}
String msg = new String(baos.toByteArray());
Log.e("TAG", msg + "======");
}
} catch (MalformedURLException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
运行结果
2020-07-22 00:39:18.104 20976-21029/com.example.shopappdemo E/TAG: {"status":1,"data":{"title":"Tony\u8001\u5e08\u804ashell\u2014\u2014\u73af\u5883\u53d8\u91cf\u914d\u7f6e\u6587\u4ef6","author":"Tony","content":"\u672c\u8bfe\u7a0b\u662f\u300aTony\u8001\u5e08\u804ashell\u300b\u7cfb\u5217\u8bfe\u7a0b\u7684\u7b2c\u4e09\u7bc7\uff0c\u4e3a\u4f60\u5e26\u6765\u5e38\u7528\u7684\u73af\u5883\u53d8\u91cf\u914d\u7f6e\u6587\u4ef6\u7684\u4f7f\u7528\u3002"},"msg":"\u6210\u529f"}======
这里获取到的\uxxxx
是Unicode编码,是并未解析的原始数据
POST实现
这里用登录功能来举例,实现提交并读取用户输入的账号user
和密码pwd
请求的URL:http://www.imooc.com/api/okhttp/postmethod
POST的实现步骤和GET差别不大,只需要修改下面这几个地方
- 实例化URL对象,修改一下URL
URL url = new URL("http://www.imooc.com/api/okhttp/postmethod");
- 修改第三步的请求方式,并在其下面设置相应属性
// 3.设置和请求相关的属性
///请求方式
conn.setRequestMethod("POST");
/// 请求超时时长
conn.setConnectTimeout(6000);
/// 设置允许输出
conn.setDoOutput(true);
/// 设置请求数据的类型
conn.setRequestProperty("Content-Type", "application/x-www-form-urlencoded");
/// 获取输出流(请求正文)
OutputStream out = conn.getOutputStream();
/// 写数据
out.write(("user=" + user + "&pwd=" + pwd).getBytes());
运行结果
输入账号:admin,密码:12345
2020-07-22 15:22:58.556 24019-24377/com.example.shopappdemo E/TAG: {"errorCode":1,"data":{"ip":"183.27.156.22","headers":{"Accept-Encoding":"gzip","User-Agent":"Dalvik\/2.1.0 (Linux; U; Android 11; sdk_gphone_x86 Build\/RPB1.200504.020)","Content-Type":"application\/x-www-form-urlencoded","Content-Length":"20","X-Forwarded-For":"183.27.156.22","X-Real-Ip":"183.27.156.22","Host":"www.imooc.com","Connection":"upgrade"},"params":"user=admin&pwd=12345"},"errorMsg":""}======
这里的原始数据都是JSON数据
JSON是一种与开发语言无关的、轻量级的数据存储格式,一种数据格式的标准规范。像上面通过GET和POST方法读到的数据就是JSON的原始数据。
优点:易于用户阅读和编写,易于程序解析与生产
JSON样例:首先是一对花括号{}
,代表一整个JSON对象,同时里面是一种Key-Value的存储形式
注意
- 权限问题,要提前完成网络权限配置
- 网络操作需要开辟一个新的线程来执行
- 可以利用
JSONObject
进行解析获取到的JSON数据