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

 更新时间:2022年09月29日 08:29:03   作者:ui不是我画的  
简单来说,HttpURLConnection 是发起HTTP请求的基础类库,提供了HTTP请求的基本功能,不过封装的比较少,在使用时很多内容都需要自己设置,也需要自己处理请求流和响应流

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与服务器交互内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Android WorkManager使用以及源码分析

    Android WorkManager使用以及源码分析

    WorkManager 是适合用于持久性工作的推荐解决方案。如果工作始终要通过应用重启和系统重新启动来调度,便是持久性的工作。本文主要介绍了Android WorkManager的使用,需要的可以参考一下
    2023-02-02
  • Android圆形旋转菜单开发实例

    Android圆形旋转菜单开发实例

    本文给大家分享一个动画菜单,基于android开发圆形旋转菜单案例,非常不错,具有参考借鉴价值,感兴趣的朋友一起看看吧
    2016-09-09
  • Android10填坑适配指南(实际经验代码)

    Android10填坑适配指南(实际经验代码)

    这篇文章主要介绍了Android10填坑适配指南(实际经验代码),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-11-11
  • Android通过overScrollBy实现下拉视差特效

    Android通过overScrollBy实现下拉视差特效

    这篇文章主要为大家详细介绍了Android通过overScrollBy实现下拉视差特效,实现精彩的阻尼效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-08-08
  • Android Service绑定过程完整分析

    Android Service绑定过程完整分析

    这篇文章主要为大家详细介绍了Android Service绑定完整过程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-10-10
  • 详解flutter中常用的container layout实例

    详解flutter中常用的container layout实例

    这篇文章主要为大家介绍了详解flutter中常用的container layout实例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-09-09
  • Android实现带节点的进度条

    Android实现带节点的进度条

    这篇文章主要为大家详细介绍了Android实现带节点的进度条,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-03-03
  • 深入理解Activity之间的数据传递

    深入理解Activity之间的数据传递

    本篇文章是对Activity之间的数据传递进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • Android SharedPreferences实现记住密码和自动登录

    Android SharedPreferences实现记住密码和自动登录

    这篇文章主要为大家详细介绍了Android SharedPreferences实现记住密码和自动登录,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-05-05
  • Android自定义View控件实现多种水波纹涟漪扩散效果

    Android自定义View控件实现多种水波纹涟漪扩散效果

    这篇文章主要给大家介绍了关于Android自定义View控件实现多种水波纹涟漪扩散效果的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。
    2018-03-03

最新评论