OKHTTP3的简单使用,表单提交,json传递
来源:互联网 发布:spss筛选数据统计 编辑:程序博客网 时间:2024/06/03 18:15
OKHTTP3的简单使用
使用okhttp3需引入以下依赖
compile 'com.squareup.okio:okio:1.13.0' compile 'com.squareup.okhttp3:okhttp:3.9.0'
1.okhttp GET方式请求
//创建OkHttpClient对象 OkHttpClient okHttpClient = new OkHttpClient.Builder() .connectTimeout(10, TimeUnit.SECONDS) .writeTimeout(10,TimeUnit.SECONDS) .readTimeout(20, TimeUnit.SECONDS) .build(); final Request request = new Request.Builder() .url("http://172.20.192.168:8080/getbookByFrom?name=android基础&price=50")//请求的url .get()//设置请求方式,get()/post() 查看Builder()方法知,在构建时默认设置请求方式为GET .build(); //构建一个请求Request对象 //创建/Call Call call = okHttpClient.newCall(request); //加入队列 异步操作 call.enqueue(new Callback() { //请求错误回调方法 @Override public void onFailure(Call call, IOException e) { System.out.println("连接失败"); } //异步请求(非主线程) @Override public void onResponse(Call call, Response response) throws IOException { if(response.code()==200) { System.out.println(response.body().string()); } });
注:在okhttp2中 如果想设置超时时间直接通过OkHttpClient 对象来设置
okHttpClient .setConnectTimeout(10, TimeUnit.SECONDS); okHttpClient .setWriteTimeout(10, TimeUnit.SECONDS); okHttpClient .setReadTimeout(20, TimeUnit.SECONDS);
但okhttp3OkHttpClient 对象没有这个方法,需要借助new OkHttpClient.Builder()按照上面的方法设置超时时间。
2.okhttp POST方式请求(提交表单方式)
OkHttpClient okHttpClient = new OkHttpClient.Builder() .connectTimeout(10, TimeUnit.SECONDS) .writeTimeout(10,TimeUnit.SECONDS) .readTimeout(20, TimeUnit.SECONDS) .build(); //post方式提交的数据 FormBody formBody = new FormBody.Builder() .add("name", "android基础") .add("price", "50") .build(); final Request request = new Request.Builder() .url("http://172.20.192.168:8080/getbookByFrom")//请求的url .post(formBody) .build(); //创建/Call Call call = okHttpClient.newCall(request); //加入队列 异步操作 call.enqueue(new Callback() { //请求错误回调方法 @Override public void onFailure(Call call, IOException e) { System.out.println("连接失败"); } @Override public void onResponse(Call call, Response response) throws IOException { if(response.code()==200) { System.out.println(response.body().string()); } } });
3.okhttp POST方式请求(提交json方式)
OkHttpClient okHttpClient = new OkHttpClient.Builder() .connectTimeout(10, TimeUnit.SECONDS) .writeTimeout(10,TimeUnit.SECONDS) .readTimeout(20, TimeUnit.SECONDS) .build(); Book book = new Book(); book.setName("android基础"); book.setPrice(59); //使用Gson 添加 依赖 compile 'com.google.code.gson:gson:2.8.1' Gson gson = new Gson(); //使用Gson将对象转换为json字符串 String json = gson.toJson(book); //MediaType 设置Content-Type 标头中包含的媒体类型值 RequestBody requestBody = FormBody.create(MediaType.parse("application/json; charset=utf-8"), json); Request request = new Request.Builder() .url("http://172.20.192.168:8080/getbookByJson")//请求的url .post(requestBody) .build(); //创建/Call Call call = okHttpClient.newCall(request); //加入队列 异步操作 call.enqueue(new Callback() { //请求错误回调方法 @Override public void onFailure(Call call, IOException e) { System.out.println("连接失败"); } @Override public void onResponse(Call call, Response response) throws IOException { System.out.println(response.body().string()); } });
阅读全文
0 0
- OKHTTP3的简单使用,表单提交,json传递
- okhttp3的简单使用
- okHttp3的简单使用
- okhttp3.0的简单使用
- 一个使用JS提交表单并传递参数的问题
- 简单的表单传递
- OkHttp3+Retiofit结合使用简单的写法
- RxJava实战演示3----okhttp3表单提交
- HTML5中使用JSON格式提交表单
- 简单的form表单提交...
- 使用JavaScript实现表单的前端简单验证后提交
- 使用JSON数据向服务器提交和获取服务器传递的Json数据
- form表单的ajax提交【组装json】
- OkHttp3的简单封装
- 无刷新提交表单(php+jquery+ajax+json的一个最简单实例 )
- json 跨域 表单提交
- 使用struts2框架提交表单时不能传递到后台的问题
- JSP使用get方法提交表单或者超链接传递参数时候中文乱码的解决方法
- PAT_A 1059. Prime Factors (25)
- HDU 6138 AC自动机
- yii2.0 的安装
- 计算结构体的大小
- 【PAT】【Advanced Level】1057. Stack (30)
- OKHTTP3的简单使用,表单提交,json传递
- 阿里云服务器部署个人博客
- sublime执行出现编码错误
- Linux 使用selenium chrome实现爬虫的两个坑
- unrecognized Windows Sockets error: 10106: create
- Composer安装Thinkphp5
- 【福分系统】MUI日期控件
- ios-Swift中解除循环引用的三种方式
- 有源汇有上下界最小流详解(loj117)