范文健康探索娱乐情感热点
投稿投诉
热点动态
科技财经
情感日志
励志美文
娱乐时尚
游戏搞笑
探索旅游
历史星座
健康养生
美丽育儿
范文作文
教案论文

一文搞懂MQTT,如何在SpringBoot中使用MQTT实现消息的订阅和发布

  之前介绍了RabbitMQ以及如何在SpringBoot项目中整合使用RabbitMQ,看过的朋友都说写的比较详细,希望再总结一下目前比较流行的MQTT。所以接下来,就来介绍什么MQTT?它在IoT中有着怎样的作用?如何在项目中使用MQTT?  一、MQTT介绍1.1 什么是MQTT?
  MQTT(Message Queuing Telemetry Transport,消息队列遥测传输协议),是一种基于发布/订阅(publish/subscribe)模式的"轻量级"通讯协议,该协议构建于TCP/IP协议上,由IBM在1999年发布。
  MQTT最大优点在于用极少的代码和有限的带宽,为连接远程设备提供实时可靠的消息服务。
  MQTT具有协议简洁、轻巧、可扩展性强、低开销、低带宽占用等优点,已经有PHP,JAVA,Python,C,C#,Go等多个语言版本,基本可以使用在任何平台上。在物联网、小型设备、移动应用等方面有较广泛的应用,特别适合用来当做物联网的通信协议。
  1.2 MQTT特点
  MQTT是一个基于客户端-服务器的消息发布/订阅传输协议。MQTT协议是轻量、简单、开放和易于实现的,这些特点使它适用范围非常广泛。在很多情况下,包括受限的环境中,如:机器与机器(M2M)通信和物联网(IoT)。
  MQTT协议是为硬件性能有限,且工作在低带宽、不可靠的网络的远程传感器和控制设备通讯而设计的协议,它具有以下主要的几项特性:  1.使用发布/订阅消息模式,提供多对多的消息发布,解除应用程序耦合;  2.对负载内容屏蔽的消息传输;  3.使用TCP/IP 提供网络连接;  4.支持三种消息发布服务质量(QoS):  QoS 0(最多一次):消息发布完全依赖底层 TCP/IP 网络。会发生消息丢失或重复。这个级别可用于如下情况,环境传感器数据,丢失一次数据无所谓,因为不久后还会有第二次发送。  QoS 1(至少一次):确保消息到达,但消息重复可能会发生。  QoS 2(只有一次):确保消息到达一次。这个级别可用于如下情况,在计费系统中,消息重复或丢失会导致不正确的结果。  5.传输数据小,开销很小(固定长度的头部是 2 字节),协议交换最小化,以降低网络流量;(用极少的代码和有限的带宽,为连接远程设备提供实时可靠的消息服务。)
  1.3 MQTT应用场景
  MQTT作为一种低开销、低带宽占用的即时通讯协议,使其在物联网、小型设备、移动应用等方面有着广泛的应用。MQTT服务只负责消息的接收和传递,应用系统连接到MQTT服务器后,可以实现采集数据接收、解析、业务处理、存储入库、数据展示等功能。常见的应用场景主要有以下几个方面:
  (1)消息推送: 如PC端的推送公告,比如安卓的推送服务,还有一些即时通信软件如微信、易信等也是采用的推送技术。
  (2)智能点餐: 通过MQTT消息队列产品,消费者可在餐桌上扫码点餐,并与商家后端系统连接实现自助下单、支付。
  (3)信息更新: 实现商场超市等场所的电子标签、公共场所的多媒体屏幕的显示更新管理。
  (4)扫码出站: 最常见的停车场扫码缴费,自动起竿;地铁闸口扫码进出站。
  二、MQTT的角色组成2.1 MQTT的客户端和服务端
  2.1.1 服务端(Broker)
  EMQX就是一个MQTT的Broker,emqx只是基于erlang语言开发的软件而已,其它的MQ还有ActiveMQ、RabbitMQ、HiveMQ等等。
  EMQX服务端:https://www.emqx.io/zh/downloads?os=Windows
  2.1.2 客户端(发布/订阅)
  EMQX客户端:https://mqttx.app/zh
  这个是用来测试验证的客户端,实际项目是通过代码来实现我们消息的生产者和消费者。
  2.2 MQTT中的几个概念
  相比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。
  step 1: 下载EMQ安装包,配置EMQ环境
  EMQX服务端:https://www.emqx.io/zh/downloads?os=Windows
  step 2: 下载压缩包解压,cmd进入bin文件夹
  step 3 :启动EMQX服务
  在命令行输入:emqx start 启动服务,打开浏览器输入:http://localhost:18083/ 进入登录页面。默认用户名密码 admin/public 。登录成功后,会进入emqx的后台管理页面,如下图所示:
  四、使用SpringBoot整合MQTT协议
  前面介绍了MQTT协议以及如何安装和启动MQTT服务。接下来演示如何在SpringBoot项目中整合MQTT实现消息的订阅和发布。  4.1 创建工程
  首先,创建spring-boot-starter-mqtt父工程,在父工程下分别创建消息的提供者spring-boot-starter-mqtt-provider 模块和消息的消费者spring-boot-starter-mqtt-consumer模块。
  4.2 实现生产者
  接下来,修改生产者模块spring-boot-starter-mqtt-provider 相关的代码,实现消息发布的功能模块。  4.2.1 导入依赖包
  修改pom.xml 文件,添加MQTT相关依赖,具体示例代码如下所示:                        org.springframework.boot             spring-boot-starter                                org.springframework.boot             spring-boot-starter-web                                org.springframework.boot             spring-boot-starter-test             test                                org.springframework.integration             spring-integration-mqtt             5.3.2.RELEASE                                org.projectlombok             lombok             1.18.4               4.2.2 修改配置文件
  修改application.yml配置文件,增加MQTT相关配置。示例代码如下所示:  spring:   application:     name: provider     #MQTT配置信息   mqtt:     #MQTT服务地址,端口号默认11883,如果有多个,用逗号隔开     url: tcp://127.0.0.1:11883     #用户名     username: admin     #密码     password: public     #客户端id(不能重复)     client:       id: provider-id     #MQTT默认的消息推送主题,实际可在调用接口是指定     default:       topic: topic server:   port: 80804.2.3 消息生产者客户端配置
  创建MqttProviderConfig配置类,读取application.yml中的相关配置,并初始化创建MQTT的连接。示例代码如下所示:  import lombok.extern.slf4j.Slf4j; import org.eclipse.paho.client.mqttv3.*; import org.eclipse.paho.client.mqttv3.persist.MemoryPersistence; import org.springframework.beans.factory.annotation.Value; import org.springframework.context.annotation.Configuration;  import javax.annotation.PostConstruct;  @Configuration @Slf4j public class MqttProviderConfig {     @Value("${spring.mqtt.username}")     private String username;      @Value("${spring.mqtt.password}")     private String password;      @Value("${spring.mqtt.url}")     private String hostUrl;      @Value("${spring.mqtt.client.id}")     private String clientId;      @Value("${spring.mqtt.default.topic}")     private String defaultTopic;      /**      * 客户端对象      */     private MqttClient client;      /**      * 在bean初始化后连接到服务器      */     @PostConstruct     public void init(){         connect();     }      /**      * 客户端连接服务端      */     public void connect(){         try{             //创建MQTT客户端对象             client = new MqttClient(hostUrl,clientId,new MemoryPersistence());             //连接设置             MqttConnectOptions options = new MqttConnectOptions();             //是否清空session,设置false表示服务器会保留客户端的连接记录(订阅主题,qos),客户端重连之后能获取到服务器在客户端断开连接期间推送的消息             //设置为true表示每次连接服务器都是以新的身份             options.setCleanSession(true);             //设置连接用户名             options.setUserName(username);             //设置连接密码             options.setPassword(password.toCharArray());             //设置超时时间,单位为秒             options.setConnectionTimeout(100);             //设置心跳时间 单位为秒,表示服务器每隔 1.5*20秒的时间向客户端发送心跳判断客户端是否在线             options.setKeepAliveInterval(20);             //设置遗嘱消息的话题,若客户端和服务器之间的连接意外断开,服务器将发布客户端的遗嘱信息             options.setWill("willTopic",(clientId + "与服务器断开连接").getBytes(),0,false);             //设置回调             client.setCallback(new MqttProviderCallBack());             client.connect(options);         } catch(MqttException e){             e.printStackTrace();         }     }     public void publish(int qos,boolean retained,String topic,String message){         MqttMessage mqttMessage = new MqttMessage();         mqttMessage.setQos(qos);         mqttMessage.setRetained(retained);         mqttMessage.setPayload(message.getBytes());         //主题的目的地,用于发布/订阅信息         MqttTopic mqttTopic = client.getTopic(topic);         //提供一种机制来跟踪消息的传递进度         //用于在以非阻塞方式(在后台运行)执行发布是跟踪消息的传递进度         MqttDeliveryToken token;         try {             //将指定消息发布到主题,但不等待消息传递完成,返回的token可用于跟踪消息的传递状态             //一旦此方法干净地返回,消息就已被客户端接受发布,当连接可用,将在后台完成消息传递。             token = mqttTopic.publish(mqttMessage);             token.waitForCompletion();         } catch (MqttException e) {             e.printStackTrace();         }     } }
  4.2.4 生产者客户端消息回调
  创建MqttProviderCallBack类并继承MqttCallback,实现相关消息回调事件,示例代码如下图所示:  import org.eclipse.paho.client.mqttv3.IMqttDeliveryToken; import org.eclipse.paho.client.mqttv3.MqttCallback; import org.eclipse.paho.client.mqttv3.MqttMessage;  public class MqttConsumerCallBack implements MqttCallback{      /**      * 客户端断开连接的回调      */     @Override     public void connectionLost(Throwable throwable) {         System.out.println("与服务器断开连接,可重连");     }      /**      * 消息到达的回调      */     @Override     public void messageArrived(String topic, MqttMessage message) throws Exception {         System.out.println(String.format("接收消息主题 : %s",topic));         System.out.println(String.format("接收消息Qos : %d",message.getQos()));         System.out.println(String.format("接收消息内容 : %s",new String(message.getPayload())));         System.out.println(String.format("接收消息retained : %b",message.isRetained()));     }      /**      * 消息发布成功的回调      */     @Override     public void deliveryComplete(IMqttDeliveryToken iMqttDeliveryToken) {         System.out.println(String.format("接收消息成功"));     } }4.2.5 创建Controller控制器实现消息发布功能
  创建SendController控制器类,实现消息的发送功能,示例代码如下所示:  @Controller public class SendController {     @Autowired     private MqttProviderConfig providerClient;      @RequestMapping("/sendMessage")     @ResponseBody     public String sendMessage(int qos,boolean retained,String topic,String message){         try {             providerClient.publish(qos, retained, topic, message);             return "发送成功";         } catch (Exception e) {             e.printStackTrace();             return "发送失败";         }     } }4.3 实现消费者
  前面完成了生成者消息发布的模块,接下来修改消费者模块spring-boot-starter-mqtt-consumer实现消息订阅、处理的功能。  4.3.1 导入依赖包
  修改pom.xml 文件,添加MQTT相关依赖,具体示例代码如下所示:                        org.springframework.boot             spring-boot-starter                                org.springframework.boot             spring-boot-starter-web                                org.springframework.boot             spring-boot-starter-test             test                                org.springframework.integration             spring-integration-mqtt             5.3.2.RELEASE                                org.projectlombok             lombok             1.18.4               4.3.2 修改配置文件
  修改application.yml配置文件,增加MQTT相关配置。示例代码如下所示:  spring:   application:     name: consumer   #MQTT配置信息   mqtt:     #MQTT服务端地址,端口默认为11883,如果有多个,用逗号隔开     url: tcp://127.0.0.1:11883     #用户名     username: admin     #密码     password: public     #客户端id(不能重复)     client:       id: consumer-id     #MQTT默认的消息推送主题,实际可在调用接口时指定     default:       topic: topic server:   port: 80854.3.3 消费者客户端配置
  创建消费者客户端配置类MqttConsumerConfig,读取application.yml中的相关配置,并初始化创建MQTT的连接。示例代码如下所示:  import javax.annotation.PostConstruct;  import org.eclipse.paho.client.mqttv3.MqttClient; import org.eclipse.paho.client.mqttv3.MqttConnectOptions; import org.eclipse.paho.client.mqttv3.MqttException; import org.eclipse.paho.client.mqttv3.persist.MemoryPersistence; import org.springframework.beans.factory.annotation.Value; import org.springframework.context.annotation.Configuration;  @Configuration public class MqttConsumerConfig {     @Value("${spring.mqtt.username}")     private String username;      @Value("${spring.mqtt.password}")     private String password;      @Value("${spring.mqtt.url}")     private String hostUrl;      @Value("${spring.mqtt.client.id}")     private String clientId;      @Value("${spring.mqtt.default.topic}")     private String defaultTopic;      /**      * 客户端对象      */     private MqttClient client;      /**      * 在bean初始化后连接到服务器      */     @PostConstruct     public void init(){         connect();     }      /**      * 客户端连接服务端      */     public void connect(){         try {             //创建MQTT客户端对象             client = new MqttClient(hostUrl,clientId,new MemoryPersistence());             //连接设置             MqttConnectOptions options = new MqttConnectOptions();             //是否清空session,设置为false表示服务器会保留客户端的连接记录,客户端重连之后能获取到服务器在客户端断开连接期间推送的消息             //设置为true表示每次连接到服务端都是以新的身份             options.setCleanSession(true);             //设置连接用户名             options.setUserName(username);             //设置连接密码             options.setPassword(password.toCharArray());             //设置超时时间,单位为秒             options.setConnectionTimeout(100);             //设置心跳时间 单位为秒,表示服务器每隔1.5*20秒的时间向客户端发送心跳判断客户端是否在线             options.setKeepAliveInterval(20);             //设置遗嘱消息的话题,若客户端和服务器之间的连接意外断开,服务器将发布客户端的遗嘱信息             options.setWill("willTopic",(clientId + "与服务器断开连接").getBytes(),0,false);             //设置回调             client.setCallback(new MqttConsumerCallBack());             client.connect(options);             //订阅主题             //消息等级,和主题数组一一对应,服务端将按照指定等级给订阅了主题的客户端推送消息             int[] qos = {1,1};             //主题             String[] topics = {"topic1","topic2"};             //订阅主题             client.subscribe(topics,qos);         } catch (MqttException e) {             e.printStackTrace();         }     }      /**      * 断开连接      */     public void disConnect(){         try {             client.disconnect();         } catch (MqttException e) {             e.printStackTrace();         }     }       /**      * 订阅主题      */     public void subscribe(String topic,int qos){         try {             client.subscribe(topic,qos);         } catch (MqttException e) {             e.printStackTrace();         }     } }4.3.4 消费者客户端消息回调
  创建MqttConsumerCallBack类并继承MqttCallback,实现相关消息回调事件,示例代码如下图所示:  import org.eclipse.paho.client.mqttv3.IMqttDeliveryToken; import org.eclipse.paho.client.mqttv3.MqttCallback; import org.eclipse.paho.client.mqttv3.MqttMessage;  public class MqttConsumerCallBack implements MqttCallback{      /**      * 客户端断开连接的回调      */     @Override     public void connectionLost(Throwable throwable) {         System.out.println("与服务器断开连接,可重连");     }      /**      * 消息到达的回调      */     @Override     public void messageArrived(String topic, MqttMessage message) throws Exception {         System.out.println(String.format("接收消息主题 : %s",topic));         System.out.println(String.format("接收消息Qos : %d",message.getQos()));         System.out.println(String.format("接收消息内容 : %s",new String(message.getPayload())));         System.out.println(String.format("接收消息retained : %b",message.isRetained()));     }      /**      * 消息发布成功的回调      */     @Override     public void deliveryComplete(IMqttDeliveryToken iMqttDeliveryToken) {         System.out.println(String.format("接收消息成功"));     } }4.3.5 创建Controller控制器,实现MQTT连接的建立和断开
  接下来,创建Controller控制器MqttController,并实现MQTT连接的建立和断开等方法。示例代码如下所示:  import com.weiz.mqtt.config.MqttConsumerConfig; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Value; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.ResponseBody;  @Controller public class MqttController {     @Autowired     private MqttConsumerConfig client;      @Value("${spring.mqtt.client.id}")     private String clientId;      @RequestMapping("/connect")     @ResponseBody     public String connect(){         client.connect();         return clientId + "连接到服务器";     }      @RequestMapping("/disConnect")     @ResponseBody     public String disConnect(){         client.disConnect();         return clientId + "与服务器断开连接";     } }4.4 测试验证
  首先,分别启动生产者spring-boot-starter-mqtt-provider 和消费者spring-boot-starter-mqtt-consumer两个项目,打开浏览器,输入地址http://localhost:18083/,在EMQX管理界面可以看到连接上来的两个客户端。如下图所示:
  接下来,调用生产者的消息发布接口验证消息发布是否成功。使用Pomstman调用消息发送接口:http://localhost:8080/sendMessage ,如下图所示:
  通过上图可以发现,生产者模块已经把消息发送成功。接下来查看消费者模块,验证消息是否处理成功。如下图所示:
  通过日志输出可以发现,消费者已经成功接收到生产者发送的消息,说明我们成功实现在Spring Boot项目中整合MQTT实现了消息的发布和订阅的功能。
  最后
  以上就是如何在Spring Boot中使用MQTT的详细内容,更多关于在Spring Boot中MQTT的使用大家可以去自己研究学习。比如:如何利用qos机制保证数据不会丢失?消息的队列和排序?集群模式下的应用?等等。

76人爆冷惜败,塔克终结纪录!梅尔顿表现不俗,哈里斯确实该离开北京时间11月24日,NBA常规赛继续进行,黄蜂主场迎战76人。黄蜂本赛季情况很糟糕,上赛季表现不俗的布里奇斯因丑闻很可能结束NBA生涯,三球鲍尔也因为脚踝伤势长时间缺席,球队打到阿根廷不要慌,晋级可能性仍排小组第1!德国危矣遭日本队碾压虽然首轮比赛12不敌沙特队,但权威数据网站给出的晋级赔率,阿根廷仍位列小组第1,而且很大可能性以小组第1晋级。而身处死亡之组的德国队,12遭日本队逆转之后,晋级可能性排在小组第3,华为Mate50用户口碑新鲜出炉!4G到底能不能忍?屏幕显示效果如何文Muse测评华为今年主打的旗舰系列Mate50这款手机相信有不少用户在观望,主要是担心只支持4G网络,会不会对日常使用造成影响。以及Mate50系列所使用的国产屏幕,显示效果究竟荣耀70系列对比荣耀80系列荣耀60SE对比荣耀80SE手机对比7080荣耀80相较于荣耀70对处理器厚度等方面进行了升级在有线充电后置主摄及超广角镜头重量等方面进行了取舍官方发售价有所降低二者的相同之处屏幕尺寸及材质柔性曲屏分辨率及刷苏州的房价明年会涨吗?首先,一手房的价格不代表苏州的房地产价格行情。其次,只有二手房价格行情才能代表苏州房地产行情。最后,法拍房的数量将严重苏州二手房行情走势。苏州法拍房在2021年10月份时就已经超过决定一个人走多远的不是才气财力,而是韧性文会想的猪猪图来源网络,与文无关,侵删知乎上有个提问出身平凡的人,怎么样才能成功?下面有个高赞回复虽然影响每个人成败的因素有很多,但都离不开坚韧的意志。韧性强的人,能屈能伸,面对任伊之密研究报告注塑ampampamp压铸双赛道增长的模压成型设备企业(报告出品方作者中信证券,刘海博,李越,李睿鹏)公司概况模压成型装备国内一线品牌公司主营业务是以注塑机和压铸机为主的模压成型装备。广东伊之密精密机械股份有限公司创始于2002年,专固态电池已装车试验?比亚迪回应不实(文潘昱辰编辑周远方)日前,一则比亚迪固态电池已经在重庆装车试验的消息在互联网上不胫而走。传言称,该项目由中国科学院院士清华大学教授欧阳明高牵头,另有三位院士顾问一同参与研发工作。会战红色家谱我给朱老总当过保卫找一位石油会战时期的老公安,实属不易。以至于3年来,都没能如愿。都说山重水复疑无路,柳岸花明又一村,张文范进入了记者的视线。被落在站台上的小姑娘1964年5月,在萨尔图火车站窄窄的闲山海战。龙的出现背景揭秘大明抗倭援朝中的朝日海战(上)昨晚看了韩国电影闲山。龙的出现,这部电影讲述的是1592年,倭寇侵略朝鲜,朝鲜水师名将在闲山海战中大败倭寇舰队的故事,七年前,同样一部鸣梁也是讲述李舜臣在鸣梁海战中大败倭寇的故事,这个男人统一了德意志俾斯麦铁血宰相俾斯麦讲起德意志帝国的建立,就不得不提到一个人物俾斯麦他外号铁血宰相,德意志帝国的奠基人,在他的领导下,普鲁士先后击败了丹麦,奥地利和号称欧陆第一强国的法国。完成了统一德意
重罚建业?陈戌源定性送行马宁事件在多拉多被中国足协重罚12个月20万结束中国足球之旅后,河南队火速完成补强与前锋马塞洛卡里略完成签约,但是多拉多冲撞马宁事件的影响显然没有结束,随着陈戌源给送行马宁定性,河南建业或郭艾伦周琦被辽宁新疆预注册5件事01hr郭艾伦周琦被辽宁新疆预注册昨日在注册截止日期前,新疆队为周琦进行了预注册,辽宁队则为郭艾伦进行了预注册。预注册的完成表明了新疆队和辽宁队的态度,下赛季两位球员不能为别的CB飞翔的荷兰人罗本天使之翼,边锋传奇。和双骄生在同一个年代是很悲催的,因为你不太会被这个时代铭记。斯内德高光的2010年没有被任何奖项刻画,里贝里生涯最佳的2013年到最后两手空空,范戴克将防守艺术客观分析周金辉为什么不把李明踢飞?相信今天很多球迷都看到了一篇有关李明的自媒体文章,题目是背锅老总李明我要真不行,老板不早把我踢飞了。这篇文章的内容是跟李明关系密切的作者为李明当前遭受北京媒体的抨击而叫屈,关于其中英超焦点战!莱斯特城迎战曼联,红魔能否拿下三连胜成为关注对象莱斯特城新赛季的开局十分糟糕,至今联赛取得一平三负的成绩,一胜难求的同时,积分排名也在积分榜最后一位。虽然期间每场比赛都有进球,不过却从未零封过对手,莱斯特城是夏窗英超最安静的球队官方曼联正式签下阿贾克斯边锋安东尼,转会费总价可达1亿欧元北京时间9月1日下午,英超豪门曼联俱乐部发布官方公告,宣布安东尼从阿贾克斯加盟的转会已经完成。安东尼与曼联签约至2027年,合同包含续约一年的选项。安东尼出生于2000年2月24日阅读比赛100分!哈兰德连破纪录有秘诀谁说瓜帅不会用大中锋背靠背上演帽子戏法,哈兰德5场比赛打入9球,证明了自己可以在英超取得成功。连续打破阿奎罗和凯恩的纪录,魔人布欧的下一个目标就是英超的34球单季进球纪录。甚至这都不是最终的高度,一个广东队三消息苏伟官宣退役,徐杰征服球迷,全队平均年龄23。5岁苏伟官宣退役。北京时间9月1日,CBA球员注册大门已经正式关闭,广东男篮在昨天压哨一口气完成4名球员的注册,分别是赵睿王薪凯徐杰胡明轩,赵睿完成注册也是给予到球迷一颗定心丸,有关于为什么我们越来越讨厌看NBA了?全都是库里,莱昂纳德,哈登害的以前的NBA,打一场比赛100比90,我们大呼精彩,现在的NBA动不动140比130,我们觉得一点儿意思也没有,那么到底有没有想过,这是为什么呢?我觉得这几点很重要!1。球员越来越又有新欢?卡西利亚斯蜜会前巴萨门将遗孀和萨拉离婚后,前皇马门神卡西利亚斯一直被曝出与不同的女子有过交往,从女演员LaraDibildos到模特RocoOsorno,卡西利亚斯一直都在辟谣或辟谣的路上。本周三,西班牙花边没有被注册,这几位球员难道要告别CBA了吗?昨天是CBA球员注册的截止日,CBA各队下赛季的注册球员名单已经出炉,一些老将却没有在注册球员名单里面,他们难道要就此告别CBA了吗?苏伟,一个让广东队球迷又爱又恨的名字,想当年广