Android开发错误锦囊-Internal Server Error

2024-05-22 06:58

本文主要是介绍Android开发错误锦囊-Internal Server Error,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在Android开发中我们经常会遇到上传图片,然而在上传图片的过程中大家很可能会遇到Internal Server Error这个错误,下面我们来看一下这个错误是如何产生的:

用xutils3上传文件

1.加入xutils3框架代码

    compile 'org.xutils:xutils:3.3.36'

2.用法

/**定义请求参数**/
RequestParams requestParams=new RequestParams("http://10.58.178.120:8080/intco/mobi/member/uploadImage");requestParams.addBodyParameter("mId", "1");requestParams.addBodyParameter("imgFile", new File(path));
/**打印请求参数**/
Log.i("dylan","请求链接:"+params.toString());/**发起post请求**/
x.http().post(requestParams, new Callback.CommonCallback<String>() {@Overridepublic void onSuccess(String result) {Log.i(TAG, "onSuccess--" + info + "---->" + result);}}@Overridepublic void onError(Throwable ex, boolean isOnCallback) {ex.printStackTrace();}@Overridepublic void onCancelled(CancelledException cex) {}@Overridepublic void onFinished() {}});}

3.请求结果

10-19 19:05:07.806 19247-19247/com.bm.ykzx I/NetworkRequest: onError--更换头像---->Internal Server Error

4.结果分析

我们发现请求并没有成功,而是在xutils的请求回调中只走了onError这个方法的回调,并打印了Internal Server Error,让我们很纳闷,到底是怎么了?问后台服务器,他们说也不知道怎么了。让我们折腾半天,因为iOS是可以上传成功的i,所以,就只能说是我们自己的错误。

解决思路

1.发现问题

我们发现我们和xutils3开源者给的例子就多了一句话,那就是:

Log.i("dylan","请求链接:"+params.toString());

就这是调用了一个对象的toString方法会有什么问题呢?
于是,我们就看一下改对象有没有覆写toString方法呢?

 /*** 在网络请求onStart前, 尽量不要在UI线程调用这个方法, 可能产生性能影响.** @return*/@Overridepublic String toString() {try {this.init();} catch (Throwable ex) {LogUtil.e(ex.getMessage(), ex);}String url = this.getUri();return TextUtils.isEmpty(url) ?super.toString() :url + (url.contains("?") ? "&" : "?") + super.toString();}

再来看看这个方法面还调用了 super.toString();再接着看

@Overridepublic String toString() {checkBodyParams();final StringBuilder sb = new StringBuilder();if (!queryStringParams.isEmpty()) {for (KeyValue kv : queryStringParams) {sb.append(kv.key).append("=").append(kv.value).append("&");}sb.deleteCharAt(sb.length() - 1);}if (HttpMethod.permitsRequestBody(this.method)) {sb.append("<");if (!TextUtils.isEmpty(bodyContent)) {sb.append(bodyContent);} else {if (!bodyParams.isEmpty()) {for (KeyValue kv : bodyParams) {sb.append(kv.key).append("=").append(kv.value).append("&");}sb.deleteCharAt(sb.length() - 1);}}sb.append(">");}return sb.toString();}

我们发现在super.toString()里面调用了checkBodyParams();下面我们来看看这个方法:

private void checkBodyParams() {if (bodyParams.isEmpty()) return;if (!HttpMethod.permitsRequestBody(method)|| !TextUtils.isEmpty(bodyContent)|| requestBody != null) {queryStringParams.addAll(bodyParams);bodyParams.clear();}if (!bodyParams.isEmpty() && (multipart || fileParams.size() > 0)) {fileParams.addAll(bodyParams);bodyParams.clear();}if (asJsonContent && !bodyParams.isEmpty()) {try {JSONObject jsonObject = null;if (!TextUtils.isEmpty(bodyContent)) {jsonObject = new JSONObject(bodyContent);} else {jsonObject = new JSONObject();}params2Json(jsonObject, bodyParams);bodyContent = jsonObject.toString();bodyParams.clear();} catch (JSONException ex) {throw new RuntimeException(ex);}}}

在上面的代码中我们发现了这句

if (!bodyParams.isEmpty() && (multipart || fileParams.size() > 0)) {fileParams.addAll(bodyParams);bodyParams.clear();}

2.找到问题

就是因为这句bodyParams.clear();虽然把参数给我们返回了但是把提交给服务器的参数都清了

3.总结

params.toString()是个坑,以后不能用这个打印这个参数值,去掉这个就好了

这篇关于Android开发错误锦囊-Internal Server Error的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/996000

相关文章

SQL Server中行转列方法详细讲解

《SQLServer中行转列方法详细讲解》SQL行转列、列转行可以帮助我们更方便地处理数据,生成需要的报表和结果集,:本文主要介绍SQLServer中行转列方法的相关资料,需要的朋友可以参考下... 目录前言一、为什么需要行转列二、行转列的基本概念三、使用PIVOT运算符进行行转列1.创建示例数据表并插入数

Android使用java实现网络连通性检查详解

《Android使用java实现网络连通性检查详解》这篇文章主要为大家详细介绍了Android使用java实现网络连通性检查的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录NetCheck.Java(可直接拷贝)使用示例(Activity/Fragment 内)权限要求

SpringBoot项目整合Netty启动失败的常见错误总结

《SpringBoot项目整合Netty启动失败的常见错误总结》本文总结了SpringBoot集成Netty时常见的8类问题及解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录一、端口冲突问题1. Tomcat与Netty端口冲突二、主线程被阻塞问题1. Netty启动阻

SpringBoot整合Kafka启动失败的常见错误问题总结(推荐)

《SpringBoot整合Kafka启动失败的常见错误问题总结(推荐)》本文总结了SpringBoot项目整合Kafka启动失败的常见错误,包括Kafka服务器连接问题、序列化配置错误、依赖配置问题、... 目录一、Kafka服务器连接问题1. Kafka服务器无法连接2. 开发环境与生产环境网络不通二、序

Python+wxPython开发一个文件属性比对工具

《Python+wxPython开发一个文件属性比对工具》在日常的文件管理工作中,我们经常会遇到同一个文件存在多个版本,或者需要验证备份文件与源文件是否一致,下面我们就来看看如何使用wxPython模... 目录引言项目背景与需求应用场景核心需求运行结果技术选型程序设计界面布局核心功能模块关键代码解析文件大

C++多线程开发环境配置方法

《C++多线程开发环境配置方法》文章详细介绍了如何在Windows上安装MinGW-w64和VSCode,并配置环境变量和编译任务,使用VSCode创建一个C++多线程测试项目,并通过配置tasks.... 目录下载安装 MinGW-w64下载安装VS code创建测试项目配置编译任务创建 tasks.js

2025最新版Android Studio安装及组件配置教程(SDK、JDK、Gradle)

《2025最新版AndroidStudio安装及组件配置教程(SDK、JDK、Gradle)》:本文主要介绍2025最新版AndroidStudio安装及组件配置(SDK、JDK、Gradle... 目录原生 android 简介Android Studio必备组件一、Android Studio安装二、A

解决java.util.RandomAccessSubList cannot be cast to java.util.ArrayList错误的问题

《解决java.util.RandomAccessSubListcannotbecasttojava.util.ArrayList错误的问题》当你尝试将RandomAccessSubList... 目录Java.util.RandomAccessSubList cannot be cast to java.

Java编译错误java.lang.NoSuchFieldError的解决方案详析

《Java编译错误java.lang.NoSuchFieldError的解决方案详析》java.lang.NoSuchFieldError是Java中的一种运行时错误,:本文主要介绍Java编译错... 目录前言解决方案1. 统一JDK版本环境2. 优化maven-compiler-plugin配置3. 清

Navicat连接Mysql8.0.11出现1251错误的解决方案

《Navicat连接Mysql8.0.11出现1251错误的解决方案》在重装电脑并安装最新版MySQL后,Navicat和Sqlyog连接MySQL时遇到的1251和2058错误,通过将MySQL用户... 目录Navicat连接mysql8.0.11出现1251错误原因分析解决问题方法有两种总结Navic