应用办公生活信息教育商业
投稿投诉
商业财经
汽车智能
教育国际
房产环球
信息数码
热点科技
生活手机
晨报新闻
办公软件
科学动态
应用生物
体育时事

一文搞懂MQTT,如何在SpringBoot中使用MQTT实

  之前介绍了RabbitMQ以及如何在SpringBoot项目中整合使用RabbitMQ,看过的朋友都说写的比较详细,希望再总结一下目前比较流行的MQTT。所以接下来,就来介绍什么MQTT?它在IoT中有着怎样的作用?如何在项目中使用MQTT?一、MQTT介绍1。1什么是MQTT?
  MQTT(MessageQueuingTelemetryTransport,消息队列遥测传输协议),是一种基于发布订阅(publishsubscribe)模式的轻量级通讯协议,该协议构建于TCPIP协议上,由IBM在1999年发布。
  MQTT最大优点在于用极少的代码和有限的带宽,为连接远程设备提供实时可靠的消息服务。
  MQTT具有协议简洁、轻巧、可扩展性强、低开销、低带宽占用等优点,已经有PHP,JAVA,Python,C,C,Go等多个语言版本,基本可以使用在任何平台上。在物联网、小型设备、移动应用等方面有较广泛的应用,特别适合用来当做物联网的通信协议。
  1。2MQTT特点
  MQTT是一个基于客户端服务器的消息发布订阅传输协议。MQTT协议是轻量、简单、开放和易于实现的,这些特点使它适用范围非常广泛。在很多情况下,包括受限的环境中,如:机器与机器(M2M)通信和物联网(IoT)。
  MQTT协议是为硬件性能有限,且工作在低带宽、不可靠的网络的远程传感器和控制设备通讯而设计的协议,它具有以下主要的几项特性:1。使用发布订阅消息模式,提供多对多的消息发布,解除应用程序耦合;2。对负载内容屏蔽的消息传输;3。使用TCPIP提供网络连接;4。支持三种消息发布服务质量(QoS):QoS0(最多一次):消息发布完全依赖底层TCPIP网络。会发生消息丢失或重复。这个级别可用于如下情况,环境传感器数据,丢失一次数据无所谓,因为不久后还会有第二次发送。QoS1(至少一次):确保消息到达,但消息重复可能会发生。QoS2(只有一次):确保消息到达一次。这个级别可用于如下情况,在计费系统中,消息重复或丢失会导致不正确的结果。5。传输数据小,开销很小(固定长度的头部是2字节),协议交换最小化,以降低网络流量;(用极少的代码和有限的带宽,为连接远程设备提供实时可靠的消息服务。)
  1。3MQTT应用场景
  MQTT作为一种低开销、低带宽占用的即时通讯协议,使其在物联网、小型设备、移动应用等方面有着广泛的应用。MQTT服务只负责消息的接收和传递,应用系统连接到MQTT服务器后,可以实现采集数据接收、解析、业务处理、存储入库、数据展示等功能。常见的应用场景主要有以下几个方面:
  (1)消息推送:如PC端的推送公告,比如安卓的推送服务,还有一些即时通信软件如微信、易信等也是采用的推送技术。
  (2)智能点餐:通过MQTT消息队列产品,消费者可在餐桌上扫码点餐,并与商家后端系统连接实现自助下单、支付。
  (3)信息更新:实现商场超市等场所的电子标签、公共场所的多媒体屏幕的显示更新管理。
  (4)扫码出站:最常见的停车场扫码缴费,自动起竿;地铁闸口扫码进出站。
  二、MQTT的角色组成2。1MQTT的客户端和服务端
  2。1。1服务端(Broker)
  EMQX就是一个MQTT的Broker,emqx只是基于erlang语言开发的软件而已,其它的MQ还有ActiveMQ、RabbitMQ、HiveMQ等等。
  EMQX服务端:https:www。emqx。iozhdownloads?osWindows
  2。1。2客户端(发布订阅)
  EMQX客户端:https:mqttx。appzh
  这个是用来测试验证的客户端,实际项目是通过代码来实现我们消息的生产者和消费者。
  2。2MQTT中的几个概念
  相比RabbitMQ等消息队列,MQTT要相对简单一些,只有Broker、Topic、发布者、订阅者等几部分构成。接下来我们先简单整理下MQTT日常使用中最常见的几个概念:1。Topic主题:MQTT消息的主要传播途径,我们向主题发布消息,订阅主题,从主题中读取消息并进行。业务逻辑处理,主题是消息的通道2。生产者:MQTT消息的发送者,他们向主题发送消息3。消费者:MQTT消息的接收者,他们订阅自己需要的主题,并从中获取消息4。broker服务:消息转发器,消息是通过它来承载的,EMQX就是我们的broker,在使用中我们不用关心它的具体实现
  其实,MQTT的使用流程就是:生产者给broker的某个topic发消息broker通过topic进行消息的传递订阅该主题的消费者拿到消息并进行相应的业务逻辑
  三、EMQX的安装和使用
  下面以Windows为例,演示Windows下如何安装和使用EXQX。
  step1:下载EMQ安装包,配置EMQ环境
  EMQX服务端:https:www。emqx。iozhdownloads?osWindows
  step2:下载压缩包解压,cmd进入bin文件夹
  step3:启动EMQX服务
  在命令行输入:emqxstart启动服务,打开浏览器输入:http:localhost:18083进入登录页面。默认用户名密码adminpublic。登录成功后,会进入emqx的后台管理页面,如下图所示:
  四、使用SpringBoot整合MQTT协议
  前面介绍了MQTT协议以及如何安装和启动MQTT服务。接下来演示如何在SpringBoot项目中整合MQTT实现消息的订阅和发布。4。1创建工程
  首先,创建springbootstartermqtt父工程,在父工程下分别创建消息的提供者springbootstartermqttprovider模块和消息的消费者springbootstartermqttconsumer模块。
  4。2实现生产者
  接下来,修改生产者模块springbootstartermqttprovider相关的代码,实现消息发布的功能模块。4。2。1导入依赖包
  修改pom。xml文件,添加MQTT相关依赖,具体示例代码如下所示:dependenciesdependencygroupIdorg。springframework。bootgroupIdspringbootstarterartifactIddependencydependencygroupIdorg。springframework。bootgroupIdspringbootstarterwebartifactIddependencydependencygroupIdorg。springframework。bootgroupIdspringbootstartertestartifactIdscopetestscopedependencydependencygroupIdorg。springframework。integrationgroupIdspringintegrationmqttartifactIdversion5。3。2。RELEASEversiondependencydependencygroupIdorg。projectlombokgroupIdlombokartifactIdversion1。18。4versiondependencydependencies4。2。2修改配置文件
  修改application。yml配置文件,增加MQTT相关配置。示例代码如下所示:spring:application:name:providerMQTT配置信息mqtt:MQTT服务地址,端口号默认11883,如果有多个,用逗号隔开url:tcp:127。0。0。1:11883用户名username:admin密码password:public客户端id(不能重复)client:id:provideridMQTT默认的消息推送主题,实际可在调用接口是指定default:topic:topicserver:port:80804。2。3消息生产者客户端配置
  创建MqttProviderConfig配置类,读取application。yml中的相关配置,并初始化创建MQTT的连接。示例代码如下所示:importlombok。extern。slf4j。Slf4j;importorg。eclipse。paho。client。mqttv3。;importorg。eclipse。paho。client。mqttv3。persist。MemoryPersistence;importorg。springframework。beans。factory。annotation。Value;importorg。springframework。context。annotation。Configuration;importjavax。annotation。PostConstruct;ConfigurationSlf4jpublicclassMqttProviderConfig{Value({spring。mqtt。username})privateStringusername;Value({spring。mqtt。password})privateStringpassword;Value({spring。mqtt。url})privateStringhostUrl;Value({spring。mqtt。client。id})privateStringclientId;Value({spring。mqtt。default。topic})privateStringdefaultTopic;客户端对象privateMqttClientclient;在bean初始化后连接到服务器PostConstructpublicvoidinit(){connect();}客户端连接服务端publicvoidconnect(){try{创建MQTT客户端对象clientnewMqttClient(hostUrl,clientId,newMemoryPersistence());连接设置MqttConnectOptionsoptionsnewMqttConnectOptions();是否清空session,设置false表示服务器会保留客户端的连接记录(订阅主题,qos),客户端重连之后能获取到服务器在客户端断开连接期间推送的消息设置为true表示每次连接服务器都是以新的身份options。setCleanSession(true);设置连接用户名options。setUserName(username);设置连接密码options。setPassword(password。toCharArray());设置超时时间,单位为秒options。setConnectionTimeout(100);设置心跳时间单位为秒,表示服务器每隔1。520秒的时间向客户端发送心跳判断客户端是否在线options。setKeepAliveInterval(20);设置遗嘱消息的话题,若客户端和服务器之间的连接意外断开,服务器将发布客户端的遗嘱信息options。setWill(willTopic,(clientId与服务器断开连接)。getBytes(),0,false);设置回调client。setCallback(newMqttProviderCallBack());client。connect(options);}catch(MqttExceptione){e。printStackTrace();}}publicvoidpublish(intqos,booleanretained,Stringtopic,Stringmessage){MqttMessagemqttMessagenewMqttMessage();mqttMessage。setQos(qos);mqttMessage。setRetained(retained);mqttMessage。setPayload(message。getBytes());主题的目的地,用于发布订阅信息MqttTopicmqttTopicclient。getTopic(topic);提供一种机制来跟踪消息的传递进度用于在以非阻塞方式(在后台运行)执行发布是跟踪消息的传递进度MqttDeliveryTokentoken;try{将指定消息发布到主题,但不等待消息传递完成,返回的token可用于跟踪消息的传递状态一旦此方法干净地返回,消息就已被客户端接受发布,当连接可用,将在后台完成消息传递。tokenmqttTopic。publish(mqttMessage);token。waitForCompletion();}catch(MqttExceptione){e。printStackTrace();}}}
  4。2。4生产者客户端消息回调
  创建MqttProviderCallBack类并继承MqttCallback,实现相关消息回调事件,示例代码如下图所示:importorg。eclipse。paho。client。mqttv3。IMqttDeliveryToken;importorg。eclipse。paho。client。mqttv3。MqttCallback;importorg。eclipse。paho。client。mqttv3。MqttMessage;publicclassMqttConsumerCallBackimplementsMqttCallback{客户端断开连接的回调OverridepublicvoidconnectionLost(Throwablethrowable){System。out。println(与服务器断开连接,可重连);}消息到达的回调OverridepublicvoidmessageArrived(Stringtopic,MqttMessagemessage)throwsException{System。out。println(String。format(接收消息主题:s,topic));System。out。println(String。format(接收消息Qos:d,message。getQos()));System。out。println(String。format(接收消息内容:s,newString(message。getPayload())));System。out。println(String。format(接收消息retained:b,message。isRetained()));}消息发布成功的回调OverridepublicvoiddeliveryComplete(IMqttDeliveryTokeniMqttDeliveryToken){System。out。println(String。format(接收消息成功));}}4。2。5创建Controller控制器实现消息发布功能
  创建SendController控制器类,实现消息的发送功能,示例代码如下所示:ControllerpublicclassSendController{AutowiredprivateMqttProviderConfigproviderClient;RequestMapping(sendMessage)ResponseBodypublicStringsendMessage(intqos,booleanretained,Stringtopic,Stringmessage){try{providerClient。publish(qos,retained,topic,message);return发送成功;}catch(Exceptione){e。printStackTrace();return发送失败;}}}4。3实现消费者
  前面完成了生成者消息发布的模块,接下来修改消费者模块springbootstartermqttconsumer实现消息订阅、处理的功能。4。3。1导入依赖包
  修改pom。xml文件,添加MQTT相关依赖,具体示例代码如下所示:dependenciesdependencygroupIdorg。springframework。bootgroupIdspringbootstarterartifactIddependencydependencygroupIdorg。springframework。bootgroupIdspringbootstarterwebartifactIddependencydependencygroupIdorg。springframework。bootgroupIdspringbootstartertestartifactIdscopetestscopedependencydependencygroupIdorg。springframework。integrationgroupIdspringintegrationmqttartifactIdversion5。3。2。RELEASEversiondependencydependencygroupIdorg。projectlombokgroupIdlombokartifactIdversion1。18。4versiondependencydependencies4。3。2修改配置文件
  修改application。yml配置文件,增加MQTT相关配置。示例代码如下所示:spring:application:name:consumerMQTT配置信息mqtt:MQTT服务端地址,端口默认为11883,如果有多个,用逗号隔开url:tcp:127。0。0。1:11883用户名username:admin密码password:public客户端id(不能重复)client:id:consumeridMQTT默认的消息推送主题,实际可在调用接口时指定default:topic:topicserver:port:80854。3。3消费者客户端配置
  创建消费者客户端配置类MqttConsumerConfig,读取application。yml中的相关配置,并初始化创建MQTT的连接。示例代码如下所示:importjavax。annotation。PostConstruct;importorg。eclipse。paho。client。mqttv3。MqttClient;importorg。eclipse。paho。client。mqttv3。MqttConnectOptions;importorg。eclipse。paho。client。mqttv3。MqttException;importorg。eclipse。paho。client。mqttv3。persist。MemoryPersistence;importorg。springframework。beans。factory。annotation。Value;importorg。springframework。context。annotation。Configuration;ConfigurationpublicclassMqttConsumerConfig{Value({spring。mqtt。username})privateStringusername;Value({spring。mqtt。password})privateStringpassword;Value({spring。mqtt。url})privateStringhostUrl;Value({spring。mqtt。client。id})privateStringclientId;Value({spring。mqtt。default。topic})privateStringdefaultTopic;客户端对象privateMqttClientclient;在bean初始化后连接到服务器PostConstructpublicvoidinit(){connect();}客户端连接服务端publicvoidconnect(){try{创建MQTT客户端对象clientnewMqttClient(hostUrl,clientId,newMemoryPersistence());连接设置MqttConnectOptionsoptionsnewMqttConnectOptions();是否清空session,设置为false表示服务器会保留客户端的连接记录,客户端重连之后能获取到服务器在客户端断开连接期间推送的消息设置为true表示每次连接到服务端都是以新的身份options。setCleanSession(true);设置连接用户名options。setUserName(username);设置连接密码options。setPassword(password。toCharArray());设置超时时间,单位为秒options。setConnectionTimeout(100);设置心跳时间单位为秒,表示服务器每隔1。520秒的时间向客户端发送心跳判断客户端是否在线options。setKeepAliveInterval(20);设置遗嘱消息的话题,若客户端和服务器之间的连接意外断开,服务器将发布客户端的遗嘱信息options。setWill(willTopic,(clientId与服务器断开连接)。getBytes(),0,false);设置回调client。setCallback(newMqttConsumerCallBack());client。connect(options);订阅主题消息等级,和主题数组一一对应,服务端将按照指定等级给订阅了主题的客户端推送消息int〔〕qos{1,1};主题String〔〕topics{topic1,topic2};订阅主题client。subscribe(topics,qos);}catch(MqttExceptione){e。printStackTrace();}}断开连接publicvoiddisConnect(){try{client。disconnect();}catch(MqttExceptione){e。printStackTrace();}}订阅主题publicvoidsubscribe(Stringtopic,intqos){try{client。subscribe(topic,qos);}catch(MqttExceptione){e。printStackTrace();}}}4。3。4消费者客户端消息回调
  创建MqttConsumerCallBack类并继承MqttCallback,实现相关消息回调事件,示例代码如下图所示:importorg。eclipse。paho。client。mqttv3。IMqttDeliveryToken;importorg。eclipse。paho。client。mqttv3。MqttCallback;importorg。eclipse。paho。client。mqttv3。MqttMessage;publicclassMqttConsumerCallBackimplementsMqttCallback{客户端断开连接的回调OverridepublicvoidconnectionLost(Throwablethrowable){System。out。println(与服务器断开连接,可重连);}消息到达的回调OverridepublicvoidmessageArrived(Stringtopic,MqttMessagemessage)throwsException{System。out。println(String。format(接收消息主题:s,topic));System。out。println(String。format(接收消息Qos:d,message。getQos()));System。out。println(String。format(接收消息内容:s,newString(message。getPayload())));System。out。println(String。format(接收消息retained:b,message。isRetained()));}消息发布成功的回调OverridepublicvoiddeliveryComplete(IMqttDeliveryTokeniMqttDeliveryToken){System。out。println(String。format(接收消息成功));}}4。3。5创建Controller控制器,实现MQTT连接的建立和断开
  接下来,创建Controller控制器MqttController,并实现MQTT连接的建立和断开等方法。示例代码如下所示:importcom。weiz。mqtt。config。MqttConsumerConfig;importorg。springframework。beans。factory。annotation。Autowired;importorg。springframework。beans。factory。annotation。Value;importorg。springframework。stereotype。Controller;importorg。springframework。web。bind。annotation。RequestMapping;importorg。springframework。web。bind。annotation。ResponseBody;ControllerpublicclassMqttController{AutowiredprivateMqttConsumerConfigclient;Value({spring。mqtt。client。id})privateStringclientId;RequestMapping(connect)ResponseBodypublicStringconnect(){client。connect();returnclientId连接到服务器;}RequestMapping(disConnect)ResponseBodypublicStringdisConnect(){client。disConnect();returnclientId与服务器断开连接;}}4。4测试验证
  首先,分别启动生产者springbootstartermqttprovider和消费者springbootstartermqttconsumer两个项目,打开浏览器,输入地址http:localhost:18083,在EMQX管理界面可以看到连接上来的两个客户端。如下图所示:
  接下来,调用生产者的消息发布接口验证消息发布是否成功。使用Pomstman调用消息发送接口:http:localhost:8080sendMessage,如下图所示:
  通过上图可以发现,生产者模块已经把消息发送成功。接下来查看消费者模块,验证消息是否处理成功。如下图所示:
  通过日志输出可以发现,消费者已经成功接收到生产者发送的消息,说明我们成功实现在SpringBoot项目中整合MQTT实现了消息的发布和订阅的功能。
  最后
  以上就是如何在SpringBoot中使用MQTT的详细内容,更多关于在SpringBoot中MQTT的使用大家可以去自己研究学习。比如:如何利用qos机制保证数据不会丢失?消息的队列和排序?集群模式下的应用?等等。

如何实现S71200F和1500F使用PNPNCouple安1概述与在标准的系统中一样,TIA安全系统中具有PROFINET接口的1200F和1500FCPU之间可以进行安全相关的通信。通信通过两个安全应用程序块进行,即SENDD……中式台球国际大师赛郑宇伯夺总冠军捧得500万奖金京报体育记者邓方佳4月5日晚,秦皇岛银行乔氏杯第十一届中式台球国际大师赛全球总决赛在秦皇岛市奥体中心体育馆闭幕。在最终决赛中,郑宇伯以21比15力克女子选手唐春晓夺冠,获……大虹桥200亩都市森林两代人,20年接力之路从赵家路进入赵家村,会经过一片森林。如果不是特意而来,常常会错过。很难想象毗邻虹桥交通枢纽,还有这样一处绿色秘境。20多年前,沪西北的华漕小镇200亩的荒野上,本地人尹文……8种好脂肪您平时吃了几种?脂肪8种好脂肪您平时吃了几种?8种常见的都有哪些?咱班老同学(铁粉)都知道,饱和包括猪油、牛油、羊油以及大家平时要限制,千万别多吃了!那么什么是好?今天就分享8种常见的……深蓝保等保险测评机构,一群披着羊皮的狼NO。128篇文章(连续日更,第22天)标签:保险理财,认准鱼师爷财经段子手最近,一搜保险。超级玛丽xx号、金玉满堂xx号。推荐的保险软文遍……银行危机大赢家出现!对冲基金卖空银行3月份狂赚70亿美元总是有人能在危机中大赚特赚!数据公司Ortex的数据显示,在3月的欧美银行业危机中,对冲基金通过做空硅谷银行获利约13亿美元,通过做空第一共和银行获利8。48亿美元,此外……顺产好还是剖腹产好去年我们单位一共有3个同事接连生子,有顺产的,有顺转剖的,还有直接剖腹产的,对比身体之后的恢复情况,直接剖腹产的女同事恢复的是最好的,顺转剖其次,最差的是顺产的。通过这一……沃森生物董事长有信心作者:李月嘉3月22日,沃森生物董事长及其控制的企业增持进展显示,李云春通过设立广州盈沃企业管理合伙企业(有限合伙)作为增持主体,以集中竞价交易方式增持公司股份264。5……盘点王国之泪各国预购奖励还有送勺子的?昨日《塞尔达传说:王国之泪》公布了由制作人青沼英二介绍的中文实机演示,并宣布游戏目前已经制作完毕。各个国家地区的游戏预购奖励也已上线,一起来了解一下吧。澳大利亚《塞尔达传……40余位院士齐聚珠海,为数字中国添智增力4月1日上午,第十六届中国电子信息年会在珠海开幕。40余位两院院士以及众多来自全国电子信息领域的专家学者齐聚一堂,围绕国家战略和科技前沿开展学术交流和技术研讨,为实现制造强国、……为什么多数人选择网上买手机,而不愿去实体店买呢?现如今消费市场中,网购已经逐渐成为了人们的主要购物方式之一。越来越多的人选择网购手机,而不是去实体店购买,这是由于多方面的原因所导致的。下面就来详细介绍一下这些原因。首先……阿里为何不做游戏?马云曾抱怨,从没一个国家游戏发展成我们这样阿里巴巴跟腾讯两家公司是中国最好的两家互联网公司。可是很多人一直不明白一个问题,两家公司一直在竞争,为何阿里却从来不去做游戏呢?如果阿里也动用资源去做游戏,那么对腾讯来说……
S29赛季四个英雄推荐,个个都吃到版本红利,白起或再迎巅峰大家好我是指尖,新版本就要来了,大家准备好用什么英雄来上分了吗?本文指尖就来给大家推荐几个比较适合版本的英雄,或许就是你平时喜欢用的那个呢。白起推荐理由:新版本边路……到了夏天才知道T恤不兴了!满大街都在穿杏衫,显瘦又衬肤到了夏天,身边就有好多小姐姐在给自己买T恤,买连衣裙,在夏天这些单品出镜率确实比较高,而且实用性也很强,但是穿久了之后确实有些容易撞衫;对那些爱美的小姐姐来说,只有穿得与众不同……被中止审查的支付机构结局如何?暂无成功案例六月下旬迎来了第四批支付牌照的续展工作,这无疑给支付行业又带来了新的谈资,续展前就传出支付行业头部玩家续展受阻,有不少人猜疑会是嘉联支付,截止6月26日尘埃落定,嘉联支付与瀚银……终身成长改变思维模式,实现终身成长今天为您解读的这本书叫做《终身成长》,本书中文版约27万字,我会用5期内容为您讲解本书的精髓,本期是讲解的第5期。上一期,我们讲到了父母对孩子的称赞方式塑造了孩子的思维模……德云社周九良开豪车上班,引发众人热议,网友说相声真挣钱4月1日,周九良开豪车来到三里屯小剧场上班的视频,引发了众人的羡慕,而网友对此也是议论纷纷。有的网友表示说相声的真挣钱,这成名成角之后真是不一样了,真是阔绰。也有的表示,怪不得……折叠屏手机将会大爆发?刘作虎晒出新铰链,是一加还是OPPO不说到折叠屏手机,目前华为、三星、小米、摩托罗拉、OPPO、vivo等智能手机品牌已经陆续入场,再加上魅族此前也表示正在研究折叠屏手机的路线,由此,有分析人士表示,整个手机行业在……新北方金霞为何离开电台,多年的问题第一次向大家讲诉新北方的金霞去哪了,致力民生新闻力量这里是正在直播的新北方金霞,辽宁电视台的主持人。也可以说是当时的当家主持人,无人不知,23岁在沈阳电视台主持《直播生活》节目,2004……为什么说最好不要和熟人一起去旅游?我用亲身经历告诉你答案自从8年前我和表哥表嫂一起外出旅游一次之后,给我留下了阴影,从那以后,我内心一再告诫自己,再也不和熟人的家庭一起外出旅游了。那年国庆长假,表哥打电话来问我要不要一起去广西……长明灯下念故人,以诗词之名,行思念之实一诗一文每一天的原创诗歌和梦想,不要再和我擦肩而过曾省惊眠闻雨过,不知迷路为花开中元节,是伤痕再次疼痛的时候,是眼泪重新泛滥的时候。逝者早已经融入泥土之中,再也找不……冲击2米40!张国伟出国比赛,跳高网红承诺领奖台表演龙吸水说到张国伟相信很多网友不陌生,张国伟是中国男子跳高运动员,职业生涯的最好成绩是2米38,张国伟非常有跳高天赋,拿到很多国内外的跳高冠军,同时性格幽默风趣,比赛现场跳舞白鹤亮翅的……世界三大顶级主题公园操盘手的秘籍是什么?主题公园运营是一项极其复杂的系统工程,世界级主题公园更是如此。如何根据消费客群结构及其偏好变化打造新产品?各种餐饮品牌、销售商品及其他业态的引入又要遵循哪些运营规则?如何……CBA最新消息!张宁拿到500万合同,董瀚麟投奔李楠,鄢手骐作为CBA选秀球员,张宁在这个夏天收到了不少大合同,根据媒体人报道,至少有4支球队都希望签下他。不过最终张宁还是选择了留在山西男篮,据了解他拿到了一份3年500万的大合同。而江……
友情链接:易事利快生活快传网聚热点七猫云快好知快百科中准网快好找文好找中准网快软网