返回顶部
首页 > 资讯 > 服务器 >KotlinHttpURLConnection与服务器交互实现方法详解
  • 880
分享到

KotlinHttpURLConnection与服务器交互实现方法详解

2024-04-02 19:04:59 880人浏览 薄情痞子
摘要

目录1.查询(get)-调用的时候记得开线程2.改(post)3.增(PUT)4.删(DELETE请求)1.查询(get)-调用的时候记得开线程 GET一般用于获取/查询资源信息

1.查询(get)-调用的时候记得开线程

GET一般用于获取/查询资源信息

 val sb = StringBuffer()
 try {
     val url = URL(url)
     val conn = url.openConnection() as HttpURLConnection
     conn.requestMethod = "GET"
     conn.connectTimeout = 5000
     val code = conn.responseCode
     if (code == 200) {
         val `is` = conn.inputStream
         val b = ByteArray(1024)
         var len: Int
         while (`is`.read(b).also { len = it } != -1) {
               sb.append(String(b, 0, len, Charset.forName("UTF-8")))
         }
          `is`.close()
         conn.disconnect()
         Log.e("TAG","sb==${sb.toString()}")
     } else {
       Log.e("TAG","code==${code.toString()}")
     }
   } catch (var1: Exception) {
     Log.e("TAG","Exception==${var1.message}")
   }

2.改(post)

post向指定资源提交数据进行处理请求(提交表单、上传文件),又可能导致新的资源的建立或原有资源的修改。

  val sb = StringBuffer()
        object : Thread() {
            override fun run() {
                super.run()
                try {
                    val url = URL(urlPath)
                    val conn = url.openConnection() as HttpURLConnection
                    conn.doOutput = true
                    conn.requestMethod = "POST"
                    conn.connectTimeout = 5000
                    conn.doInput = true
                    conn.useCaches = false
                    conn.setRequestProperty("Connection", "Keep-Alive")
                    conn.setRequestProperty("Charset", "UTF-8")
                    conn.setRequestProperty("Content-Type", "application/JSON; charset=UTF-8")
                    conn.setRequestProperty("accept", "application/json")
                    conn.setRequestProperty("appid", mAPP_ID)
                    conn.setRequestProperty("ts", time)
                    conn.setRequestProperty("sign", sign)
                    Log.e(TAG, "Json:$Json")
                    if (Json != null && !TextUtils.isEmpty(Json)) {
                        val writebytes = Json.toByteArray()
                        conn.setRequestProperty("Content-Length", writebytes.size.toString())
                        val outwritestream = conn.outputStream
                        outwritestream.write(Json.toByteArray())
                        outwritestream.flush()
                        outwritestream.close()
                    }
                    val code = conn.responseCode
                    if (code == 200) {
                        val `is` = conn.inputStream
                        val b = ByteArray(1024)
                        var len: Int
                        while (`is`.read(b).also { len = it } != -1) {
                            sb.append(String(b, 0, len, Charset.forName("UTF-8")))
                        }
                        `is`.close()
                        conn.disconnect()
                        Log.w(TAG, "TXPost sb====$sb")
                    } else {
                        Log.w(TAG, "TXPost code====$code")
                    }
                } catch (var1: Exception) {
                    Log.w(TAG, "TXPost Exception====$var1")
                }
            }
        }.start()

设置请求头:

1.基本headers 这四句一般没有特殊需求的话,都是需要的
conn.setRequestProperty("Connection", "Keep-Alive")
conn.setRequestProperty("Charset", "UTF-8")
conn.setRequestProperty("Content-Type", "application/json; charset=UTF-8")
conn.setRequestProperty("accept", "application/json")
2.特殊headers 这些是客户端与服务通信服务器所需的headers
conn.setRequestProperty("appid", mAPP_ID)
conn.setRequestProperty("ts", time)
conn.setRequestProperty("sign", sign) 

Headers:

HTTP是“Hypertext Transfer Protocol”的所写,整个万维网都在使用这种协议,几乎你在浏览器里看到的大部分内容都是通过http协议来传输的.

HTTP Headers是HTTP请求和相应的核心,它承载了关于客户端浏览器,请求页面,服务器等相关的信息.

设置body(请求内容)

if (Json != null && !TextUtils.isEmpty(Json)) {
   val writebytes = Json.toByteArray()
   conn.setRequestProperty("Content-Length", writebytes.size.toString())
   val outwritestream = conn.outputStream
   outwritestream.write(Json.toByteArray())
   outwritestream.flush()
   outwritestream.close()
  }

有时候开发的时候你能看到一个名叫token的东西,这个玩意是后台自定义的东西,有时候可以放在请求头,有时候可以放在body里面,具体可以看协议

3.增(PUT)

PUT:这个方法比较少见。html表单也不支持这个。本质上来讲, PUT和POST极为相似,都是向服务器发送数据,但它们之间有一个重要区别,PUT通常指定了资源的存放位置,而POST则没有,POST的数据存放位置由服务器自己决定。

val url = URL(urlPath)
        val connection = url.openConnection() as HttpURLConnection
        val outputStream = connection.outputStream
        val inputStream = FileInputStream(file)
        object : Thread() {
            override fun run() {
                super.run()
                try {
                    connection.doOutput = true
                    connection.useCaches = false
                    connection.setRequestProperty("Accept-Charset", "utf-8")
                    connection.setRequestProperty("Connection", "keep-alive")
                    connection.setRequestProperty(
                        "Content-Type",
                        "multipart/fORM-data;boundary=fengexian===="
                    )
                    connection.setRequestProperty("Accept", "application/json")
                    connection.connect()
                    val bytes = ByteArray(
                        getFileOrFilesSize(file.absolutePath).toInt()
                    )
                    var length: Int
                    while (inputStream.read(bytes).also { length = it } != -1) {
                        outputStream.write(bytes, 0, length)
                    }
                    outputStream.flush()
                    val response = connection.inputStream
                    val reader = InputStreamReader(response)
                    while (reader.read() != -1) {
                        String(bytes, Charset.forName("UTF-8"))
                    }
                    if (connection.responseCode == 200) {
                        Log.w("TAG", "connection===${connection.responseMessage}")
                    } else {
                        Log.w("TAG", "responseCode===${connection.responseCode}")
                    }
                } catch (var13: IOException) {
                    Log.w("TAG", "IOException===${var13.message}")
                } finally {
                    try {
                        outputStream.close()
                        inputStream.close()
                        connection.disconnect()
                    } catch (var12: IOException) {
                        var12.printStackTrace()
                    }
                }
            }
        }.start()

4.删(DELETE请求)

DELETE:删除某一个资源。基本上这个也很少见,我只在像亚马逊s3之类的服务器见过!

val sb = StringBuffer()
        var uri: URL? = null
        var con: HttpURLConnection? = null
        try {
            uri = URL(url)
            con = uri.openConnection() as HttpURLConnection
            con.requestMethod = "DELETE"
            con.doOutput = true
            con.doInput = true
            con.connectTimeout = 60000 //60 secs
            con.readTimeout = 60000 //60 secs
            val code = con.responseCode
            if (code == 200) {
                val `is` = con.inputStream
                val b = ByteArray(1024)
                var len: Int
                while (`is`.read(b).also { len = it } != -1) {
                    sb.append(String(b, 0, len, Charset.forName("UTF-8")))
                }
                `is`.close()
                con.disconnect()
                Log.w("TAG", "sb===${sb}")
            } else {
                Log.w("TAG", "code===$[code]")
            }
        } catch (e: Exception) {
            Log.w("TAG", "Exception===${e.message}")
        }

到此这篇关于Kotlin HttpURLConnection与服务器交互实现方法详解的文章就介绍到这了,更多相关Kotlin HttpURLConnection与服务器交互内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: KotlinHttpURLConnection与服务器交互实现方法详解

本文链接: https://lsjlt.com/news/168634.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • KotlinHttpURLConnection与服务器交互实现方法详解
    目录1.查询(get)-调用的时候记得开线程2.改(post)3.增(PUT)4.删(DELETE请求)1.查询(get)-调用的时候记得开线程 GET一般用于获取/查询资源信息 ...
    99+
    2024-04-02
  • Android中webview与JS交互、互调方法实例详解
    Android中webview与JS交互、互调方法实例详解 前言: 对于试水的功能,一般公司都会采用H5的方式来开发,可以用很少的资源与很短的项目工期来完成。 但许多情况下,...
    99+
    2022-06-06
    方法 webview js Android
  • 详解android与服务端交互的两种方式
    做Android开发的程序员必须知道android客户端应该如何与服务端进行交互,这里主要介绍的是使用json数据进行交互。服务端从数据库查出数据并以json字符串的格式或者map集合的格式返回到客户端,客户端进行解析并输出到手机屏幕上。此...
    99+
    2023-05-31
    android 服务端 交互
  • 详解c#与python的交互方式
    目录前言: 一、IronPython 二、Python打包exe调用 三、Python提供WebApi接口(推荐) 总结: 前言:  在平时工作中,需求有多种实现方式;根据不同的需...
    99+
    2024-04-02
  • Android中WebView与Js交互的实现方法
    获取WebView对象 调用WebView对象的getSettings()方法,获取WebSettings对象 调用WebSettings对象的setJavaScriptEna...
    99+
    2022-06-06
    方法 webview js Android
  • android与云服务器交互的方法是什么
    Android与云服务器交互的方法可以通过以下几种方式:1. RESTful API:使用HTTP协议通过RESTful风格的API...
    99+
    2023-09-26
    android 云服务器
  • Aptos SDK交互实现过程详解
    目录背景官网示例实现过程初始化客户端创建本地账户创建区块链账户读取余额转帐等待交易处理背景 之前我们已经了解TS的一些语法,接下来可以实战训练下,这系列的文章就会介绍如何通过Apt...
    99+
    2023-03-03
    Aptos SDK交互 Aptos SDK
  • AJAX实现JSON与XML数据交换方法详解
    目录1、JS中如何创建和访问JSON对象2、基于JSON的数据交换3、基于XML的数据交换1、JS中如何创建和访问JSON对象 (1)在javascript语言中怎么创建一个json...
    99+
    2023-01-13
    AJAX JSON与XML数据交换 AJAX JSON数据交换 AJAX XML数据交换
  • 与云服务器交互失败
    检查云服务器的配置和服务设置。检查云服务器的配置文档、端口、IP地址和安全组等信息,确保它们与您的本地系统配置完全一致。 检查您的网络连接。如果您使用的是公共互联网连接,请确保您的网络连接正常,并且没有被防火墙或其他安全软件阻止连接。 重...
    99+
    2023-10-27
    服务器
  • Vue生命周期与后端交互实现流程详解
    目录表单控制购物车案例v-model进阶(了解)vue生命周期与后端交互电影案例表单控制 1.input:checkbox(单选,多选),radio(单选) 2.代码展示 <!...
    99+
    2022-11-13
    Vue生命周期 Vue后端交互
  • JQuery怎么以JSON方式与服务器交互
    这篇文章主要介绍“JQuery怎么以JSON方式与服务器交互”,在日常操作中,相信很多人在JQuery怎么以JSON方式与服务器交互问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解...
    99+
    2024-04-02
  • node.js+postman实现模拟HTTP服务器与客户端交互
    目录一、node搭建HTTP服务器二、HTTP服务器处理get请求1、postman发送get请求2、服务器解析三、HTTP服务器处理post请求1、postman发送post请求2...
    99+
    2024-04-02
  • 如何实现Flex与浏览器交互
    本篇文章为大家展示了如何实现Flex与浏览器交互,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。总结Flex与浏览器交互在用Flex做Web应用时为了扩展应用程序功能,势必会更多的同浏览器进行交互,这...
    99+
    2023-06-17
  • C#怎么实现允许服务与桌面交互
    本篇内容介绍了“C#怎么实现允许服务与桌面交互”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!onstart的时候修改注册表[HKEY_LOC...
    99+
    2023-06-17
  • python3中实现客户端与服务端交互发
    在python3中实现客户端与服务端程序交互,从客户端发送文件到服务端客户端代码:client.py#!/usr/bin/env python #_*_ encoding=utf-8 _*_ import socket,sys,os ...
    99+
    2023-01-31
    服务端 客户端
  • Ajax+js实现异步交互的方法
    小编给大家分享一下Ajax+js实现异步交互的方法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!JS是什么JS是JavaScript的简称,它是一种直译式的脚本语...
    99+
    2023-06-08
  • Flutter中实现交互式Webview的方法
    前言: Flutter是一款强大的跨平台移动应用开发框架,而Webview则是在应用中展示Web内容的重要组件。本文将介绍如何在Flutter应用中实现交互式的Webview,以便为用户提供更加丰...
    99+
    2023-09-10
    flutter
  • 与云服务器交互失败602
    云服务器配置不正确:请检查云服务器的配置信息,确保它们与您的操作系统兼容。 云服务器故障:请检查云服务器的故障情况,确保它们处于可用状态。 云服务器连接超时:请确保您的云服务器能够与其他云服务器和网络之间进行可靠的通信。 云服务器负载过高...
    99+
    2023-10-27
    服务器
  • 与云服务器交互失败133
    很抱歉,您遇到了服务器无法与云服务器交互的问题。您可以尝试以下步骤来解决这一问题: 检查网络连接:尝试重启服务器、检查您的网络连接是否正常。 重新启动设备:重新启动云服务器或其他云存储设备。 检查您的账户和密码是否正确:确保您的账户密码...
    99+
    2023-10-26
    服务器
  • Node.js REPL (交互式解释器)实例详解
    Node.js REPL (交互式解释器)实例详解 Node.js REPL(Read Eval Print Loop:交互式解释器) 表示一个电脑的环境,类似 Window 系统的终端,我们可以在终端中...
    99+
    2022-06-04
    详解 实例 Node
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作