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

安卓使用HttpURLConnection与服务器的交互(Kotlin)

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}")
        }

相关文章:

  • 湖仓一体电商项目(二十二):实时任务执行流程
  • mfc随记:基于vs2010创建MFC ActiveX控件并测试
  • DOM事件对象
  • mqtt报文逐条解析
  • 你会不会主动拒绝 “无意义、无理由” 加班?
  • java-php-python-springboot校园管理系统计算机毕业设计
  • SSM+高校食堂外卖服务小程序 毕业设计-附源码200910
  • 如何将MNIST数据集数据图像可视化
  • 毫米波雷达在检测、分割、深度估计等多个方向的近期工作及简要介绍
  • LeetCode0005.最长回文子串 Go语言AC笔记
  • JavaScript:JavaScript编程语言学习之基础知识(变量/类型/数组/运算符/标签函数对象)的简介、案例应用之详细攻略
  • TiDB 重要监控指标详解
  • 【web前端开发】前端生日礼物--注册页面篇
  • C++ Reference: Standard C++ Library reference: C Library: cmath
  • 康耐视InSight相机与西门子PLC关于Profinet通讯说明
  • 【399天】跃迁之路——程序员高效学习方法论探索系列(实验阶段156-2018.03.11)...
  • 3.7、@ResponseBody 和 @RestController
  • Docker下部署自己的LNMP工作环境
  • Electron入门介绍
  • FineReport中如何实现自动滚屏效果
  • Invalidate和postInvalidate的区别
  • JS数组方法汇总
  • PAT A1050
  • PHP的类修饰符与访问修饰符
  • React的组件模式
  • SpringBoot 实战 (三) | 配置文件详解
  • 关于Android中设置闹钟的相对比较完善的解决方案
  • 快速体验 Sentinel 集群限流功能,只需简单几步
  • 老板让我十分钟上手nx-admin
  • 前嗅ForeSpider采集配置界面介绍
  • 如何编写一个可升级的智能合约
  • 实现菜单下拉伸展折叠效果demo
  • 微信小程序开发问题汇总
  • 为物联网而生:高性能时间序列数据库HiTSDB商业化首发!
  • 我与Jetbrains的这些年
  • 小试R空间处理新库sf
  • 携程小程序初体验
  • RDS-Mysql 物理备份恢复到本地数据库上
  • ​LeetCode解法汇总2583. 二叉树中的第 K 大层和
  • ​软考-高级-信息系统项目管理师教程 第四版【第19章-配置与变更管理-思维导图】​
  • ​水经微图Web1.5.0版即将上线
  • # Python csv、xlsx、json、二进制(MP3) 文件读写基本使用
  • $NOIp2018$劝退记
  • (4)logging(日志模块)
  • (MIT博士)林达华老师-概率模型与计算机视觉”
  • (差分)胡桃爱原石
  • (附源码)python房屋租赁管理系统 毕业设计 745613
  • (附源码)ssm失物招领系统 毕业设计 182317
  • (一)RocketMQ初步认识
  • ./configure、make、make install 命令
  • .NET 5种线程安全集合
  • .NET 6 Mysql Canal (CDC 增量同步,捕获变更数据) 案例版
  • .NET Core实战项目之CMS 第十二章 开发篇-Dapper封装CURD及仓储代码生成器实现
  • .net refrector
  • .NET Standard 支持的 .NET Framework 和 .NET Core