MultipartUploadRequest 无法从Android传递信息到服务器的一种情况

MultipartUploadRequest 的标准代码大概是这样写的:

String UPLOAD_URL = "http://XX.XX.XX.XX/AndroidUpload/upload.php";

new MultipartUploadRequest(this, uploadId, UPLOAD_URL)
                    .addFileToUpload(path, "image") // 一张图片
                    .addParameter("name", name) // 一个text
                    .setNotificationConfig(new UploadNotificationConfig())
                    .setMaxRetries(2)
                    .setMethod("POST")
                    .startUpload(); 

这时候注意到图片和text都没有上传上去,一时间无法判断是什么问题。

通过阅读官网代码发现属性setDelegate可以监控MultipartUploadRequest 的传输过程,于是设置属性setDelegate进行排查:

String UPLOAD_URL = "http://XX.XX.XX.XX/AndroidUpload/upload.php";

new MultipartUploadRequest(this, uploadId, UPLOAD_URL)
                    .addFileToUpload(path, "image") // 一张图片
                    .addParameter("name", name) // 一个text
                    .setNotificationConfig(new UploadNotificationConfig())
                    .setMaxRetries(2)
                    .setMethod("POST")
                    .setDelegate(new UploadStatusDelegate() {
                        @Override
                        public void onError(Context context, UploadInfo uploadInfo, ServerResponse serverResponse,
                                            Exception exception) {
                            Toast.makeText(context, "信息传递错误", Toast.LENGTH_SHORT).show();
                            exception.printStackTrace(); // 输出错误信息
                        }

                        @Override
                        public void onCompleted(Context context, UploadInfo uploadInfo, ServerResponse serverResponse) {
                            Toast.makeText(context, "信息传递完成", Toast.LENGTH_SHORT).show();
                        }

                        @Override
                        public void onCancelled(Context context, UploadInfo uploadInfo) {
                            Toast.makeText(context, "信息传递取消", Toast.LENGTH_SHORT).show();
                        }
                    }).startUpload(); 

重新允许程序,在run输出区中,可以看到一个错误信息:

Cleartext HTTP traffic to XX not permitted

这个错误出现的原因是,在Android 9及更新的安卓版本,明确规定禁止通过http协议传输信息,应该通过https进行传输。

知道了症状就好解决了,这里提供两种解决办法:

1、允许http协议传输
首先打开Android项目,在res下新建一个Directory,命名为xml,在xml中新建一个network_config.xml

<?xml version="1.0" encoding="utf-8"?>
<network-security-config>
    <base-config cleartextTrafficPermitted="true" />
</network-security-config>

然后转到AndroidManifest.xml,加入属性android:networkSecurityConfig="@xml/network_config"
如下:

<application
        android:icon="@mipmap/ic_launcher"
        android:networkSecurityConfig="@xml/network_config" <!--这一行-->
        android:label="@string/app_name"
        android:roundIcon="@mipmap/ic_launcher_round"
        android:supportsRtl="true"
        android:theme="@style/AppTheme"
        tools:ignore="AllowBackup,GoogleAppIndexingWarning">

重新运行程序即可。

2、在服务器部署https
参考这两篇博客完成:(1)wampserver3.0.6部署https、(2)wamp3 本地配置https

发布了213 篇原创文章 · 获赞 858 · 访问量 125万+

猜你喜欢

转载自blog.csdn.net/baishuiniyaonulia/article/details/104378558