Retrofit 系列文章导读:

  • Android Retrofit 源码系列(一)~ 原理剖析
  • Android Retrofit 源码系列(二)~ 自定义 CallAdapter
  • Android Retrofit 源码系列(三)~ 整合 RxJava、Coroutine 分析
  • Android Retrofit 源码系列(四)~ 文件上传
  • Android Retrofit 源码系列(五)~ 归纳总结

前言

今天我们来聊一聊 Retrofit 文件上传。为了调试 Retrofit 文件上传功能,我搭建了简单的服务器来接收客户端上传的文件。为了减少篇幅我就不将服务端的代码贴出来了,有兴趣的可以查看我的 GitHub :https://github.com/chiclaim/WebApp

本文主要讲 Retrofit 文件上传功能主要包括:

  • Retrofit 文件上传
  • 文件上传遇到的问题
  • 分析问题原因以及如何解决该问题

Retrofit 文件上传

在实际开发中我们可能经常遇到文件上传的功能,多文件上传,图文上传等。

比如我们要上传单个文件,外加一个描述字段,我们想一下在网页端我们是怎么做的(一个文件选择器和一个输入框):

FileUpload

那么我们通过 Retrofit 中如何来实现呢,大家在网上一搜很容易就能找到,例如:

/*** 单文件上传*/
@Multipart
@POST("fileUpload")
fun upload(@Part("description") description: RequestBody,@Part file: MultipartBody.Part
): Call<ResponseBody>fun fileUpload() {val fileRequestBody = RequestBody.create(mediaType, file)val filePart = MultipartBody.Part.createFormData("file_1", file.name, fileRequestBody)val formFieldPart = RequestBody.create(MultipartBody.FORM, "单文件上传")uploadService.upload(formFieldPart, filePart)
}

MultipartBody.Part.createFormData 方法有 3 个参数:

createFormData(String name, @Nullable String filename, RequestBody body){if (name == null) {throw new NullPointerException("name == null");}// ...
}

其中 namefilename 有什么区别? filename 顾名思义就是文件的名称,那 name 代表的是什么呢?

有的开发者没有搞清楚其中的区别,就将 name 设置成 filename,这可能会产生问题,因为 filename 是可以为空的,而 name 是不能为空的,否则会抛出空指针异常。

其实这一行代码:

val filePart = MultipartBody.Part.createFormData("file_1", file.name, fileRequestBody)

相当于 HTML 页面里面的 文件选择控件 对应的代码:

<input type="file" name="file_1"/>

createFormData 方法的第一个参数 name 就相当于 input 控件的 name 属性

多文件上传(List<MultipartBody.Part>)

如果我们的需要上传的文件数量是可变的呢?我们可以将 MultipartBody.Part 放在一个集合中:

/*** 多文件上传(List<MultipartBody.Part>)*/
@Multipart
@POST("fileUpload")
fun upload(@Part("description") description: RequestBody,@Part parts: List<MultipartBody.Part>
): Call<ResponseBody>// ======文件上传
fun fileUpload() {val formFieldBody = RequestBody.create(MultipartBody.FORM, "通过 List<MultipartBody.Part> 多文件上传")execute(uploadService.upload(formFieldBody, buildListPart()))
}private fun buildListPart(): List<MultipartBody.Part> {val list = arrayListOf<MultipartBody.Part>()var index = 0files.forEach {val fileUri = it.valueval mediaType = getMediaType(fileUri)val file = UriHelper.getFileFromUri(applicationContext, fileUri)val fileRequestBody = RequestBody.create(mediaType, file)val filePart = MultipartBody.Part.createFormData("file_${++index}", file.name, fileRequestBody)list.add(filePart)}return list
}

服务器端我们打印了文本字段以及上传的图片信息:

for (FileItem item : formItems) {// 处理文件if (!item.isFormField()) {if (Objects.isNull(item.getName()) || "".equals(item.getName().trim())) continue;String fileName = new File(item.getName()).getName();String filePath = uploadPath + File.separator + fileName;File storeFile = new File(filePath);item.write(storeFile);System.out.println("文件存储路径:" + storeFile.getAbsolutePath());} else { // 处理普通字段System.out.println(getFieldName -> " + item.getFieldName() + ", getString -> " + item.getString("UTF-8"));}
}

然后我们来测试下,服务器控制台输出结果:

getFieldName -> description, getString -> 通过 List<MultipartBody.Part> 多文件上传
文件存储路径:D:\xxx\WebApp\out\artifacts\ServletDemo_Web_exploded\upload\shumei.txt

如果需要上传的文本字段的数量也是可变的呢?我们可以将文本字段放在 Map 集合中,然后使用 @PartMap 注解来修饰:

@Multipart
@POST("fileUpload")
fun upload(@PartMap partMap: HashMap<String, RequestBody>,@Part parts: List<MultipartBody.Part>
): Call<ResponseBody>

我们来测试下,看看服务器控制台输出结果:

getFieldName -> description0, getString -> 通过 List<MultipartBody.Part> 多文件上传 PartMap0
getFieldName -> description1, getString -> 通过 List<MultipartBody.Part> 多文件上传 PartMap1
文件存储路径:D:\xxx\WebApp\out\artifacts\ServletDemo_Web_exploded\upload\shumei.txt

其实对于文本字段我们也可以放在 List<MultipartBody.Part> 中,也就是说不用单独声明一个 Map 集合来保存普通文本信息:

@Multipart
@POST("fileUpload")
fun upload(@Part parts: List<MultipartBody.Part>
): Call<ResponseBody>private fun buildListPart(): List<MultipartBody.Part> {val list = arrayListOf<MultipartBody.Part>()list.add(MultipartBody.Part.createFormData("description0", "通过 List<MultipartBody.Part> 多文件上传 in list 参数0"))list.add(MultipartBody.Part.createFormData("description1", "通过 List<MultipartBody.Part> 多文件上传 in list 参数1"))var index = 0files.forEach {val fileUri = it.valueval mediaType = getMediaType(fileUri)val file = UriHelper.getFileFromUri(applicationContext, fileUri)val fileRequestBody = RequestBody.create(mediaType, file)val filePart = MultipartBody.Part.createFormData("file_${++index}", file.name, fileRequestBody)list.add(filePart)}return list
}

我们来测试下,看看服务器控制台输出结果:

getFieldName -> description0, getString -> 通过 List<MultipartBody.Part> å¤šæ–‡ä»¶ä¸Šä¼  in list 参数0
getFieldName -> description1, getString -> 通过 List<MultipartBody.Part> å¤šæ–‡ä»¶ä¸Šä¼  in list 参数1
文件存储路径:D:\xxx\WebApp\out\artifacts\ServletDemo_Web_exploded\upload\shumei.txt

乱码原因分析及解决

我们发现产生了乱码。我们先从服务器端的角度来看这个问题,上面乱码的内容是通过 FileItem.getString 方法获取的,我们就来看下该方法的源码:

public String getString() {byte[] rawdata = this.get();String charset = this.getCharSet();if (charset == null) {charset = "ISO-8859-1";}try {return new String(rawdata, charset);} catch (UnsupportedEncodingException var4) {return new String(rawdata);}
}

从中得知,如果没有设置字符集 Charset,那么则使用 ISO-8859-1,这肯定会产生乱码,所以调用 FileItem.getString 方法的时候传递 UTF-8 字符集:

item.getString("UTF-8")

此时,我们再来看看服务器控制台的输出:

getFieldName -> description0, getString -> 通过 List<MultipartBody.Part> 多文件上传 in list 参数0
getFieldName -> description1, getString -> 通过 List<MultipartBody.Part> 多文件上传 in list 参数1
文件存储路径:D:\xxx\WebApp\out\artifacts\ServletDemo_Web_exploded\upload\shumei.txt

发现乱码问题已经好了。有人可能会问了,服务器端使用 UTF-8 来读取,你怎么客户端是以 UTF-8 编码发送过来的呢?因为 Android 是使用 UTF-8 来进行编码的。

我们还可以通过另一个例子对乱码问题再讲解下。我在 WebApp 里新建了一个 upload.jsp ,如下图所示:

FileUpload

如果服务器端不设置 item.getString("UTF-8"),网页端上传中文也会乱码的。因为网页端也是以 UTF-8 编码发送过来的,为什么呢?因为我们在 jsp 文件中设置了 UTF-8 字符集:

<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8" %>

我们可以将其改成 GBK:

<%@ page language="java" contentType="text/html; charset=GBK" pageEncoding="GBK" %>

看看控制台输出:

getFieldName -> username, getString -> �ȸ�ռ��
文件存储路径:D:\xxx\WebApp\out\artifacts\ServletDemo_Web_exploded\upload\222.pdf

这是因为网页客户端通过 GBK 编码将参数传递服务器,服务器以 UTF-8 来解码,所以出现了乱码问题。

好,我们在回到 Android 端。在服务器端不设置 UTF-8 的情况下,为什么通过 @PartMap 的方法是传递中文就不会乱码,通过上面方式就会乱码呢?

对于这个问题,我们分别抓包看下就知道,它们两个在传输的过程中有什么差别?

通过 @PartMap

--601c02cc-341c-4362-8a53-c7190066ee3f
Content-Disposition: form-data; name="description0"
Content-Transfer-Encoding: binary
Content-Type: multipart/form-data; charset=utf-8
Content-Length: 56通过 List<MultipartBody.Part> 多文件上传 PartMap0
--601c02cc-341c-4362-8a53-c7190066ee3f
Content-Disposition: form-data; name="description1"
Content-Transfer-Encoding: binary
Content-Type: multipart/form-data; charset=utf-8
Content-Length: 56通过 List<MultipartBody.Part> 多文件上传 PartMap1

通过 List<MultipartBody.Part>

--601c02cc-341c-4362-8a53-c7190066ee3f
Content-Disposition: form-data; name="description0"
Content-Length: 63通过 List<MultipartBody.Part> 多文件上传 in list 参数0
--601c02cc-341c-4362-8a53-c7190066ee3f
Content-Disposition: form-data; name="description1"
Content-Length: 63通过 List<MultipartBody.Part> 多文件上传 in list 参数1

对比我们发现 @PartMapList<MultipartBody.Part> 的方式多传输了:

Content-Transfer-Encoding: binary
Content-Type: multipart/form-data; charset=utf-8

也就是说客户端告知了服务器我是以 utf-8 编码的,那么服务器在解析这个请求的时候,封装 FileItem 的时候就会设置 charset,FileItem.getString() 的时候里面的 charset 就不会为空,自然就不会以 ISO-8859-1 来解码了。

同样都是 Retrofit API,为什么一个就会设置 charset,一个就不会呢? 我们深入源码来看看究竟。

先看下我们是怎么创建 MultipartBody.Part 的:

list.add(MultipartBody.Part.createFormData("description0", "通过 List<MultipartBody.Part> 多文件上传 in list 参数0"))
list.add(MultipartBody.Part.createFormData("description1", "通过 List<MultipartBody.Part> 多文件上传 in list 参数1"))

我们是通过 MultipartBody.Part.createFormData 来创建 Part 然后放进集合的,那么我们就来看看该方法:

public static Part createFormData(String name, String value) {return createFormData(name, null, RequestBody.create(null, value));
}

再来看看 RequestBody.create 方法:

public static RequestBody create(@Nullable MediaType contentType, String content) {Charset charset = UTF_8;if (contentType != null) {charset = contentType.charset();if (charset == null) {charset = UTF_8;contentType = MediaType.parse(contentType + "; charset=utf-8");}}byte[] bytes = content.getBytes(charset);return create(contentType, bytes);
}

我们发现只有当 MediaType contentType 不为空的时候会设置 content-typecharset

而 createFormData 方法将 MediaType 设置为 null,所以在抓包的时候为什么没有向服务器传递 charset 信息。

既然知道了原因,我们设置 MediaType 不就可以从客户端角度来解决这个问题吗?

所以只能我们自己来创建 RequestBody,然后将 RequestBody 传递给 createFormData 方法即可:

val param1 = RequestBody.create(MultipartBody.FORM, "通过 List<MultipartBody.Part> 多文件上传 in list 参数0")
list.add(MultipartBody.Part.createFormData("description0", null, param1))val param2 = RequestBody.create(MultipartBody.FORM, "通过 List<MultipartBody.Part> 多文件上传 in list 参数1")
list.add(MultipartBody.Part.createFormData("description1", null, param2))

在服务器端不设置 UTF-8 的情况下,看看控制台输出的结果:

getFieldName -> description0, getString -> 通过 List<MultipartBody.Part> 多文件上传 in list 参数0
getFieldName -> description1, getString -> 通过 List<MultipartBody.Part> 多文件上传 in list 参数1
文件存储路径:D:\xxx\WebApp\out\artifacts\ServletDemo_Web_exploded\upload\shumei.tx

多文件上传(MultipartBody)

除了 List<MultipartBody.Part> 的方式来实现 多图文 上传,还可以通过 MultipartBody 来实现:

// UploadService.java
@POST("fileUpload")
fun upload(@Body multipartBody: MultipartBody
): Call<ResponseBody>// 组装参数
private fun buildMultipartBody(): MultipartBody {val builder = MultipartBody.Builder()val param1 = RequestBody.create(MultipartBody.FORM, "通过 MultipartBody 多文件上传 in buildMultipartBody 参数1")builder.addFormDataPart("description0", null, param1)val param2 = RequestBody.create(MultipartBody.FORM, "通过 MultipartBody 多文件上传 in buildMultipartBody 参数1")builder.addFormDataPart("description0", null, param2)var index = 0files.forEach { entry: Map.Entry<String, Uri> ->val uri = entry.valueval mediaType = getMediaType(uri)val file = UriHelper.getFileFromUri(applicationContext, uri)val requestBody = RequestBody.create(mediaType, file)builder.addFormDataPart("file${++index}", file.name, requestBody)}return builder.build()
}// 执行上传文件
uploadService.upload(buildMultipartBody())

来看看服务器控制台输出结果:

getFieldName -> description0, getString -> 通过 MultipartBody 多文件上传 in buildMultipartBody 参数1
getFieldName -> description0, getString -> 通过 MultipartBody 多文件上传 in buildMultipartBody 参数1
文件存储路径:D:\dev\Workspace\MyGitHub\WebApp\out\artifacts\ServletDemo_Web_exploded\upload\shumei.tx

小结

本文主要介绍了 Retrofit 多图文上传功能,以及上传过程中遇到的中文乱码问题,我们从网页端、Android客户端、服务器端、Retrofit 源码角度 来分析了产生的原因及解决方案。

本文涉及到的服务器端程序代码地址:WebApp

本文涉及到的客户端程序代码地址:AndroidAll

AndroidAll 中除了 Retrofit,还有 Android 程序员需要掌握的技术栈,如:程序架构、设计模式、性能优化、数据结构算法、Kotlin、Flutter、NDK、Router、RxJava、Glide、LeakCanary、Dagger2、Retrofit、OkHttp、ButterKnife、Router 等等。持续更新,欢迎 star。

查看全文
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

相关文章

  1. 前端移动开发布局_flex布局

    百分比布局就是在传统布局中将盒子宽度换为其父亲宽度的百分比,较为简单。不做整理知识导航简单介绍 父项常见属性 子项常见属性1. 简单介绍 flex布局又被意为弹性布局,它为盒装模型提供了最大的灵活性。并且任意一个盒子都可以被指定为flex布局模式即任何的盒子均可以添加这…...

    2024/4/25 3:06:41
  2. 计算机的指令系统

    3.计算机概论组成篇.pdf计算机总线,计算机输出输入设备,计算机储存概叙,计算机指令系统,计算机控制器计算机总线,计算机输出输入设备,计算机储存概叙,计算机指令系统,计算机控制器计算机总线,计算机输出输入设备,计算机储存概叙,计算机指令系统,计算机控制器立即下…...

    2024/4/6 2:23:02
  3. 数据结构——递归

    栈 一:栈的概念 简单来说,栈就是方法自己调用自己,每次调用时候传入的参数是不一样的 二:代码 代码示例: package cn.littleworm;public class Test {public static void main(String[] args) {int n = 5;test1(n);}public static void test1(int n){if (n>2){test1(n-…...

    2024/4/15 20:19:39
  4. 机器学习入门笔记05-聚类

    无监督学习无监督学习是一类机器学习算法,在无监督学习中,训练样本的标记信息是未知的,目标是通过对无标记训练样本的学习来揭示数据的内在性质及规律,为进一步数据分析提供基础。通俗的讲,无监督学习就是“从无规律中找到规律”,在未知样本的真实结果的情况下,通过自主…...

    2024/3/29 7:14:45
  5. 字符串连接符

    比较两次输出结果: String a="3"; int b=4; int c=5; System.out.println(a+b+c); //345 System.out.println(b+c+a); //93都是从左到右运算 第一次遇到字符串a,后面都是字符串 第二次先算整数b+c,再和字符串a结合...

    2024/4/28 5:31:26
  6. 学习数据结构:树

    树的定义 树是一种一对多的数据结构。在一任意非空的树中,有且仅有一个根结点,其余结点可分为互不相交的有限集,每个集合本身又是一棵树,称为根的子树。下图的结构子树之间相交了,就不符合树的定义。结点的分类: ①结点拥有的子树个数称为结点的度。 ②度为0的结点称为叶…...

    2024/4/28 6:06:40
  7. 求1+2+…+n

    求1+2+…+n 求1+2+…+n,要求不能使用乘除法、for、while、if、else、switch、case等关键字及条件判断语句(A?B:C)。 样例 **输入:**10 ****输出:55 常规做法一:公式法 1+2+…+n=(n+1)*n/2 常规做法二:递归 int f(int n) {int res=n;if(n>0) res+=f(n-1);return res; …...

    2024/4/28 13:50:54
  8. tomcat启动脚本startup.sh分析

    一、分析说明为了写出更加完善的tomcat启动方面的自动化脚本,健壮自己用于代码上线自动化部署的脚本,特分析下tomcat的bin目录下的starup.sh脚本,学习标准的sh脚本的编写方法,从中吸取经验二、脚本分析#!/bin/sh # Licensed to the Apache Software Foundation (ASF) under…...

    2024/4/28 17:15:31
  9. 语言的学习方法

    不惧怕语言 许多编程语言的学习,让小伙伴们着实有点难受… 太难了~ 为啥呢? 这是因为,人类的思想,本生就和计算机有着很大的不同之处。对于计算机,其实它并没有大家想象中的那么聪明,相反的,计算机是一个非常木讷的小兄弟。 在一些事情发生之后,人类会对于各种情况,做…...

    2024/4/28 11:12:09
  10. Python 进阶之路(一)Python 核心知识 1 —— 数据类型之序列

    Python 数据类型之序列概念操作内置函数 概念操作内置函数...

    2024/3/29 7:14:38
  11. 三级网络技术之:交换机及其配置

    1.对于还没有配置设备管理地址的交换机,应采用的配置方式是Console。 交换机有三种配置方式: (1)使用Console控制端口进行本地配置。第一次配置只能采取这种方式。 (2)使用Telnet远程登录到交换机进行配置。 (3)使用Web,利用浏览器进行配置。 2.下列关于VLAN标识的描述…...

    2024/4/28 4:00:14
  12. .sync和v-model的异同

    <template><!-- v-model 是语法糖 --><Input v-model="username"><!-- 默认等效与下面这行<Input :value="username" @input="username=$event.target.value">--> </template>但是你可以通过设置 model 选项…...

    2024/3/29 7:14:36
  13. Spring 框架

    目录Spirng是什么Spring发展历程Spirng是什么Spring是分层的 Java SE/EE应用 full-stack 轻量级开源框架,以 IoC(Inverse Of Control:反转控制)和 AOP(Aspect Oriented Programming:面向切面编程)为内核。 提供了展现层 SpringMVC和持久层 Spring JDBCTemplate以及业务层…...

    2024/4/27 22:39:01
  14. 800. 背包问题 IX

    题目描述https://www.lintcode.com/problem/backpack-ix/description你总共有n万元,希望申请国外的大学,要申请的话需要交一定的申请费用,给出每个大学的申请费用以及你得到这个大学offer的成功概率,大学的数量是 m。如果经济条件允许,你可以申请多所大学。找到获得至少一…...

    2024/4/28 10:33:24
  15. Python学习笔记-Python 列表(List)

    序列中的每个元素都分配一个数字 - 它的位置,或索引,第一个索引是0,第二个索引是1,依此类推。此外,Python已经内置确定序列的长度以及确定最大和最小的元素的方法。列表的数据项不需要具有相同的类型创建一个列表,只要把逗号分隔的不同的数据项使用方括号括起来即可。如下…...

    2024/4/28 13:12:41
  16. 自动删除日志的shell脚本

    auto-del-7-days-ago-log.sh 文件内容,注意文件编码,保存时换行一定要用Unix格式#!/bin/sh #保留几天的日志 dayCount=15 #要删除的Log目录 log_gz=/home/data/logs/ssn_manage_sys #要删除的tomcat_Log目录 dir_gz_tomcat_log=/home/data/soft/tomcat-7.0.55-ssn-8090-8006/l…...

    2024/4/18 22:15:24
  17. A. On Number of Decompositions into Multipliers(组合数)

    总结: 第一步:质因子分解 第二步:每个质因子,相同质因子相乘p^k的方案数为C(k-1+n,n-1),然后把每个质因子方案数相乘 C(k-1+n,n-1)解释一下过程: k个相同元素 n个不同分组 符号隔板法用法,每个分组的数量可以为0,原因这个分组为空,就是num=1; #include<bits/stdc…...

    2024/4/19 21:12:59
  18. 支付宝二维码支付--沙箱测试版(一)

    关键词: 支付宝二维码支付、java实现、沙箱测试版 实现功能:java后台代码按照参数生成相应订单,转到HTML页面展示订单二维码,用户扫码支付结束后,进行页面跳转。 本文章实现:沙箱支付宝APP端(Android)配置,收款方商户信息配置 首先,因为是沙箱测试版,所以我们需要在…...

    2024/3/29 7:08:00
  19. js闭包的理解

    闭包(closure)一个有权访问另一个函数作用域中的变量的函数,我们称之为闭包。闭包的主要作用是延伸变量的作用域,可以让变量不仅仅在一个函数作用域中使用。代码如下:function Foo() {var i = 10;return function() {console.log(i);} } var test = Foo(); test(); //10如…...

    2024/3/29 7:07:58
  20. webpack概念简介

    目录一、webpack概述1. 什么是webpack?2. 为什么要使用webpack?二、webpack相关概念1. 入口(entry)2. 出口(output)3. 加载器(loader)4. 插件(plugin)三、补充 - 热更新原理总结 一、webpack概述 1. 什么是webpack? webpack被定义为现代 JavaScript 应用程序的静态模…...

    2024/3/29 7:07:57

最新文章

  1. 利用STM32实现语音识别功能

    引言 随着物联网和智能设备的普及&#xff0c;语音识别技术正逐渐成为用户交互的主流方式之一。 STM32微控制器具备处理高效率语音识别算法的能力&#xff0c;使其成为实现低成本、低功耗语音交互系统的理想选择。 本教程将介绍如何在STM32平台上开发和部署一个基础的语音识…...

    2024/4/28 18:24:33
  2. 梯度消失和梯度爆炸的一些处理方法

    在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言&#xff0c;在此感激不尽。 权重和梯度的更新公式如下&#xff1a; w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...

    2024/3/20 10:50:27
  3. 【AcWing】蓝桥杯集训每日一题Day22|区间DP|博弈论|1388.游戏(C++)

    1388.游戏 1388. 游戏 - AcWing题库难度&#xff1a;中等时/空限制&#xff1a;1s / 64MB总通过数&#xff1a;1429总尝试数&#xff1a;1925来源&#xff1a;usaco training 3.3算法标签博弈论DP区间DP 题目内容 玩家一和玩家二共同玩一个小游戏。 给定一个包含 N 个正整数的…...

    2024/4/13 16:49:51
  4. 文件系统 FTP Ubuntu 安装入门介绍

    FTP 环境: Ubuntu 14.04 blog zh_CN ubuntu14.04 Install 全新安装&#xff1a;apt-get install vsftpd 重新安装:apt-get --reinstall install vsftpd 卸载并清除配置文件&#xff1a;apt-get --purge remove vsftpd Start & Restart $ service vsftpd start $ se…...

    2024/4/26 19:07:53
  5. OpenAI 宣布, ChatGPT 网页端无需注册就能立即使用(2024年4月1日)

    今天&#xff0c;OpenAI宣布&#xff0c;为了让更多人轻松体验人工智能的强大功能&#xff0c;现在无需注册账户即可立即使用 ChatGPT。这一变化是他们使命的核心部分&#xff0c;即让像 ChatGPT 这样的工具广泛可用&#xff0c;让世界各地的人们都能享受到 AI 带来的好处。 网…...

    2024/4/23 17:22:07
  6. 【外汇早评】美通胀数据走低,美元调整

    原标题:【外汇早评】美通胀数据走低,美元调整昨日美国方面公布了新一期的核心PCE物价指数数据,同比增长1.6%,低于前值和预期值的1.7%,距离美联储的通胀目标2%继续走低,通胀压力较低,且此前美国一季度GDP初值中的消费部分下滑明显,因此市场对美联储后续更可能降息的政策…...

    2024/4/28 13:52:11
  7. 【原油贵金属周评】原油多头拥挤,价格调整

    原标题:【原油贵金属周评】原油多头拥挤,价格调整本周国际劳动节,我们喜迎四天假期,但是整个金融市场确实流动性充沛,大事频发,各个商品波动剧烈。美国方面,在本周四凌晨公布5月份的利率决议和新闻发布会,维持联邦基金利率在2.25%-2.50%不变,符合市场预期。同时美联储…...

    2024/4/28 3:28:32
  8. 【外汇周评】靓丽非农不及疲软通胀影响

    原标题:【外汇周评】靓丽非农不及疲软通胀影响在刚结束的周五,美国方面公布了新一期的非农就业数据,大幅好于前值和预期,新增就业重新回到20万以上。具体数据: 美国4月非农就业人口变动 26.3万人,预期 19万人,前值 19.6万人。 美国4月失业率 3.6%,预期 3.8%,前值 3…...

    2024/4/26 23:05:52
  9. 【原油贵金属早评】库存继续增加,油价收跌

    原标题:【原油贵金属早评】库存继续增加,油价收跌周三清晨公布美国当周API原油库存数据,上周原油库存增加281万桶至4.692亿桶,增幅超过预期的74.4万桶。且有消息人士称,沙特阿美据悉将于6月向亚洲炼油厂额外出售更多原油,印度炼油商预计将每日获得至多20万桶的额外原油供…...

    2024/4/28 13:51:37
  10. 【外汇早评】日本央行会议纪要不改日元强势

    原标题:【外汇早评】日本央行会议纪要不改日元强势近两日日元大幅走强与近期市场风险情绪上升,避险资金回流日元有关,也与前一段时间的美日贸易谈判给日本缓冲期,日本方面对汇率问题也避免继续贬值有关。虽然今日早间日本央行公布的利率会议纪要仍然是支持宽松政策,但这符…...

    2024/4/27 17:58:04
  11. 【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响

    原标题:【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响近日伊朗局势升温,导致市场担忧影响原油供给,油价试图反弹。此时OPEC表态稳定市场。据消息人士透露,沙特6月石油出口料将低于700万桶/日,沙特已经收到石油消费国提出的6月份扩大出口的“适度要求”,沙特将满…...

    2024/4/27 14:22:49
  12. 【外汇早评】美欲与伊朗重谈协议

    原标题:【外汇早评】美欲与伊朗重谈协议美国对伊朗的制裁遭到伊朗的抗议,昨日伊朗方面提出将部分退出伊核协议。而此行为又遭到欧洲方面对伊朗的谴责和警告,伊朗外长昨日回应称,欧洲国家履行它们的义务,伊核协议就能保证存续。据传闻伊朗的导弹已经对准了以色列和美国的航…...

    2024/4/28 1:28:33
  13. 【原油贵金属早评】波动率飙升,市场情绪动荡

    原标题:【原油贵金属早评】波动率飙升,市场情绪动荡因中美贸易谈判不安情绪影响,金融市场各资产品种出现明显的波动。随着美国与中方开启第十一轮谈判之际,美国按照既定计划向中国2000亿商品征收25%的关税,市场情绪有所平复,已经开始接受这一事实。虽然波动率-恐慌指数VI…...

    2024/4/28 15:57:13
  14. 【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试

    原标题:【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试美国和伊朗的局势继续升温,市场风险情绪上升,避险黄金有向上突破阻力的迹象。原油方面稍显平稳,近期美国和OPEC加大供给及市场需求回落的影响,伊朗局势并未推升油价走强。近期中美贸易谈判摩擦再度升级,美国对中…...

    2024/4/27 17:59:30
  15. 【原油贵金属早评】市场情绪继续恶化,黄金上破

    原标题:【原油贵金属早评】市场情绪继续恶化,黄金上破周初中国针对于美国加征关税的进行的反制措施引发市场情绪的大幅波动,人民币汇率出现大幅的贬值动能,金融市场受到非常明显的冲击。尤其是波动率起来之后,对于股市的表现尤其不安。隔夜美国股市出现明显的下行走势,这…...

    2024/4/25 18:39:16
  16. 【外汇早评】美伊僵持,风险情绪继续升温

    原标题:【外汇早评】美伊僵持,风险情绪继续升温昨日沙特两艘油轮再次发生爆炸事件,导致波斯湾局势进一步恶化,市场担忧美伊可能会出现摩擦生火,避险品种获得支撑,黄金和日元大幅走强。美指受中美贸易问题影响而在低位震荡。继5月12日,四艘商船在阿联酋领海附近的阿曼湾、…...

    2024/4/28 1:34:08
  17. 【原油贵金属早评】贸易冲突导致需求低迷,油价弱势

    原标题:【原油贵金属早评】贸易冲突导致需求低迷,油价弱势近日虽然伊朗局势升温,中东地区几起油船被袭击事件影响,但油价并未走高,而是出于调整结构中。由于市场预期局势失控的可能性较低,而中美贸易问题导致的全球经济衰退风险更大,需求会持续低迷,因此油价调整压力较…...

    2024/4/26 19:03:37
  18. 氧生福地 玩美北湖(上)——为时光守候两千年

    原标题:氧生福地 玩美北湖(上)——为时光守候两千年一次说走就走的旅行,只有一张高铁票的距离~ 所以,湖南郴州,我来了~ 从广州南站出发,一个半小时就到达郴州西站了。在动车上,同时改票的南风兄和我居然被分到了一个车厢,所以一路非常愉快地聊了过来。 挺好,最起…...

    2024/4/28 1:22:35
  19. 氧生福地 玩美北湖(中)——永春梯田里的美与鲜

    原标题:氧生福地 玩美北湖(中)——永春梯田里的美与鲜一觉醒来,因为大家太爱“美”照,在柳毅山庄去寻找龙女而错过了早餐时间。近十点,向导坏坏还是带着饥肠辘辘的我们去吃郴州最富有盛名的“鱼头粉”。说这是“十二分推荐”,到郴州必吃的美食之一。 哇塞!那个味美香甜…...

    2024/4/25 18:39:14
  20. 氧生福地 玩美北湖(下)——奔跑吧骚年!

    原标题:氧生福地 玩美北湖(下)——奔跑吧骚年!让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 啊……啊……啊 两…...

    2024/4/26 23:04:58
  21. 扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!

    原标题:扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!扒开伪装医用面膜,翻六倍价格宰客!当行业里的某一品项火爆了,就会有很多商家蹭热度,装逼忽悠,最近火爆朋友圈的医用面膜,被沾上了污点,到底怎么回事呢? “比普通面膜安全、效果好!痘痘、痘印、敏感肌都能用…...

    2024/4/27 23:24:42
  22. 「发现」铁皮石斛仙草之神奇功效用于医用面膜

    原标题:「发现」铁皮石斛仙草之神奇功效用于医用面膜丽彦妆铁皮石斛医用面膜|石斛多糖无菌修护补水贴19大优势: 1、铁皮石斛:自唐宋以来,一直被列为皇室贡品,铁皮石斛生于海拔1600米的悬崖峭壁之上,繁殖力差,产量极低,所以古代仅供皇室、贵族享用 2、铁皮石斛自古民间…...

    2024/4/28 5:48:52
  23. 丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者

    原标题:丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者【公司简介】 广州华彬企业隶属香港华彬集团有限公司,专注美业21年,其旗下品牌: 「圣茵美」私密荷尔蒙抗衰,产后修复 「圣仪轩」私密荷尔蒙抗衰,产后修复 「花茵莳」私密荷尔蒙抗衰,产后修复 「丽彦妆」专注医学护…...

    2024/4/26 19:46:12
  24. 广州械字号面膜生产厂家OEM/ODM4项须知!

    原标题:广州械字号面膜生产厂家OEM/ODM4项须知!广州械字号面膜生产厂家OEM/ODM流程及注意事项解读: 械字号医用面膜,其实在我国并没有严格的定义,通常我们说的医美面膜指的应该是一种「医用敷料」,也就是说,医用面膜其实算作「医疗器械」的一种,又称「医用冷敷贴」。 …...

    2024/4/27 11:43:08
  25. 械字号医用眼膜缓解用眼过度到底有无作用?

    原标题:械字号医用眼膜缓解用眼过度到底有无作用?医用眼膜/械字号眼膜/医用冷敷眼贴 凝胶层为亲水高分子材料,含70%以上的水分。体表皮肤温度传导到本产品的凝胶层,热量被凝胶内水分子吸收,通过水分的蒸发带走大量的热量,可迅速地降低体表皮肤局部温度,减轻局部皮肤的灼…...

    2024/4/27 8:32:30
  26. 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...

    解析如下&#xff1a;1、长按电脑电源键直至关机&#xff0c;然后再按一次电源健重启电脑&#xff0c;按F8健进入安全模式2、安全模式下进入Windows系统桌面后&#xff0c;按住“winR”打开运行窗口&#xff0c;输入“services.msc”打开服务设置3、在服务界面&#xff0c;选中…...

    2022/11/19 21:17:18
  27. 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。

    %读入6幅图像&#xff08;每一幅图像的大小是564*564&#xff09; f1 imread(WashingtonDC_Band1_564.tif); subplot(3,2,1),imshow(f1); f2 imread(WashingtonDC_Band2_564.tif); subplot(3,2,2),imshow(f2); f3 imread(WashingtonDC_Band3_564.tif); subplot(3,2,3),imsho…...

    2022/11/19 21:17:16
  28. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...

    win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面&#xff0c;在等待界面中我们需要等待操作结束才能关机&#xff0c;虽然这比较麻烦&#xff0c;但是对系统进行配置和升级…...

    2022/11/19 21:17:15
  29. 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...

    有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows&#xff0c;请勿关闭计算机”的提示&#xff0c;要过很久才能进入系统&#xff0c;有的用户甚至几个小时也无法进入&#xff0c;下面就教大家这个问题的解决方法。第一种方法&#xff1a;我们首先在左下角的“开始…...

    2022/11/19 21:17:14
  30. win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...

    置信有很多用户都跟小编一样遇到过这样的问题&#xff0c;电脑时发现开机屏幕显现“正在配置Windows Update&#xff0c;请勿关机”(如下图所示)&#xff0c;而且还需求等大约5分钟才干进入系统。这是怎样回事呢&#xff1f;一切都是正常操作的&#xff0c;为什么开时机呈现“正…...

    2022/11/19 21:17:13
  31. 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...

    Win7系统开机启动时总是出现“配置Windows请勿关机”的提示&#xff0c;没过几秒后电脑自动重启&#xff0c;每次开机都这样无法进入系统&#xff0c;此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一&#xff1a;开机按下F8&#xff0c;在出现的Windows高级启动选…...

    2022/11/19 21:17:12
  32. 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...

    有不少windows10系统用户反映说碰到这样一个情况&#xff0c;就是电脑提示正在准备windows请勿关闭计算机&#xff0c;碰到这样的问题该怎么解决呢&#xff0c;现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法&#xff1a;1、2、依次…...

    2022/11/19 21:17:11
  33. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...

    今天和大家分享一下win7系统重装了Win7旗舰版系统后&#xff0c;每次关机的时候桌面上都会显示一个“配置Windows Update的界面&#xff0c;提示请勿关闭计算机”&#xff0c;每次停留好几分钟才能正常关机&#xff0c;导致什么情况引起的呢&#xff1f;出现配置Windows Update…...

    2022/11/19 21:17:10
  34. 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...

    只能是等着&#xff0c;别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚&#xff0c;只能是考虑备份数据后重装系统了。解决来方案一&#xff1a;管理员运行cmd&#xff1a;net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...

    2022/11/19 21:17:09
  35. 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?

    原标题&#xff1a;电脑提示“配置Windows Update请勿关闭计算机”怎么办&#xff1f;win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢&#xff1f;一般的方…...

    2022/11/19 21:17:08
  36. 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...

    关机提示 windows7 正在配置windows 请勿关闭计算机 &#xff0c;然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;关机提示 windows7 正在配…...

    2022/11/19 21:17:05
  37. 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...

    钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...

    2022/11/19 21:17:05
  38. 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...

    前几天班里有位学生电脑(windows 7系统)出问题了&#xff0c;具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面&#xff0c;长时间没反应&#xff0c;无法进入系统。这个问题原来帮其他同学也解决过&#xff0c;网上搜了不少资料&#x…...

    2022/11/19 21:17:04
  39. 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...

    本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法&#xff0c;并在最后教给你1种保护系统安全的好方法&#xff0c;一起来看看&#xff01;电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中&#xff0c;添加了1个新功能在“磁…...

    2022/11/19 21:17:03
  40. 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...

    许多用户在长期不使用电脑的时候&#xff0c;开启电脑发现电脑显示&#xff1a;配置windows更新失败&#xff0c;正在还原更改&#xff0c;请勿关闭计算机。。.这要怎么办呢&#xff1f;下面小编就带着大家一起看看吧&#xff01;如果能够正常进入系统&#xff0c;建议您暂时移…...

    2022/11/19 21:17:02
  41. 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...

    配置windows update失败 还原更改 请勿关闭计算机&#xff0c;电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;配置windows update失败 还原更改 请勿关闭计算机&#x…...

    2022/11/19 21:17:01
  42. 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...

    不知道大家有没有遇到过这样的一个问题&#xff0c;就是我们的win7系统在关机的时候&#xff0c;总是喜欢显示“准备配置windows&#xff0c;请勿关机”这样的一个页面&#xff0c;没有什么大碍&#xff0c;但是如果一直等着的话就要两个小时甚至更久都关不了机&#xff0c;非常…...

    2022/11/19 21:17:00
  43. 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...

    当电脑出现正在准备配置windows请勿关闭计算机时&#xff0c;一般是您正对windows进行升级&#xff0c;但是这个要是长时间没有反应&#xff0c;我们不能再傻等下去了。可能是电脑出了别的问题了&#xff0c;来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...

    2022/11/19 21:16:59
  44. 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...

    我们使用电脑的过程中有时会遇到这种情况&#xff0c;当我们打开电脑之后&#xff0c;发现一直停留在一个界面&#xff1a;“配置Windows Update失败&#xff0c;还原更改请勿关闭计算机”&#xff0c;等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢&#xff0…...

    2022/11/19 21:16:58
  45. 如何在iPhone上关闭“请勿打扰”

    Apple’s “Do Not Disturb While Driving” is a potentially lifesaving iPhone feature, but it doesn’t always turn on automatically at the appropriate time. For example, you might be a passenger in a moving car, but your iPhone may think you’re the one dri…...

    2022/11/19 21:16:57