当前位置: 首页 > news >正文

Jetpack Compose 通过 OkHttp 发送 HTTP 请求的示例

下面是一个使用 Kotlin 和 Jetpack Compose 来演示通过 OkHttp 发送 HTTP 请求的示例。这个示例包括在 Jetpack Compose 中发送一个 GET 请求和一个 POST 请求,并显示结果。

在这里插入图片描述

添加okhttp依赖

首先,在你的 build.gradle.kts 文件中添加必要的依赖:

dependencies {implementation("com.squareup.okhttp3:okhttp:4.10.0")//其他依赖
}

INTERNET 权限

你需要在 AndroidManifest.xml 文件中添加网络权限声明。请按照以下步骤操作:

  1. 打开 AndroidManifest.xml 文件。
  2. <manifest> 标签内添加 <uses-permission android:name="android.permission.INTERNET"/>

你的 AndroidManifest.xml 文件应该如下所示:

<manifest xmlns:android="http://schemas.android.com/apk/res/android"package="com.example.yourapp"><uses-permission android:name="android.permission.INTERNET"/><applicationandroid:allowBackup="true"android:icon="@mipmap/ic_launcher"android:label="@string/app_name"android:roundIcon="@mipmap/ic_launcher_round"android:supportsRtl="true"android:theme="@style/Theme.YourApp"><activity android:name=".MainActivity"><intent-filter><action android:name="android.intent.action.MAIN" /><category android:name="android.intent.category.LAUNCHER" /></intent-filter></activity></application></manifest>

添加这个权限声明后,再次运行你的应用程序,它应该能够正常进行网络请求。

主程序代码

import android.os.Bundle
import androidx.activity.ComponentActivity
import androidx.activity.compose.setContent
import androidx.compose.foundation.layout.*
import androidx.compose.material.*
import androidx.compose.material3.MaterialTheme
import androidx.compose.material3.Text
import androidx.compose.runtime.*
import androidx.compose.ui.Modifier
import androidx.compose.ui.tooling.preview.Preview
import androidx.compose.ui.unit.dp
import kotlinx.coroutines.*
import okhttp3.*
import okhttp3.MediaType.Companion.toMediaType
import okio.IOExceptionclass MainActivity : ComponentActivity() {override fun onCreate(savedInstanceState: Bundle?) {super.onCreate(savedInstanceState)setContent {MyApp()}}
}@Composable
fun MyApp() {var getResponse by remember { mutableStateOf("Loading...") }var postResponse by remember { mutableStateOf("Loading...") }LaunchedEffect(Unit) {getResponse = performGetRequest()postResponse = performPostRequest()}Column(modifier = Modifier.padding(16.dp)) {Text(text = "GET Response:", style = MaterialTheme.typography.bodyLarge)Spacer(modifier = Modifier.height(8.dp))Text(text = getResponse)Spacer(modifier = Modifier.height(16.dp))Text(text = "POST Response:", style = MaterialTheme.typography.bodyLarge)Spacer(modifier = Modifier.height(8.dp))Text(text = postResponse)}
}suspend fun performGetRequest(): String = withContext(Dispatchers.IO) {val client = OkHttpClient()val request = Request.Builder().url("https://jsonplaceholder.typicode.com/posts/1").build()client.newCall(request).execute().use { response ->if (!response.isSuccessful) throw IOException("Unexpected code $response")response.body?.string() ?: "No response body"}
}suspend fun performPostRequest(): String = withContext(Dispatchers.IO) {val client = OkHttpClient()val JSON = "application/json; charset=utf-8".toMediaType()val json = """{ "title": "foo", "body": "bar", "userId": 1 }"""val body = RequestBody.create(JSON, json)val request = Request.Builder().url("https://jsonplaceholder.typicode.com/posts").post(body).build()client.newCall(request).execute().use { response ->if (!response.isSuccessful) throw IOException("Unexpected code $response")response.body?.string() ?: "No response body"}
}@Preview(showBackground = true)
@Composable
fun DefaultPreview() {MyApp()
}

参考

某AI的生成

http://www.lryc.cn/news/407006.html

相关文章:

  • Pytorch使用教学3-特殊张量的创建与类型转化
  • 【日记】办个护照不至于有这种刑事罪犯一样的待遇吧……(737 字)
  • 【矩阵微分】在不涉及张量的前提下计算矩阵对向量的导数并写出二阶泰勒展开
  • 数据结构之判断平衡二叉树详解与示例(C,C++)
  • 深入解析仓颉编程语言:函数式编程的核心特性
  • springboot惠农服务平台-计算机毕业设计源码50601
  • Lua脚本简单理解
  • AutoSAR自适应平台架构总览--AP的初认识
  • GPT-4o Mini:探索最具成本效益的小模型在软件开发中的应用
  • {Spring Boot 原理篇} Spring Boot自动装配原理
  • QEMU源码全解析 —— CPU虚拟化(10)
  • 46、PHP实现矩阵中的路径
  • c++笔记2
  • 通过Lua脚本手写redis分布式锁
  • 解析银行个人征信系统
  • AttributeError: ‘list‘ object has no attribute ‘text‘
  • Codeforces Round 874 (Div. 3)(A~D题)
  • [Python][基础语法]详细讲解
  • Layui---输入事件
  • 甄选范文“论软件测试中缺陷管理及其应用”软考高级论文,系统架构设计师论文
  • spring框架实现滑动验证码功能
  • Pytorch使用教学8-张量的科学运算
  • [Spring Boot]登录密码三种加密方式
  • 前端面试项目细节重难点分享(十三)
  • 每天五分钟深度学习:向量化方式完成逻辑回归m个样本的前向传播
  • 以线程完成并发的UDP服务端
  • linux c 特殊字符分割
  • 搭建本地私有知识问答系统:MaxKB + Ollama + Llama3 (wsl网络代理配置、MaxKB-API访问配置)
  • 谷粒商城实战笔记-65-商品服务-API-品牌管理-表单校验自定义校验器
  • 学好C++之——命名空间