CN116743624A - 通信连接方法、装置、终端设备以及存储介质 - Google Patents

通信连接方法、装置、终端设备以及存储介质 Download PDF

Info

Publication number
CN116743624A
CN116743624A CN202310403949.5A CN202310403949A CN116743624A CN 116743624 A CN116743624 A CN 116743624A CN 202310403949 A CN202310403949 A CN 202310403949A CN 116743624 A CN116743624 A CN 116743624A
Authority
CN
China
Prior art keywords
client
server
communication connection
connection
reconnection
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Pending
Application number
CN202310403949.5A
Other languages
English (en)
Inventor
王彤彤
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
China Merchants Bank Co Ltd
Original Assignee
China Merchants Bank Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by China Merchants Bank Co Ltd filed Critical China Merchants Bank Co Ltd
Priority to CN202310403949.5A priority Critical patent/CN116743624A/zh
Publication of CN116743624A publication Critical patent/CN116743624A/zh
Pending legal-status Critical Current

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L43/00Arrangements for monitoring or testing data switching networks
    • H04L43/08Monitoring or testing based on specific metrics, e.g. QoS, energy consumption or environmental parameters
    • H04L43/0805Monitoring or testing based on specific metrics, e.g. QoS, energy consumption or environmental parameters by checking availability
    • H04L43/0811Monitoring or testing based on specific metrics, e.g. QoS, energy consumption or environmental parameters by checking availability by checking connectivity
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L43/00Arrangements for monitoring or testing data switching networks
    • H04L43/10Active monitoring, e.g. heartbeat, ping or trace-route
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/14Session management
    • H04L67/141Setup of application sessions
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L69/00Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
    • H04L69/16Implementation or adaptation of Internet protocol [IP], of transmission control protocol [TCP] or of user datagram protocol [UDP]
    • H04L69/161Implementation details of TCP/IP or UDP/IP stack architecture; Specification of modified or new header fields
    • H04L69/162Implementation details of TCP/IP or UDP/IP stack architecture; Specification of modified or new header fields involving adaptations of sockets based mechanisms

Abstract

本发明公开了一种通信连接方法、装置、终端设备以及存储介质,其方法包括:响应客户端触发的对服务端的访问请求;通过预设的兼容性检测模块检测所述客户端的环境中通信连接的可用性;根据所述兼容性检测模块的通信连接可用性检测结果,选择对应的连接方案与服务端进行连接;根据客户端传入的配置信息,开启心跳检测机制,以检测服务端与客户端之间的连接状况。本发明解决了服务不稳定、数据实时性不强的问题,提升了通信连接的稳定性、实时性。

Description

通信连接方法、装置、终端设备以及存储介质
技术领域
本发明涉及通信领域,尤其涉及一种通信连接方法、装置、终端设备以及存储介质。
背景技术
随着互联网和人工智能的迅猛发展,在客户端侧呈现的内容越来越丰富,从最早的文本信息,到现在的音、视频流。随之而来的是对客户端的设备要求和实时性需求的增强,从传统的Ajax技术正在逐步转变为实时的数据交互。传统的服务端、客户端数据交互形式,由于使用Ajax的形式,存在数据延迟、信息滞后的问题。在目前的互联网领域中,大部分平台已经在之前的Ajax的基础上做了一定的优化,比如使用轮询和Websocket的方式,但是仍然存在服务不稳定、数据实时性不强的问题。
上述内容仅用于辅助理解本发明的技术方案,并不代表承认上述内容是现有技术。
发明内容
本发明的主要目的在于提供一种通信连接方法、装置、终端设备以及存储介质,旨在解决服务不稳定、数据实时性不强的技术问题。
为实现上述目的,本发明提供一种通信连接方法,所述通信连接方法包括:
响应客户端触发的对服务端的访问请求;
通过预设的兼容性检测模块检测所述客户端的环境中通信连接的可用性;
根据所述兼容性检测模块的通信连接可用性检测结果,选择对应的连接方案与服务端进行连接;
根据客户端传入的配置信息,开启心跳检测机制,以检测服务端与客户端之间的连接状况。
可选的,所述通过预设的兼容性检测模块检测所述客户端的环境中通信连接的可用性的步骤包括:
通过预设的兼容性检测模块对客户端的传入地址进行转换并检测客户端的环境中通信连接的可用性,获得检测结果。
可选的,所述根据所述兼容性检测模块的通信连接可用性检测结果,选择对应的连接方案与服务端进行连接的步骤包括:
分析所述兼容性检测模块的检测结果,得到客户端的连接方式;
当客户端的连接方式表明客户端不支持Websocket时,使用Ajax通过轮询服务器的方式与服务端进行连接;
当客户端的连接方式表明客户端支持Websocket时,使用客户端传入的配置参数,对客户端进行初始化并与服务端进行连接。
可选的,所述根据客户端传入的配置信息,开启心跳检测机制,以检测服务端与客户端之间的连接状况的步骤包括:
当检测到客户端与服务端Websocket连接建立成功时,开启心跳检测机制;
根据客户端的配置项,在预设的第一配置时间后,向服务端发送心跳报文;
通过定时器开启定时,检测在第二配置时间内接收到的服务端的心跳响应报文;
若所述心跳响应报文为约定好的服务端报文,则在下次心跳检测周期再次向服务端发送心跳报文;
若接收到的心跳响应报文不是约定好的服务端报文,则根据预设的时间进行等待,若等待时间内未接收到约定好的服务端报文,则断开连接;
可选的,所述方法还包括:
当检测到客户端与服务端出现断开连接情况时,启动断开重连机制。
可选的,所述当检测到客户端与服务端出现断开连接情况时,启动断开重连机制的步骤包括:
通过客户端的配置项开启定时器,设定重连次数;
在所述定时器预设的时间后进行客户端与服务端的Websocket重新连接;
当重连失败且重连次数未达到客户端中配置项的重连次数时,延长下次重连的间隔时间后进行重连;
当重连次数达到客户端中配置项的重连次数且重连失败时,停止重连;
显示重连结果为重连成功或重连失败。
可选的,所述当客户端的连接方式表明客户端支持Websocket时,使用客户端传入的配置参数,对客户端进行初始化并与服务端进行连接的步骤之后还包括:
通过客户端预设的通信软件打开与服务端的交互式通信会话;
通过所述交互式通信会话,向服务端发送信息并接收服务端反馈的事件驱动的响应。
本发明实施例还提出一种通信连接装置,所述通信连接装置包括:
响应模块,用于响应客户端触发的对服务端的访问请求;
兼容性检测模块,用于检测客户端环境中通信连接的可用性;
连接模块,用于根据所述兼容性检测模块的通信连接可用性检测结果,选择对应的连接方案与服务端进行连接;
心跳检测模块,用于根据客户端传入的配置信息,开启心跳检测机制,以检测服务端与客户端之间的连接状况。
本发明实施例还提出了一种终端设备所述终端设备包括存储器、处理器及存储在所述存储器上并可在所述处理器上运行的通信连接程序,所述通信连接程序被所述处理器执行时实现如上所述的通信连接方法的步骤。
本发明实施例还提出一种计算机可读存储介质,所述计算机可读存储介质上存储通信连接程序,所述通信连接程序被处理器执行时实现如上所述的通信连接方法的步骤。
本发明实施例提出的一种通信连接方法、装置、终端设备以及存储介质,响应客户端触发的对服务端的访问请求;通过预设的兼容性检测模块检测所述客户端的环境中通信连接的可用性;根据所述兼容性检测模块的通信连接可用性检测结果,选择对应的连接方案与服务端进行连接;根据客户端传入的配置信息,开启心跳检测机制,以检测服务端与客户端之间的连接状况。实现了通信连接时服务稳定,数据实时性强的效果。
附图说明
图1为本发明通信连接装置所属终端设备的功能模块示意图;
图2为本发明通信连接方法一示例性实施例的流程示意图;
图3为本发明通信连接方法另一示例性实施例的流程示意图;
图4为本发明实施例中通信连接方法一整体流程示意图;
图5为本发明实施例中通信连接方法另一整体流程示意图;
图6为本发明通信连接方法涉及实时通信连接实施例的流程示意图;
图7为本发明通信连接方法涉及心跳检测实施例的流程示意图;
图8为本发明通信连接方法涉及断开重连实施例的流程示意图。
本发明目的的实现、功能特点及优点将结合实施例,参照附图做进一步说明。
具体实施方式
应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。
本发明实施例的主要解决方案是:通过预设的兼容性检测模块对客户端的传入地址进行转换并检测客户端的环境中通信连接的可用性,获得检测结果。分析所述兼容性检测模块的检测结果,得到客户端的连接方式;当客户端的连接方式表明客户端不支持Websocket时,使用Ajax通过轮询服务器的方式与服务端进行连接;当客户端的连接方式表明客户端支持Websocket时,使用客户端传入的配置参数,对客户端进行初始化并与服务端进行连接。当检测到客户端与服务端Websocket连接建立成功时,开启心跳检测机制;根据客户端的配置项,在预设的第一配置的时间后,向服务端发送心跳报文;通过定时器开启定时,检测在第二配置时间内接收到的服务端的心跳响应报文;若所述心跳响应报文为约定好的服务端报文,则在下次心跳检测周期再次向服务端发送心跳报文;若接收到的心跳响应报文不是约定好的服务端报文,则根据预设的时间进行等待,若等待时间内未接收到约定好的服务端报文,则断开连接;当检测到客户端与服务端出现断开连接情况时,启动断开重连机制。通过客户端的配置项开启定时器,设定重连次数:在所述定时器预设的时间后进行客户端与服务端的Websocket重新连接;当重连失败且重连次数未达到客户端中配置项的重连次数时,延长下次重连的间隔时间后进行重连;当重连次数达到客户端中配置项的重连次数且重连失败时,停止重连;显示重连结果为重连成功或重连失败。通过客户端预设的通信软件打开与服务端的交互式通信会话;通过所述交互式通信会话,向服务端发送信息并接收服务端反馈的事件驱动的响应。解决服务不稳定、数据实时性不强的问题。基于本发明方案,从真实世界中传统Websocket技术中存在兼容性差、连接不稳定、服务断连、资源占用率高的问题出发,结合兼容性模块、心跳检测机制以及断开重连机制,设计了一种通信连接方法,并在实时通信连接上验证了本发明中的通信连接方法的有效性,最后经过本发明方法进行通信连接的效率得到了明显提升。
本发明实施例涉及的技术术语:
Websocket:WebSocket协议是基于TCP的一种新的网络协议。实现了浏览器和服务器的全双工(full-duplex)通信。允许服务器主动发送信息给客户端。WebSocket使得客户端和服务器之间的数据交换变得更加简单,允许服务端主动向客户端推送数据。在WebSocket API中,浏览器和服务器只需要完成一次握手,两者之间就直接可以创建持久性的连接,并进行双向数据传输。
Ajax:全称是Asynchronous JavaScript and XML,意思就是异步的JavaScript和XML,用于快速创建动态的网页技术,该技术实现了服务器和客户端少量数据交换条件下实现网页的动态更新,意味着无需重新加载整个网页。
轮询:轮询是一种中央处理器CPU决策如何提供周边设备服务的方式,又称“程控输入输出”(Programmed I/O),是由中央处理器CPU定时发出询问,依序询问每一个周边设备是否需要其服务,有即给予服务,服务结束后再问下一个周边,接着不断周而复始。
配置项:配置项是指软件、系统或设备中可以进行设置和调整的特定参数或选项。它们通常用于定制软件、系统或设备的行为和功能,以满足用户的需求和偏好。一些常见的配置项包括语言设置、主题设置、安全设置、网络设置、显示设置等等。在许多软件和系统中,配置项可以通过图形用户界面(GUI)或命令行界面(CLI)来进行设置。
降级:指的是一开始就制定完美的功能计划,然后先在主流的浏览器中测试实现功能,最后在老一点版本,不常用的版本中测试实现,如果不能完全达到我们的要求,这时我们的原则是尽量去实现,如果还是没办法,那就适当减少功能。
本发明实施例考虑到,使用轮询和Websocket的方式仍然存在服务不稳定、数据实时性不强的问题。
因此,本发明实施例方案,从真实世界中传统Websocket技术中存在兼容性差、连接不稳定、服务断连、资源占用率高的问题出发,结合兼容性模块、心跳检测机制以及断开重连机制,设计了一种通信连接方法,并在实时通信连接上验证了本发明中的通信连接方法的有效性,最后经过本发明方法进行通信连接的效率得到了明显提升。
具体地,参照图1,图1为本发明通信连接装置所属终端设备的功能模块示意图。该通信连接装置可以为独立于终端设备的、能够进行兼容性检测、心跳检测、断开重连的装置,其可以通过硬件或软件的形式承载于终端设备上。该终端设备可以为手机、平板电脑等具有数据处理功能的智能移动设备,还可以为具有数据处理功能的固定终端设备或服务器等。
在本实施例中,该开品装置所属终端设备至少包括输出模块110、处理器120、存储器130以及通信模块140。
存储器130中存储有操作系统以及通信连接程序,通信连接装置可以将接收客户端的连接请求;通过预设的兼容性检测模块检测客户端环境中Websocket技术的可用性;根据兼容性检测模块的结果,选择对应的方案进行连接;建立连接后,根据用户传入的配置,同时开启心跳检测机制;当连接出现异常断开的情况时触发断开重连机制。通过该通信连接装置进行连接,得到通信连接结果等信息存储于该存储器130中;输出模块110可为显示屏等。通信模块140可以包括WIFI模块、移动通信模块以及蓝牙模块等,通过通信模块140与外部设备或服务器进行通信。
其中存储器130中的通信连接程序被处理器执行时实现以下步骤:
响应客户端触发的对服务端的访问请求;
通过预设的兼容性检测模块检测所述客户端的环境中通信连接的可用性;
根据所述兼容性检测模块的通信连接可用性检测结果,选择对应的连接方案与服务端进行连接;
根据客户端传入的配置信息,开启心跳检测机制,以检测服务端与客户端之间的连接状况。
进一步地,存储器130中的通信连接程序被处理器执行时还实现以下步骤:
通过预设的兼容性检测模块对客户端的传入地址进行转换并检测客户端的环境中通信连接的可用性,获得检测结果。
进一步地,存储器130中的通信连接程序被处理器执行时还实现以下步骤:
分析所述兼容性检测模块的检测结果,得到客户端的连接方式;
当客户端的连接方式表明客户端不支持Websocket时,使用Ajax通过轮询服务器的方式与服务端进行连接;
当客户端的连接方式表明客户端支持Websocket时,使用客户端传入的配置参数,对客户端进行初始化并与服务端进行连接。
进一步地,存储器130中的通信连接程序被处理器执行时还实现以下步骤:
当检测到客户端与服务端Websocket连接建立成功时,开启心跳检测机制;
根据客户端的配置项,在预设的第一配置的时间后,向服务端发送心跳报文;
通过定时器开启定时,检测在第二配置时间内接收到的服务端的心跳响应报文;
若所述心跳响应报文为约定好的服务端报文,则在下次心跳检测周期再次向服务端发送心跳报文;
若接收到的心跳响应报文不是约定好的服务端报文,则根据预设的时间进行等待,若等待时间内未接收到约定好的服务端报文,则断开连接;
进一步地,存储器130中的通信连接程序被处理器执行时还实现以下步骤:
当检测到客户端与服务端出现断开连接情况时,启动断开重连机制。
进一步地,存储器130中的通信连接程序被处理器执行时还实现以下步骤:
通过客户端的配置项开启定时器,设定重连次数;
在所述定时器预设的时间后进行客户端与服务端的Websocket重新连接;
当重连失败且重连次数未达到客户端中配置项的重连次数时,延长下次重连的间隔时间后进行重连;
当重连次数达到客户端中配置项的重连次数且重连失败时,停止重连;
显示重连结果为重连成功或重连失败。
进一步地,存储器130中的通信连接程序被处理器执行时还实现以下步骤:
通过客户端预设的通信软件打开与服务端的交互式通信会话;
通过所述交互式通信会话,向服务端发送信息并接收服务端反馈的事件驱动的响应。
本实施例通过上述方案,具体通过响应客户端触发的对服务端的访问请求;通过预设的兼容性检测模块检测所述客户端的环境中通信连接的可用性;根据所述兼容性检测模块的通信连接可用性检测结果,选择对应的连接方案与服务端进行连接;根据客户端传入的配置信息,开启心跳检测机制,以检测服务端与客户端之间的连接状况。基于兼容性检测模块、心跳检测以及断开重连机制进行通信连接,可以解决服务不稳定、数据实时性不强的问题,提高用户体验。基于本发明方案,从真实世界中传统Websocket技术中存在兼容性差、连接不稳定、服务断连、资源占用率高的问题出发,结合兼容性模块、心跳检测机制以及断开重连机制,设计了一种通信连接方法,并在实时通信连接上验证了本发明中的通信连接方法的有效性,最后经过本发明方法进行通信连接的效率得到了明显提升。
基于上述终端设备架构但不限于上述架构,提出本发明方法实施例。
参照图2,图2为本发明通信连接方法一示例性实施例的流程示意图。所述通信连接方法包括:
步骤S01:响应客户端触发的对服务端的访问请求;
本实施例方法的执行主体可以是一种通信装置,也可以是一种通信连接终端设备或服务器,本实施例以通信装置进行举例,该通信连接装置可以集成在具有数据处理功能终端设备上。
本实施例方案主要实现对通信尤其是交互式通信的实时连接,提升通信连接的稳定性,提高连接的完整性,减少异常情况的发生,减少资源占用率。
首先,当用户需要客户端访问服务端的时候,使用客户端的通信软件对服务端发起访问请求。
步骤S02:通过预设的兼容性检测模块检测所述客户端的环境中通信连接的可用性;
当用户通过客户端对服务端发起访问请求时,使用客户端中的兼容性检测模块,对连接进行预处理,检测客户端环境中的通信连接可用性。其次,对客户端传入的地址进行转换。
通过预设的兼容性检测模块对客户端的传入地址进行转换并检测客户端的环境中通信连接的可用性,获得检测结果。
步骤S03:根据所述兼容性检测模块的通信连接可用性检测结果,选择对应的连接方案与服务端进行连接;
根据兼容检测模块检测的结果,选择对应的连接方式,来对客户端与服务端进行连接,其中,连接方式具体可以是,Websocket、Ajax、轮询、长轮询等,本实施例用Websocket以及Ajax轮询的方式来说明。
分析所述兼容性检测模块的检测结果,得到当前客户端的连接方式,选择对应客户端的连接方式进行连接;当客户端的连接方式表明客户端不支持Websocket时,使用Ajax通过轮询服务器的方式与服务端进行连接;
进一步的,当客户端的连接方式表明客户端支持Websocket时,使用客户端传入的配置参数,对客户端进行初始化并与服务端进行连接。通过客户端中的通信软件,与服务端进行实时数据交互通信。
其中,客户端中的通信软件,可以是浏览器、会话软件也可以是其他用于交互的软件。
步骤S04:根据客户端传入的配置信息,开启心跳检测机制,以检测服务端与客户端之间的连接状况。
当客户端与服务端通过Websocket连接成功后,根据用户预先在客户端设置的配置项,打开心跳检测机制,通过客户端发送心跳报文至服务端,并接受服务端的心跳响应报文,判断当前客户端与服务端的连接情况。
根据客户端的配置项,在预设的第一配置的时间后,向服务端发送心跳报文;通过定时器开启定时,检测在第二配置时间内接收到的服务端的心跳响应报文;若所述心跳响应报文为约定好的服务端报文,则在下次心跳检测周期再次向服务端发送心跳报文;若接收到的心跳响应报文不是约定好的服务端报文,则根据预设的时间进行等待,若等待时间内未接收到约定好的服务端报文,则断开连接。
本实施例通过上述方案,具体通过响应客户端触发的对服务端的访问请求;通过预设的兼容性检测模块检测所述客户端的环境中通信连接的可用性;根据所述兼容性检测模块的通信连接可用性检测结果,选择对应的连接方案与服务端进行连接;根据客户端传入的配置信息,开启心跳检测机制,以检测服务端与客户端之间的连接状况。基于兼容性模块、心跳检测机制以及断开重连机制进行通信连接,可以解决兼容性差、连接不稳定、资源占用率高的问题,提升通信连接效率。
参照图3,图3为本发明通信连接方法另一示例性实施例的流程示意图。
基于上述图2所示的实施例,在本实施例中,本发明通信连接方法中还可以包括:
步骤S05:当检测到客户端与服务端出现断开连接情况时,启动断开重连机制。
在客户端与服务端通过Websocket连接建立后,当检测到当前客户端与服务端连接出现异常断开的情况时,启动断开重连机制,尝试重新通过Websocket进行客户端与服务端的连接。
具体的,通过客户端的配置项开启定时器,设定重连次数;在所述定时器预设的时间后进行客户端与服务端的Websocket重新连接;当重连失败且重连次数未达到客户端中配置项的重连次数时,延长下次重连的间隔时间后进行重连;当重连次数达到客户端中配置项的重连次数且重连失败时,停止重连;显示重连结果为重连成功或重连失败。
本实施例整体流程如图4所示,通过兼容性模块检测客户端连接方案,支持Websocket的客户端,初始化其配置项并建立与服务端的连接,通过客户端的通信软件与服务端进行数据交互通信,当连接出现异常时,启动断开重连机制尝试重新进行通信连接,当连接失败时,客户端则断开连接。
本实施例通过上述方案,具体通过当检测到客户端与服务端出现断开连接情况时,启动断开重连机制。基于断开重连机制进行通信连接,可以解决通信连接时,服务断连的问题,提高了通信连接的实时性。
本实施例采用兼容性模块、心跳检测机制以及断开重连机制进行通信连接,该通信连接方法的通信流程如图5所示:
首先,用户操作客户端触发对服务端的连接请求。
然后,兼容性检测对当前客户端的环境进行检测,检测当前客户端支持的通信连接方法,并对客户端传入的地址进行转换。
然后,根据兼容性检测模块的检测结果,选择对应的连接方式,当客户端不支持Websocket技术连接时,使用Ajax技术通过轮询服务器的方式进行连接;当客户端支持Websocket技术连接时,使用客户端传入的配置参数进行初始化并与服务端进行连接。
然后,在初始化连接建立的同时,启动心跳检测,通过发送心跳数据的方式,判断当前连接活跃度。
最后,在连接出现异常时,启动断开重连机制,重新创建连接。
参照图6,图6为本发明通信连接方法涉及实时通信连接实施例的流程示意图。
基于上述图2所示的实施例,所述步骤S03:根据所述兼容性检测模块的通信连接可用性检测结果,选择对应的连接方案与服务端进行连接的步骤包括:
步骤S031:分析所述兼容性检测模块的检测结果,得到客户端的连接方式;
步骤S032:当客户端的连接方式表明客户端不支持Websocket时,使用Ajax通过轮询服务器的方式与服务端进行连接;
步骤S033:当客户端的连接方式表明客户端支持Websocket时,使用客户端传入的配置参数,对客户端进行初始化并与服务端进行连接;
步骤S034:通过客户端预设的通信软件打开与服务端的交互式通信会话;
步骤S035:通过所述交互式通信会话,向服务端发送信息并接收服务端反馈的事件驱动的响应。
具体的,分析兼容性检测模块得出的检测结果,得到客户端对应的连接方式,当客户端的连接方式表明客户端不支持Websocket时,使用Ajax通过轮询服务器的方式进行降级处理,随后客户端按规定时间,定时向服务端发送Ajax请求,获取实时通信连接。当客户端的连接方式表明客户端支持Wecsocket时,使用客户端传入的配置参数进行初始化,并建立与服务端的连接。
进一步的,连接建立成功后,通过客户端预设的通信软件打开与服务端的交互通信会话,通过交互通信会话,客户端与服务端能实时通信,且及时接收服务端反馈的事件驱动的响应。
本实施例通过上述方案,具体通过分析所述兼容性检测模块的检测结果,得到客户端的连接方式;当客户端的连接方式表明客户端不支持Websocket时,使用Ajax通过轮询服务器的方式与服务端进行连接;当客户端的连接方式表明客户端支持Websocket时,使用客户端传入的配置参数,对客户端进行初始化并与服务端进行连接;通过客户端预设的通信软件打开与服务端的交互式通信会话;通过所述交互式通信会话,向服务端发送信息并接收服务端反馈的事件驱动的响应。基于兼容性检测模块进行通信连接,可以根据客户端的环境中对通信连接的支持,选择适合的连接方式。提高通信连接的稳定性、实时性,使连接更稳定。
参照图7,图7为本发明通信连接方法涉及心跳检测实施例的流程示意图。
基于上述图2所示的实施例,所述步骤S04:根据客户端传入的配置信息,开启心跳检测机制,以检测服务端与客户端之间的连接状况的步骤包括:
步骤S041:当检测到客户端与服务端Websocket连接建立成功时,开启心跳检测机制;
步骤S042:根据客户端的配置项,在预设的第一配置的时间后,向服务端发送心跳报文;
步骤S043:通过定时器开启定时,检测在第二配置时间内接收到的服务端的心跳响应报文;
步骤S044:若所述心跳响应报文为约定好的服务端报文,则在下次心跳检测周期再次向服务端发送心跳报文;
步骤S045:若接收到的心跳响应报文不是约定好的服务端报文,则根据预设的时间进行等待,若等待时间内未接收到约定好的服务端报文,则断开连接;
具体的,当客户端与服务端通过Websocket连接成功后,根据用户预先在客户端设置的配置项,开启定时器,首先先配置第一个时间,在第一配置时间后,向服务端发送心态报文,随后通过定时器配置第二个时间用来检测在第二配置时间内是否有接收到与服务端约定的心跳响应报文,根据接受到的报文,对当前的连接情况进行判断。当接收到的心跳响应报文是约定好的心跳响应报文,则判定为当前连接状况正常,则在下次心跳检测周期再次向服务端发送心跳报文。当接收到的心跳响应报文不是约定好的服务端报文,则进行一定时间的等待,当等待时间内仍未接收到约定好的服务端报文,则判定当前服务端已断开连接,此时客户端断开连接,避免资源的耗费。
本实施例通过上述方案,具体通过当检测到客户端与服务端Websocket连接建立成功时,开启心跳检测机制;根据客户端的配置项,在预设的第一配置的时间后,向服务端发送心跳报文;通过定时器开启定时,检测在第二配置时间内接收到的服务端的心跳响应报文;若所述心跳响应报文为约定好的服务端报文,则在下次心跳检测周期再次向服务端发送心跳报文;若接收到的心跳响应报文不是约定好的服务端报文,则根据预设的时间进行等待,若等待时间内未接收到约定好的服务端报文,则断开连接;当检测到客户端与服务端出现断开连接情况时,启动断开重连机制。基于心跳检测机制进行通信连接,可以不断的确认当前客户端与服务端的连接状态,根据心跳检测机制,提高通信连接的实时性,避免了断开连接时资源的占用。
参照图8,图8为本发明通信连接方法涉及断开重连实施例的流程示意图。
基于上述图3所示的实施例,所述步骤S05:当检测到客户端与服务端出现断开连接情况时,启动断开重连机制的步骤包括:
步骤S051:通过客户端的配置项开启定时器,设定重连次数;
步骤S052:在所述定时器预设的时间后进行客户端与服务端的Websocket重新连接;
步骤S053:当重连失败且重连次数未达到客户端中配置项的重连次数时,延长下次重连的间隔时间后进行重连;
步骤S054:当重连次数达到客户端中配置项的重连次数且重连失败时,停止重连;
步骤S055:显示重连结果为重连成功或重连失败。
具体的,当检测到当前客户端与服务端连接出现异常断开的情况时,启动断开重连机制,尝试重新通过Websocket进行客户端与服务端的连接。首先,根据用户预先设置的配置项,开启定时器,并设定重连次数,在定时器设置的时间过后进行客户端与服务端的Websocket重新连接,当重连失败且重连次数未达到客户端中配置项的重连次数时,延长下次重连的间隔时间,并在延长的间隔时间过后,再次进行重连。当重连次数达到客户端中配置的重连次数,且重连失败时,停止重连。最后根据重连的实际情况,显示重连的结果为重连成功或重连失败。
本实施例通过上述方案,具体通过,通过客户端的配置项开启定时器,设定重连次数;在所述定时器预设的时间后进行客户端与服务端的Websocket重新连接;当重连失败且重连次数未达到客户端中配置项的重连次数时,延长下次重连的间隔时间后进行重连;当重连次数达到客户端中配置项的重连次数且重连失败时,停止重连;显示重连结果为重连成功或重连失败。基于断开重连机制进行通信连接,可以解决服务断连的问题,使客户端与服务端的连接更加稳定,减少了异常情况的发生,提高了通信连接的完整性。
此外,本发明实施例还提出一种通信连接装置,所述通信连接装置包括:
响应模块,用于响应客户端触发的对服务端的访问请求;
兼容性检测模块,用于检测客户端环境中通信连接的可用性;
连接模块,用于根据所述兼容性检测模块的通信连接可用性检测结果,选择对应的连接方案与服务端进行连接;
心跳检测模块,用于根据客户端传入的配置信息,开启心跳检测机制,以检测服务端与客户端之间的连接状况.
本实施例实现通信连接的原理及实施过程,请参照上述各实施例,在此不再赘述。
此外,本发明实施例还提出一种终端设备,所述终端设备包括存储器、处理器及存储在所述存储器上并可在所述处理器上运行的通信连接程序,所述通信连接程序被所述处理器执行时实现如上所述的通信连接方法的步骤。
由于本通信连接程序被处理器执行时,采用了前述所有实施例的全部技术方案,因此至少具有前述所有实施例的全部技术方案所带来的所有有益效果,在此不再一一赘述。
此外,本发明实施例还提出一种计算机可读存储介质,所述计算机可读存储介质上存储有通信连接程序,所述通信连接程序被处理器执行时实现如上所述的通信连接方法的步骤。
由于本通信连接程序被处理器执行时,采用了前述所有实施例的全部技术方案,因此至少具有前述所有实施例的全部技术方案所带来的所有有益效果,在此不再一一赘述。
相比现有技术,本发明实施例提出的通信连接方法、装置、终端设备以及存储介质,通过响应客户端触发的对服务端的访问请求;通过预设的兼容性检测模块检测所述客户端的环境中通信连接的可用性;根据所述兼容性检测模块的通信连接可用性检测结果,选择对应的连接方案与服务端进行连接;根据客户端传入的配置信息,开启心跳检测机制,以检测服务端与客户端之间的连接状况。可以提高连接兼容性、稳定性,避免了服务断连、资源占用率的问题,使通信连接的效率得到了明显提升。基于本发明方案,从传统通信连接服务不稳定、数据实时性不强的问题出发,构建了一种通信连接方法、装置、终端设备以及存储介质,并在实际通信连接上验证了本发明提出的通信连接方法的有效性,最后经过本发明方法的通信连接方法,实现了提高通信连接的效率,解决了服务不稳定、数据实时性不强的问题。
需要说明的是,在本文中,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者系统不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者系统所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括该要素的过程、方法、物品或者系统中还存在另外的相同要素。
上述本发明实施例序号仅仅为了描述,不代表实施例的优劣。
通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到上述实施例方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在如上的一个存储介质(如ROM/RAM、磁碟、光盘)中,包括若干指令用以使得一台终端设备(可以是手机,计算机,服务器,被控终端,或者网络设备等)执行本发明每个实施例的方法。
以上仅为本发明的优选实施例,并非因此限制本发明的专利范围,凡是利用本发明说明书及附图内容所作的等效结构或等效流程变换,或直接或间接运用在其他相关的技术领域,均同理包括在本发明的专利保护范围内。

Claims (10)

1.一种通信连接方法,其特征在于,所述方法应用于客户端,所述通信连接方法包括以下步骤:
响应客户端触发的对服务端的访问请求;
通过预设的兼容性检测模块检测所述客户端的环境中通信连接的可用性;
根据所述兼容性检测模块的通信连接可用性检测结果,选择对应的连接方案与服务端进行连接;
根据客户端传入的配置信息,开启心跳检测机制,以检测服务端与客户端之间的连接状况。
2.根据权利要求1所述的通信连接方法,其特征在于,所述通过预设的兼容性检测模块检测所述客户端的环境中通信连接的可用性的步骤包括:
通过预设的兼容性检测模块对客户端的传入地址进行转换并检测客户端的环境中通信连接的可用性,获得检测结果。
3.根据权利要求1所述的通信连接方法,其特征在于,所述根据所述兼容性检测模块的通信连接可用性检测结果,选择对应的连接方案与服务端进行连接的步骤包括:
分析所述兼容性检测模块的检测结果,得到客户端的连接方式;
当客户端的连接方式表明客户端不支持Websocket时,使用Ajax通过轮询服务器的方式与服务端进行连接;
当客户端的连接方式表明客户端支持Websocket时,使用客户端传入的配置参数,对客户端进行初始化并与服务端进行连接。
4.根据权利要求1所述的通信连接方法,其特征在于,所述根据客户端传入的配置信息,开启心跳检测机制,以检测服务端与客户端之间的连接状况的步骤包括:
当检测到客户端与服务端Websocket连接建立成功时,开启心跳检测机制;
根据客户端的配置项,在预设的第一配置时间后,向服务端发送心跳报文;
通过定时器开启定时,检测在第二配置时间内接收到的服务端的心跳响应报文;
若所述心跳响应报文为约定好的服务端报文,则在下次心跳检测周期再次向服务端发送心跳报文;
若接收到的心跳响应报文不是约定好的服务端报文,则根据预设的时间进行等待,若等待时间内未接收到约定好的服务端报文,则断开连接。
5.根据权利要求1-4中任一项所述的通信连接方法,其特征在于,所述方法还包括:
当检测到客户端与服务端出现断开连接情况时,启动断开重连机制。
6.根据权利要求5所述的通信连接方法,其特征在于,所述当检测到客户端与服务端出现断开连接情况时,启动断开重连机制的步骤包括:
通过客户端的配置项开启定时器,设定重连次数;
在所述定时器预设的时间后进行客户端与服务端的Websocket重新连接;
当重连失败且重连次数未达到客户端中配置项的重连次数时,延长下次重连的间隔时间后进行重连;
当重连次数达到客户端中配置项的重连次数且重连失败时,停止重连;
显示重连结果为重连成功或重连失败。
7.根据权利要求3所述的通信连接方法,其特征在于,所述当客户端的连接方式表明客户端支持Websocket时,使用客户端传入的配置参数,对客户端进行初始化并与服务端进行连接的步骤之后还包括:
通过客户端预设的通信软件打开与服务端的交互式通信会话;
通过所述交互式通信会话,向服务端发送信息并接收服务端反馈的事件驱动的响应。
8.一种通信连接装置,其特征在于,所述通信连接装置包括:
响应模块,用于响应客户端触发的对服务端的访问请求;
兼容性检测模块,用于检测客户端环境中通信连接的可用性;
连接模块,用于根据所述兼容性检测模块的通信连接可用性检测结果,选择对应的连接方案与服务端进行连接;
心跳检测模块,用于根据客户端传入的配置信息,开启心跳检测机制,以检测服务端与客户端之间的连接状况。
9.一种终端设备,其特征在于,所述终端设备包括存储器、处理器及存储在所述存储器上并可在所述处理器上运行的通信连接程序,所述通信连接程序被所述处理器执行时实现如权利要求1-7中任一项所述的通信连接方法的步骤。
10.一种计算器可读存储介质,其特征在于,所述计算机可读存储介质上存储有通信连接程序,所述通信连接程序被处理器执行时实现如权利要求1-7中任一项所述的通信连接方法的步骤。
CN202310403949.5A 2023-04-06 2023-04-06 通信连接方法、装置、终端设备以及存储介质 Pending CN116743624A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202310403949.5A CN116743624A (zh) 2023-04-06 2023-04-06 通信连接方法、装置、终端设备以及存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202310403949.5A CN116743624A (zh) 2023-04-06 2023-04-06 通信连接方法、装置、终端设备以及存储介质

Publications (1)

Publication Number Publication Date
CN116743624A true CN116743624A (zh) 2023-09-12

Family

ID=87901853

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202310403949.5A Pending CN116743624A (zh) 2023-04-06 2023-04-06 通信连接方法、装置、终端设备以及存储介质

Country Status (1)

Country Link
CN (1) CN116743624A (zh)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN117527638A (zh) * 2024-01-05 2024-02-06 未势能源科技有限公司 通讯检测方法、装置、电子设备及存储介质

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN117527638A (zh) * 2024-01-05 2024-02-06 未势能源科技有限公司 通讯检测方法、装置、电子设备及存储介质

Similar Documents

Publication Publication Date Title
EP3487148A1 (en) Video conference implementation method, apparatus and system, and cloud desktop terminal
US20090077184A1 (en) Remote Control of Mobile Terminal via Remote Control Proxy and SMS
US20080307064A1 (en) System and method for obtainingn remote instant messages
JP2007525087A (ja) アクティブ受信及びアクティブ警告でのコンテクスト依存の転送
JP2007508617A (ja) 持続的なアプリケーションセッションにアクセスを提供する方法および装置
JP2000163360A (ja) ネットワ―クの少なくとも1つの周辺装置をサポ―トする方法
CN101599982A (zh) 手机信息浏览装置、系统及实现方法
CN116743624A (zh) 通信连接方法、装置、终端设备以及存储介质
JP3955268B2 (ja) 統合ウェブブラウジングサービス装置及びそのサービス方法
JP5023082B2 (ja) ウェブブラウザに対する非同期メッセージのプッシュ
CN107248978A (zh) 一种消息监听处理方法及系统
CN112199597A (zh) 一种呼叫中心平台通信适配层及方法
CN112291238A (zh) 一种数据通讯方法、装置、设备以及计算机可读存储介质
CN107454184B (zh) Android客户端与服务器建立稳定网络连接的方法
US20040230684A1 (en) Context sensitive transfer
CN112380028A (zh) 一种异步非阻塞响应式消息处理方法
US8417767B2 (en) Call control method, device, and system
EP1816831A1 (en) Computing device supporting bridging between a packet switched network and the public switched telephone network
CN112839106A (zh) 通信方法及装置、电子设备及介质
CN110445834A (zh) 一种解决推送数据丢失的方法及系统
EP1368933B1 (en) Packet switched network voice communication
US20070183397A1 (en) Computing device supporting selective local call termination and call bridging
CN115866535A (zh) 一种多协议实现5g消息接入的方法及系统
CN106375447A (zh) 基于消息中间件的服务切换方法及装置
US20060031343A1 (en) Integrated instant message system with gateway functions and method for implementing the same

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination