前提

了解如何实现客户端和服务端通讯
上一篇博客——SpringBoot+Netty整合websocket(一)——客户端和服务端通讯

实现点对点聊天

后端

1.建立服务端WebSocketNettyServer

@Slf4j
@Configuration
public class WebSocketNettyServer {/** netty整合websocket的端口 */@Value("${netty.port}")private int port;public void run() throws InterruptedException {EventLoopGroup boss = new NioEventLoopGroup();EventLoopGroup worker = new NioEventLoopGroup();try {ServerBootstrap bootstrap = new ServerBootstrap();bootstrap.group(boss,worker).channel(NioServerSocketChannel.class).option(ChannelOption.SO_BACKLOG,1024).childOption(ChannelOption.TCP_NODELAY,true).childHandler(new ChannelInitializer<SocketChannel>() {@Overrideprotected void initChannel(SocketChannel ch) throws Exception {//web基于http协议的解码器ch.pipeline().addLast(new HttpServerCodec());//对大数据流的支持ch.pipeline().addLast(new ChunkedWriteHandler());//对http message进行聚合,聚合成FullHttpRequest或FullHttpResponsech.pipeline().addLast(new HttpObjectAggregator(1024 * 64));//websocket服务器处理对协议,用于指定给客户端连接访问的路径//该handler会帮你处理一些繁重的复杂的事//会帮你处理握手动作:handshaking(close,ping,pong) ping + pong = 心跳//对于websocket来讲,都是以frames进行传输的,不同的数据类型对应的frames也不同ch.pipeline().addLast(new WebSocketServerProtocolHandler("/ws"));//添加我们的自定义channel处理器ch.pipeline().addLast(new WebSocketHandler());}});log.info("服务器启动中,websocket的端口为:"+port);ChannelFuture future = bootstrap.bind(port).sync();future.channel().closeFuture().sync();} finally {//关闭主从线程池worker.shutdownGracefully();boss.shutdownGracefully();}}
}
2.建立聊天类

聊天类主要是消息本身的各种属性

@Data
public class ChatVO implements Serializable {/** 消息id */private Integer questionId;/**聊天信息类型*/private String chatMessageType;/**聊天内容*/private String content;/**发送方ID*/private Integer fromUserId;/**接收方ID*/private Integer toUserId;/**消息时间*/@JSONField(format="yyyy-MM-dd HH:mm:ss")private Date dateTime;}

3.封装聊天消息的VO

继承聊天类,拥有聊天类的属性,额外封装消息的额外属性(比如:消息类型、是否读取等)

@EqualsAndHashCode(callSuper = true)
@Data
public class ChatMsgVO extends ChatVO {/** 动作类型 */private Integer action;/** 消息签收状态 */private MsgSignFlagEnum signed;}

4.建立枚举类MsgSignFlagEnum

主要用于判断消息是否签收

public enum MsgSignFlagEnum {/** 消息是否签收 */unsign(0,"未签收"),signed(1,"已签收");@Getterpublic final int type;@Getterpublic final String value;private MsgSignFlagEnum(int type,String value) {this.type = type;this.value = value;}}

5.建立枚举类MsgActionEnum

主要用于确定客户端发送消息的动作类型

public enum MsgActionEnum {/** 第一次(或重连)初始化连接 */CONNECT(1,"第一次(或重连)初始化连接"),/** 聊天消息 */CHAT(2,"聊天消息"),/** 客户端保持心跳 */KEEPALIVE(3,"客户端保持心跳");public final Integer type;public final String content;private MsgActionEnum(Integer type,String content) {this.type = type;this.content = content;}
}

6.在写WebSocketHandler之前,将用户Id跟Channel做一个绑定

主要用于确定客户端信息

@Slf4j
public class UserChannelRel {/** 用户id为键,channel为值 */private static ConcurrentHashMap<Integer, Channel> manager = new ConcurrentHashMap<>();/** 添加客户端与channel绑定 */public static void put(Integer senderId,Channel channel) {manager.put(senderId,channel);}/** 根据用户id查询 */public static Channel get(Integer senderId) {return manager.get(senderId);}/** 根据用户id,判断是否存在此客户端(即客户端是否在线) */public static boolean isContainsKey(Integer userId){return manager.containsKey(userId);}/** 输出 */public static void output() {manager.forEach(( key, value ) -> log.info("UserId:" + key + ",ChannelId:" +value.id().asLongText()));}}

到这里只要再建立WebSocketHandler,就可以实现点对点聊天

7.建立WebSocketHandler

@Slf4j
public class WebSocketHandler extends SimpleChannelInboundHandler<Object> {/*** 客户端组* 用于记录和管理所有客户端的channel*/public static ChannelGroup channelGroup;static {channelGroup = new DefaultChannelGroup(GlobalEventExecutor.INSTANCE);}/*** 接收客户端传来的消息** @param ctx* @param msg* @throws Exception*/@Overrideprotected void channelRead0 ( ChannelHandlerContext ctx, Object msg ) throws Exception {Channel currentChannel = ctx.channel();//文本消息if (msg instanceof TextWebSocketFrame) {String message = ((TextWebSocketFrame) msg).text();System.out.println("收到客户端消息:" + message);//json消息转换为Javabean对象ChatMsgVO chatMsgVO = null;try {chatMsgVO = JSONUtil.toBean(message, ChatMsgVO.class, true);} catch (JSONException e) {e.printStackTrace();System.out.println("json解析异常,发送的消息应该为json格式");return;}//得到消息的动作类型Integer action = chatMsgVO.getAction();//客户端第一次连接websocket或者重连时执行if (action.equals(MsgActionEnum.CONNECT.type)) {//当websocket第一次open的时候,初始化channel,把用的channel和userId关联起来Integer fromUserId = chatMsgVO.getFromUserId();UserChannelRel.put(fromUserId, currentChannel);//测试channelGroup.forEach(channel -> log.info(channel.id().asLongText()));UserChannelRel.output();} else if (action.equals(MsgActionEnum.CHAT.type)) {//聊天类型的消息,把聊天记录保存到redis,同时标记消息的签收状态[是否签收]Integer toUserId = chatMsgVO.getToUserId();//设置发送消息的时间chatVO.setDateTime(new DateTime());/* 发送消息给指定用户 *///判断消息是否符合定义的类型if (ChatTypeVerificationUtil.verifyChatType(chatVO.getChatMessageType())) {//发送消息给指定用户if (toUserId > 0 && UserChannelRel.isContainsKey(toUserId)) {sendMessage(toUserId, JSONUtil.toJsonStr(chatVO));}} else {//消息不符合定义的类型的处理}} else if (action.equals(MsgActionEnum.KEEPALIVE.type)) {//心跳类型的消息log.info("收到来自channel为[" + currentChannel + "]的心跳包");}}//二进制消息if (msg instanceof BinaryWebSocketFrame) {System.out.println("收到二进制消息:" + ((BinaryWebSocketFrame) msg).content().readableBytes());BinaryWebSocketFrame binaryWebSocketFrame = new BinaryWebSocketFrame(Unpooled.buffer().writeBytes("hello".getBytes()));//给客户端发送的消息ctx.channel().writeAndFlush(binaryWebSocketFrame);}//ping消息if (msg instanceof PongWebSocketFrame) {System.out.println("客户端ping成功");}//关闭消息if (msg instanceof CloseWebSocketFrame) {System.out.println("客户端关闭,通道关闭");Channel channel = ctx.channel();channel.close();}}/*** Handler活跃状态,表示连接成功* 当客户端连接服务端之后(打开连接)* 获取客户端的channel,并且放到ChannelGroup中去进行管理** @param ctx* @throws Exception*/@Overridepublic void handlerAdded ( ChannelHandlerContext ctx ) throws Exception {System.out.println("与客户端连接成功");channelGroup.add(ctx.channel());}/*** @param ctx* @throws Exception*/@Overridepublic void handlerRemoved ( ChannelHandlerContext ctx ) throws Exception {//当触发handlerRemoved,ChannelGroup会自动移除对应的客户端的channel//所以下面这条语句可不写
//        clients.remove(ctx.channel());log.info("客户端断开,channel对应的长id为:" + ctx.channel().id().asLongText());log.info("客户端断开,channel对应的短id为:" + ctx.channel().id().asShortText());}/*** 异常处理** @param ctx* @param cause* @throws Exception*/@Overridepublic void exceptionCaught ( ChannelHandlerContext ctx, Throwable cause ) throws Exception {System.out.println("连接异常:" + cause.getMessage());cause.printStackTrace();ctx.channel().close();channelGroup.remove(ctx.channel());}@Overridepublic void userEventTriggered ( ChannelHandlerContext ctx, Object evt ) throws Exception {//IdleStateEvent是一个用户事件,包含读空闲/写空闲/读写空闲if (evt instanceof IdleStateEvent) {IdleStateEvent event = (IdleStateEvent) evt;if (event.state() == IdleState.READER_IDLE) {log.info("进入读空闲");} else if (event.state() == IdleState.WRITER_IDLE) {log.info("进入写空闲");} else if (event.state() == IdleState.ALL_IDLE) {log.info("channel关闭前,用户数量为:" + channelGroup.size());//关闭无用的channel,以防资源浪费ctx.channel().close();log.info("channel关闭后,用户数量为:" + channelGroup.size());}}}/*** 给指定用户发内容* 后续可以掉这个方法推送消息给客户端*/public void sendMessage ( Integer toUserId, String message ) {Channel channel = UserChannelRel.get(toUserId);channel.writeAndFlush(new TextWebSocketFrame(message));}/*** 群发消息*/public void sendMessageAll ( String message ) {channelGroup.writeAndFlush(new TextWebSocketFrame(message));}}
1.JSON处理

接受客户端的消息都是json数据类型的,这里采用的json处理使用的是Hutool工具包(完善并且轻量级的Java工具包)
如何使用?
直接引入依赖即可

<dependency><groupId>cn.hutool</groupId><artifactId>hutool-all</artifactId><version>5.3.5</version>
</dependency>

详细使用请参考官网:https://hutool.cn/docs/

2.TextWebSocketFrame: 在netty中,用于为websocket专门处理文本的对象,frame是消息的载体
3.SimpleChannelInboundHandler<Object>中的Object意味可以接收任意类型的消息。
4.ChatTypeVerificationUtil主要用于验证消息类型(比如文本、图片、语音)等
public class ChatTypeVerificationUtil {/*** 功能描述:枚举:聊天信息的类型* @author RenShiWei* Date: 2020/2/6 15:58*/@Getter@NoArgsConstructor@AllArgsConstructorpublic enum ChatMessageTypeEnum {/**文本*/TEXT("text"),/**图片*/IMAGE("image"),/**音频*/VOICE("voice"),/**心跳包*/HEART("heart"),;private String chatType;}/*** 功能描述:* @param chatType 预判断类型* @return boolean*/public static boolean verifyChatType(String chatType) {//循环枚举for (ChatMessageTypeEnum airlineTypeEnum : ChatMessageTypeEnum.values()) {if (StringUtils.isNotBlank(chatType)&&chatType.equals(airlineTypeEnum.getChatType())){return true;}}return false;}}

8.在SpringBoot启动时,启动Netty整合的websocket服务

启动类实现CommandLineRunner 接口,重写run方法,用来在项目启动时预加载资源

/*** 声明CommandLineRunner接口,实现run方法,就能给启动项目同时启动netty服务*/
@SpringBootApplication
public class WebsocketApplication implements CommandLineRunner {/** 注入netty整合websocket的服务  CommandLineRunner */@Autowiredprivate WebSocketNettyServer webSocketNettyServer;public static void main(String[] args) throws InterruptedException {SpringApplication.run(WebsocketApplication.class, args);}/***声明CommandLineRunner接口,实现run方法,就能给启动项目同时启动netty服务*/@Overridepublic void run ( String... args ) throws Exception {webSocketNettyServer.run();}
}

在application.yml配置netty的启动端口

netty:port: 10101

连接netty整合的websocket路径:ws://127.0.0.1:10101/ws

可通过在线websocket进行测试:http://www.easyswoole.com/wstool.html

在这里插入图片描述

前端使用

连接地址

前端连接websocket地址:ws://127.0.0.1:10101/ws
10101为yml文件自定义的端口(可以自定义,但不能与项目端口重复)

第一次连接或者重连websocket

第一次连接或者重连websocket必须发送指定的json消息类型
例如:

{"fromUserId": "1","action":"1"
}

fromUserId为连接websocket的用户id
action为后端定义的消息动作(1代表的是首次连接或者重连)。

客户端发送的消息类型

{
"questionId": "113",
"chatMessageType": "text",
"content": "01用户发送消息",
"fromUserId": "1",
"toUserId": "2",
"action":"2"
} 

questionIdchatMessageType为业务需求,暂时可以忽略
content为发送消息的内容
fromUserId为发送方的用户id
toUserId为接受方的用户id
action为后端定义的消息动作(2代表的是聊天消息)。

心跳包

很多时候,服务器需要在一定的时间段内知道客户端是否还在线,所以可以采用客户端定期给服务器发送心跳数据的方式。

{"fromUserId": "1","action":"3"
}

fromUserId为发送方的用户id
action为后端定义的消息动作(3代表的是心跳包消息)。

注意:action可以定义成常量,与后端对应,防止出错,也方便维护。

前端实现

具体的前端实现,略。可参考上一篇文章,一般需要根据具体的业务逻辑来写。

总结

  1. 现在可以实现点对点聊天,即客户端与客户端通信,但是只是实现了最基础的聊天功能,并不是很完善。
  2. 一般都需要将聊天的消息存储在数据库当中,保存聊天记录。但是聊天的业务一般比较频繁,如果每条消息都存储在数据库,会给数据库造成很大的压力。所以一般采用的方式都是采用redis缓存消息,等到积累到一定的程度,然后在将消息统一存储进数据库。
  3. 现在客户端发送消息只能是对方客户端也连接websocket(即在线状态下)才可以实现通讯,如何对方离线,则不行,缺少对离线消息的处理。

下一篇博客将总结如何将客户端通信的消息缓存进redis,并达到一定的条件下存储进mysql

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

相关文章

  1. 【类与对象、封装】

    【类与对象、封装】 面向对象思想的概述 面向过程:当需要实现一个功能的时候,每一个具体的步骤都要亲历亲为,详细处理每一个细节; 面向过程:当需要实现一个功能的时候,不关心具体步骤,而是找一个已经具有该功能的人,来帮我实现。 import java.util.Arrays;public class…...

    2024/4/28 12:16:52
  2. python学习笔记-第一天(202.5.25)-安装基础

    1、解释器:安装python意思是安装python解释器 2、编辑器 3、包 方案一:只安装python解释器 方案二:只安装anaconda(自带很多库,还有编辑器,兼容python版本),但是anaconda版本不兼容 方案三:安装python解释器+安装pycharm(编辑器)或者VsCode等 方案四:安装Anaconda+…...

    2024/4/28 2:55:23
  3. 大一计算机新生看到这篇文章 赢了一半

    计算机系学生大一新手篇(也适用于大一迷茫的大二学生)**相信每个刚刚步入大学的人 都对自己的大学有一个美好的期盼**希望自己的大学 风生水起 有一个快乐的四年 以及一个美好的未来 谈一段甜甜的恋爱 有一群好兄弟 嘻嘻 我来是作为一个步入大二的学长 给刚步入大学的萌新(…...

    2024/4/24 7:27:30
  4. 《FCOS: Fully Convolutional One-Stage Object Detection》论文详解

    《FCOS: Fully Convolutional One-Stage Object Detection》发表于ICCV2019 代码地址:https://github.com/tianzhi0549/FCOS/ 这篇文章主要是觉得现有的基于anchor的目标检测器存在一些缺点:检测结果对于anchor的大小,尺度比例,数量比较敏感 即使认真的调好的上述参数,检测…...

    2024/4/28 0:42:19
  5. 10分钟 搭建 NPM 私服

    私服 npm 能做什么?如果一个公司的项目非常多,而且有很多的方法、组件、api都是可以共用的。如果没有私服 npm,那么我们将不断的复制粘贴这些代码到各个项目中,一旦其中的某一处需要修改,那么所有的项目都需要改一遍。更好地维护这些公共代码,比较好的处理方式是将这些公…...

    2024/4/28 14:08:00
  6. BaseServlet抽取

    平常我们写Servlet时总是一个功能一个Servlet,然后发现自己写的Servlet文件一大堆。 就比如登录,注册,退出,验证等等。 但是我们仔细分析登录,注册,退出,验证等等好像都是和用户有关的。那么我们能不能将与用户有关的写一个Servlet,与货物有关的写一个Servet呢? 再仔细…...

    2024/4/27 22:46:25
  7. 腾讯大动作,使用wetool等之类的第三方工具的用户注意了!

    最近腾讯大动作不断,从企业微信到视频号,再到大面积的wetool用户被封,有网友发出疑问,腾讯又想要出什么幺蛾子?众所周知,腾讯对于外挂容忍度是一项不高的,你如果使用外挂,让腾讯感觉受到威胁,那你可就危险了。自5月20日起,其实就已经有很多用户反映自己的微信账号被封…...

    2024/4/29 0:16:07
  8. 嵌入式计算机的关键特征,与通用计算机的区别

    从汽水自动售货机到汽车系统,几乎所有东西都可以在嵌入式计算机上运行。即使嵌入式计算机涵盖了广泛的专用系统,但它们之间也具有共同的特征,这些共同的特征在许多计算条件下都具有出色的优势: 通过热管和散热器的被动冷却消除了对将内部组件暴露于灰尘和碎屑的机械风扇的需…...

    2024/4/28 17:22:27
  9. Java web题目

    Java Web应用开发 - 中国大学mooc [1周]Java Web应用开发概述 1.1 Web应用程序概述随堂测验 1、以下哪个概念或者哪种功能属于“Web前端”( ) A、Web系统中以网页等形式为用户提供的部分,用户能接触到的部分 B、Web系统中负责数据存取的部分 C、Web系统中负责平台稳定性与性…...

    2024/4/21 14:41:43
  10. 吃什么1.1 - 开发笔记

    吃什么1.1 - 开发笔记 写作目的 【吃什么1.1】 为 【吃什么1.0】的进阶版,功能不变,只是换了另一种技术实现食物列表的呈现(ListView),其他部分可以参考应用——吃什么?开发笔记。 实现手段 本次开发主要用于学习列表类视图的使用,因此文章主要描述我的学习过程。 ListV…...

    2024/4/28 11:31:15
  11. Yocto 配置串口必要参数

    CONSOLE_LINUX = "ttyS1" ## 当然tty可以选择 CONSOLE ?= "${CONSOLE_LINUX}" SERIAL_CONSOLES = "115200;ttyS1"...

    2024/4/28 2:05:13
  12. 微机原理与应用综合实验—中断控制8259

    微机原理与应用综合实验—中断控制8259——南京理工大学2019秋季学期电子信息工程专业《微机原理与应用综合实验》(1学分)1.实验内容与要求实验代码 编程软件:emu8086。 SSTACK SEGMENT STACK DW 32 DUP(?) SSTACK ENDSCODE SEGMENT ASSUME CS:CODEMAIN PROC FAR PUS…...

    2024/4/28 23:48:21
  13. Unity 开发——标签

    1、ExecuteInEditModeExecuteInEditMode属性的作用是在EditMode下也可以执行脚本。Unity中默认情况下,脚本只有在运行的时候才被执行,加上此属性后,不运行程序,也能执行脚本。与PlayMode不同的是,函数并不会不停的执行。Update : 只有当场景中的某个物体发生变化时,才调用…...

    2024/4/28 5:09:51
  14. node.js+express+mysql+axios 实现对数据的增删查改完美方案(附源码)

    node.js+express+mysql+axios 实现对数据的增删查改完美方案 准备工作 提示:安装好 mysql数据库,node.js 完成图1.创建数据库及创建数据表 //创建数据库 books create database books; //创建数据库表 定义id,书名,作者,描述 create table newbooks (id INT(255) AUTO_IN…...

    2024/4/28 6:28:34
  15. ETHEREUM 2.0对ETH的投资价值

    在过去的几周里,有关以太坊2.0升级的热情激增。 令人兴奋的是,升级有望在以太坊区块链上得到改善。在2019年3月的Token2049的以太坊亚洲超级会议上,区块链的神秘创始人Vitalik Buterin告诉群众升级: “ 这是一种将PoS和分片等技术改进组合在一起的方法,以改善虚拟机,协议…...

    2024/4/28 4:32:14
  16. 大一计算机新生看过来

    计算机系学生大一新手篇(也适用于大一迷茫的大二学生)**相信每个刚刚步入大学的人 都对自己的大学有一个美好的期盼**希望自己的大学 风生水起 有一个快乐的四年 以及一个美好的未来 谈一段甜甜的恋爱 有一群好兄弟 嘻嘻 我来是作为一个步入大二的学长 给刚步入大学的萌新(…...

    2024/4/27 22:20:18
  17. Java做一个让电脑循环按空格的小程序

    主页面类(包装成了一个exe程序) import javax.swing.*; import java.awt.*; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; /** * 脚本的主页面 * @author Serendipity */ public class Client extends JFrame implements ActionListener { priva…...

    2024/4/28 1:54:18
  18. SpringBoot中上传图片到当前目录下,不能立即显示

    转载https://blog.csdn.net/qq_46495709/article/details/106272258...

    2024/4/28 20:43:42
  19. idea springmvc 环境搭建maven模板

    1.使用maven模板: 1.新建project2.项目类型选择maven,勾选create from archetype 选择maven webapp(注意不要选错一定要选带有maven的weba,next ![在这里插入图片描述](https://img-blog.csdnimg.cn/20200526084648666.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5na…...

    2024/4/28 16:34:23
  20. ETH2.0赌注是什么?到底能不能赚钱?​

    以太坊2.0赌注是什么? 持有一定数量的ETH参与网络并获得回报。 抵押过程涉及将一定数量的给定加密货币锁定在钱包中以参与区块链的操作以换取奖励。从理论上讲,任何人都可以在任何进行权益证明共识的区块链上参与抵押。股权证明有多种变体,这也使人们可以参与股权。 在ETH核…...

    2024/4/24 7:27:15

最新文章

  1. openssl3.2 - exp - 使用默认的函数宏,在release版中也会引入__FILE__

    文章目录 openssl3.2 - exp - 使用默认的函数宏&#xff0c;在release版中也会引入__FILE__概述笔记验证是否__FILE__在release版下也能用&#xff1f;将openssl编译成release版的&#xff0c;看看CRYPTO_free()是否只需要一个参数就行&#xff1f;将工程中的openssl相关的库换…...

    2024/4/29 0:50:41
  2. 梯度消失和梯度爆炸的一些处理方法

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

    2024/3/20 10:50:27
  3. 职场口才提升之道

    职场口才提升之道 在职场中&#xff0c;口才的重要性不言而喻。无论是与同事沟通协作&#xff0c;还是向上级汇报工作&#xff0c;亦或是与客户洽谈业务&#xff0c;都需要具备良好的口才能力。一个出色的职场人&#xff0c;除了拥有扎实的专业技能外&#xff0c;还应具备出色…...

    2024/4/24 11:56:56
  4. npm常用命令技巧

    NPM (Node Package Manager) 是 JavaScript 的包管理工具&#xff0c;广泛用于管理项目中的依赖。无论是前端项目还是Node.js后端项目&#xff0c;NPM 都扮演着重要的角色。本文将介绍 NPM 中常用的几个命令&#xff0c;并提供相应的代码示例。 1. 初始化项目&#xff1a;npm …...

    2024/4/28 21:50:48
  5. 【外汇早评】美通胀数据走低,美元调整

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    2022/11/19 21:17:18
  26. 错误使用 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
  27. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...

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

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

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

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

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

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

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

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

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

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

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

    2022/11/19 21:17:10
  33. 电脑桌面一直是清理请关闭计算机,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
  34. 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    2022/11/19 21:16:58
  44. 如何在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