php开发在线客服系统_app内在线客服

php开发在线客服系统_app内在线客服  在本节中,我们将简要讨论通过PHP在线客服系统源码传输数据的数据传输方法。我们可以发送普通消息或基于时间表的消息。我们将逐一介绍这两种基本类型的消息传递。  完整源码:zxkfym.top  Azure服务总线:MicrosoftAzure服务总线是一种完全托管的云上企业集成消息传递服务,用于将云中运行的任何应用程序、设备和服务连接到任何其他应用程序或服务。该平台充当云上和任何设备上的应用程序的消息传递骨干。  它是如何工作的?使用消息在不同的应用程序和服务之间传输数据。消息为二进制格

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

  在本节中,我们将简要讨论通过PHP在线客服系统源码传输数据的数据传输方法。我们可以发送普通消息或基于时间表的消息。我们将逐一介绍这两种基本类型的消息传递。
  完整源码:zxkfym.top
  Azure 服务总线: Microsoft Azure 服务总线是一种完全托管的云上企业集成消息传递服务,用于将云中运行的任何应用程序、设备和服务连接到任何其他应用程序或服务。该平台充当云上和任何设备上的应用程序的消息传递骨干。

php开发在线客服系统_app内在线客服

 
  它是如何工作的 ?使用消息在不同的应用程序和服务之间传输数据。消息为二进制格式,可以包含 JSON、XML 或仅包含文本。这些消息被放置到应用程序所连接的服务总线上,以便所有或特定用户连接到这个应用程序上,通过套接字服务连接打开可以接收通过服务总线传输的数据。
  消息类型:通过 Azure 服务总线传输的数据消息可以分为两种主要类型,即数据需要按特定计划发送还是需要立即发送。在这里,我们将详细讨论这两个消息传递过程。其中每一个都有自己特定的方法来调用消息传递过程。
  ●立即发送消息: send() 函数调用将消息发送到当前发送方连接到的 Azure 服务总线。此方法进行非异步调用。您还有一个异步版本来提高性能。

  send( IMessage message )

示例代码:

  public static async sendMessage(content: Message): Promise<string> {
  const serviceConnection = AzureServiceBus.createConnection();
  const client = serviceConnection.createQueueClient(""
  + process.env.AZURE_SERVICEBUS_QUEUE);
  const sender = client.createSender();
  let response = "";
  try {
  const scheduledEnqueueTimeUtc
  = moment().utc().add(1, "m").toDate();
  await sender.send( {body: JSON.stringify(content),
  label: "MyTopic"});
  await client.close();
  } catch (error) {
  } finally {
  await serviceConnection.close();
  }
  return resp;
  }

  ●计划消息:此方法将基于计时器的消息发送到调用发件人所连接的 Azure 服务总线。它将消息排入总线以预定时间消息,将消息传递到接收端。这是当前的异步过程,以获得更好的性能。

php开发在线客服系统_app内在线客服

  原型:


  scheduleMessage( IMessage message, Instant scheduledEnqueueTimeUtc )

示例代码:

  public static async sendScheduleMessage(
  content: Message): Promise<string> {
  const serviceConnection =
  AzureServiceBus.createConnection();
  const client = serviceConnection.createQueueClient(
  "" + process.env.AZURE_SERVICEBUS_QUEUE);
  const sender = client.createSender();
  let response = "";
  try {
  const scheduledEnqueueTimeUtc
  = moment().utc().add(1, "m").toDate();
  const sequenceId = await sender.scheduleMessage(
  scheduledEnqueueTimeUtc,
  {body: JSON.stringify(content),
  label: "MyTopic"});
  response = sequenceId.toString();
  await client.close();
  } catch (error) {
  } finally {
  await serviceConnection.close();
  }
  return resp;
  }

  这将引发一个问题,即 sequenceId 值将变为“未定义”。Azure 门户提供了一个修复,即需要对消息进行编码,然后将其放入服务总线中,以便获取正确的 sequenceId。
  错误修复:

  import { DefaultDataTransformer }
  from "@azure/amqp-common";
  ...
  ...
  const dt = new DefaultDataTransformer();
  const sequenceId = await sender.scheduleMessage(
  scheduledEnqueueTimeUtc,
  {body: dt.encode(JSON.stringify(content)),
  label: "MyTopic"});
  response = sequenceId.toString();

  现在您将收到正确的 sequenceId,如果将来需要,您可以使用以下代码段来取消消息。
  CancelMessage:此方法使用 scheduleMessage 调用删除了早期放置在服务总线中的消息。我们需要将调用期间返回的 sequenceNumber 作为此方法调用的唯一参数发送。如果消息已经传递,那么我们会收到一个错误 MessageNotFound ,需要在 catch 中处理。
  原型:

  cancelScheduledMessage( long sequenceNumber )

        因此,我们已经介绍了如何使用上述两种方法进行数据通信,并通过调度或非调度方式放置数据请求。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/193185.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 如何使用Powershell脚本监控Exchange2010(前言)

    如何使用Powershell脚本监控Exchange2010(前言)

    2021年8月15日
    57
  • Pycharm精选插件

    Pycharm精选插件可能很多人都没有安装过什么pycharm插件,一个很重要的原因是默认的pycharm已经很强大了,已经有很多功能了,但是这不妨碍我们喜欢更强大的pycharm。下面介绍几款能够提高效率的插件MaterialThemeUI相信很多用过Sublime的同学,一装完pycharm的第一感觉就是:“怎么这么难看”,然后赶紧去找教程把主题换回Sublime主题。其实不用这么麻烦,只需要装了这个插…

    2022年6月24日
    20
  • 谈磁盘列阵 raid0 raid1 raid3 raid5 raid10简介及区别

    谈磁盘列阵 raid0 raid1 raid3 raid5 raid10简介及区别转自:https://www.fengjunzi.com/blog-25108.htmlRAID简介随着服务器在企业的应用越来越广泛,数据安全,数据存储,数据恢复,存储速度等方面对企业用户来说越来越重要,而RAID卡在此过程中起着至关重要的作用,RAID卡本身的性能和特点往往会被一些用户忽视,而服务器厂商为节约成本也会搭配一些比较初级甚至一些小品牌的RAID卡产品,在使用过程中出现问题时用…

    2022年7月15日
    18
  • 如何查询、修改参数状态值

    如何查询、修改参数状态值

    2022年3月5日
    35
  • vue的form表单提交(vue表单数据和图片一起提交)

    利用v-model能比较便捷地上传用户信息的数据,不用一个个参数地拼接。直接在data根据要传的字段定义一个对象,再利用双向绑定得到值。下面写了传json格式跟formData格式的两种情况,根据实际参考<template><divclass=”from_box”><formaction=””><inputty…

    2022年4月18日
    188
  • c#窗体怎么居中_窗口居中

    c#窗体怎么居中_窗口居中窗体始终居桌面中央显示,需要考虑以下两个方面:(1).窗体距离桌面左部边缘与桌面的宽度以及自身宽度的判断;(2).窗体距离桌面上边缘与桌面的高度以及自身高度的判断下面用代码一一实现,当然这都是在窗体加载时完成this.Left=Screen.PrimaryScreen.Bounds.Width/2-this.Width/2;//桌面的宽度的一半减去自身宽的的一半this…….

    2022年9月9日
    1

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号