package com.yunda.app.service;

import java.io.InputStream;
import java.net.HttpURLConnection;
import java.net.URL;
import java.util.ArrayList;
import java.util.List;
import java.util.Scanner; import net.sf.json.JSONArray;
import net.sf.json.JSONObject; import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional; import com.yunda.app.entity.vo.MessageQueue;
import com.yunda.app.entity.vo.Page;
import com.yunda.app.util.StaticVar; @Service(value = "messageQueueService")
@Transactional
public class MessageQueueServiceImpl implements MessageQueueService {
private Scanner scanner; @Override
public Page pageQuery(MessageQueue messageQueue) {
Page page = new Page();
try {
StringBuilder ipText = new StringBuilder();
String url = StaticVar.RABBITMQ_URL;
// 用户名密码部分
String username = StaticVar.RABBITMQ_USERNAME;
String password = StaticVar.RABBITMQ_PASSWORD;
String input = username + ":" + password;
String encoding = new String((new sun.misc.BASE64Encoder()).encode(input.getBytes()));
URL myURL = new URL(url);
HttpURLConnection conn = (HttpURLConnection) myURL.openConnection();
conn.setConnectTimeout(6 * 1000);
conn.setReadTimeout(6 * 1000);
conn.setRequestProperty("Authorization", "Basic " + encoding);
//如果连接成功,获得返回字符串
if (conn.getResponseCode() == 200) {
InputStream inputStream = conn.getInputStream();
scanner = new Scanner(inputStream, "utf-8");
while (scanner.hasNext()) {
ipText.append(scanner.next());
}
if (inputStream != null) {
inputStream.close();
}
conn.disconnect();
JSONArray jsonArray = JSONArray.fromObject(ipText.toString());
List<MessageQueue> mqList = new ArrayList<MessageQueue>();
int pageNo = messageQueue.getPageNo();
int pageSize = messageQueue.getPageSize();
//如果json有子项,说明有消息队列
if (jsonArray != null && jsonArray.size() > 0) {
String messageQueueName = messageQueue.getName();
//不是搜索某个消息队列
if (messageQueueName == null) {
//分页选取消息队列
for (int i = (pageNo - 1) * pageSize; i < pageNo
* pageSize; i++) {
if (i == jsonArray.size()) {
break;
}
MessageQueue mq = new MessageQueue();
JSONObject jsonobject = jsonArray.getJSONObject(i);
//获取消息队列name等字段
mq.setName(jsonobject.getString("name"));
mq.setMessagesReady(jsonobject
.getInt("messages_ready"));
mq.setMessagesUnacknowledged(jsonobject
.getInt("messages_unacknowledged"));
mq.setMessages(jsonobject.getInt("messages"));
mq.setConsumers(jsonobject.getInt("consumers"));
mq.setState(jsonobject.getString("state"));
mqList.add(mq);
}
if (mqList.size() > 0) {
page.setTotal(jsonArray.size());
page.setRows(mqList);
}
} else {//是搜索某个消息队列
MessageQueue mq = new MessageQueue();
for (int i = 0; i < jsonArray.size(); i++) {
JSONObject jsonobject = jsonArray.getJSONObject(i);
//获取消息队列name字段,判断是否和搜索队列名称相同
String jsonobjectName=jsonobject.getString("name");
if (jsonobjectName.equals(messageQueueName)) {
mq.setName(messageQueueName);
mq.setMessagesReady(jsonobject
.getInt("messages_ready"));
mq.setMessagesUnacknowledged(jsonobject
.getInt("messages_unacknowledged"));
mq.setMessages(jsonobject.getInt("messages"));
mq.setConsumers(jsonobject.getInt("consumers"));
mq.setState(jsonobject.getString("state"));
mqList.add(mq);
break;
}
}
if (mqList.size() > 0) {
page.setTotal(1);
page.setRows(mqList);
}
} } }
} catch (Exception e) {
e.printStackTrace();
}
return page;
}
}
package com.yunda.app.entity.vo;

import java.io.Serializable;
import java.util.ArrayList;
import java.util.List;
/**
* 分页信息实体
*
* @author JS
* @since 2013-04-09
*/
@SuppressWarnings("serial")
public class Page implements Serializable { /**总记录数*/
private long total;
/**当前页记录,类型为List*/
private Object rows;
/**列表底部显示的数据,例如统计数据,类型为List*/
private Object footer; /**
* 构造方法,只构造空页.
*/
public Page() {
this(0, new ArrayList());
} /**
* 不分页列表数据对象默认构造方法
*
* @param rows 列表数据
*/
public Page(Object rows) {
this.rows = rows;
if(null != rows && rows instanceof List) {
this.total = ((List)rows).size();
} else if (null != rows){
this.total = 1;
}
} /**
* 分页列表数据对象默认构造方法(仅含含列表)
*
* @param rows 列表数据
*/
public Page(long total, Object rows) {
this.total = total;
this.rows = rows;
} /**
* 默认分页构造方法(含列表和表底)
*
* @param total 总记录数
* @param rows 页数据
* @param footer 页脚数据
*/
public Page(long total, Object rows, Object footer) {
this.total = total;
this.rows = rows;
this.footer = footer;
} /**
* 取当前页中的记录.
*/
public Object getRows() {
return rows;
} /**
* 设置当前页中的记录.
*/
public void setRows(Object rows){
this.rows = rows;
} /**
* 获取总记录数
*
* @return
*/
public long getTotal() {
return total;
} /**
* 设置总记录数
*
* @param total
*/
public void setTotal(long total) {
this.total = total;
} public Object getFooter() {
return footer;
} public void setFooter(Object footer) {
this.footer = footer;
} /**
* 获取任一页第一条数据在数据集的位置(不考虑总记录数)
*
* @param pageNo 从1开始的页号
* @param pageSize 每页记录条数
* @return 该页第一条数据
*/
public static long getStartOfPage(int pageNo, int pageSize) {
long start = (pageNo - 1) * pageSize;
return start < 0 ? 0 : start;
} /**
* 获取任一页第一条数据在数据集的位置(考虑总记录数并做调整)
*
* @param total 总记录数
* @param pageNo 从1开始的页号
* @param pageSize 每页记录条数
* @return 该页第一条数据
*/
public static long getStartOfPage(long total, int pageNo, int pageSize) {
long start = (pageNo - 1) * pageSize;
//如果超过了最后一行,则自动退回到最后一页的第一行
if (start >= total) {
start = Page.getStartOfPage(pageNo-1, pageSize);
}
return start < 0 ? 0 : start;
}
}

查询rabbitmq的更多相关文章

  1. rabbitmq高级消息队列

    rabbitmq使用 什么是消息队列 消息(Message)是指在应用间传送的数据.消息可以非常简单,比如只包含文本字符串,也可以很复杂,可以包含嵌入对象. 消息队列是一种应用间的通信方式,消息发送后 ...

  2. CentOS 6快捷安装RabbitMQ教程

    1.安装Erlang yum install erlang 2.安装RabbitMQ yum install rabbitmq-server 3.配置开机自启动 chkconfig rabbitmq- ...

  3. 消息队列之 RabbitMQ

    https://www.jianshu.com/p/79ca08116d57 关于消息队列,从前年开始断断续续看了些资料,想写很久了,但一直没腾出空,近来分别碰到几个朋友聊这块的技术选型,是时候把这块 ...

  4. RabbitMQ,Apache的ActiveMQ,阿里RocketMQ,Kafka,ZeroMQ,MetaMQ,Redis也可实现消息队列,RabbitMQ的应用场景以及基本原理介绍,RabbitMQ基础知识详解,RabbitMQ布曙

    消息队列及常见消息队列介绍 2017-10-10 09:35操作系统/客户端/人脸识别 一.消息队列(MQ)概述 消息队列(Message Queue),是分布式系统中重要的组件,其通用的使用场景可以 ...

  5. 转 消息队列之 RabbitMQ

    转 https://www.jianshu.com/p/79ca08116d57 消息队列之 RabbitMQ 预流 2017.05.06 16:03* 字数 4884 阅读 80990评论 18喜欢 ...

  6. RabbitMQ 使用

    安装步骤略过. 启动 启动很简单,找到安装后的 RabbitMQ 所在目录下的 sbin 目录,可以看到该目录下有6个以 rabbitmq 开头的可执行文件,直接执行 rabbitmq-server ...

  7. Python3.7.1学习(六)RabbitMQ在Windows环境下的安装

    Windows下安装RabbitMQ 环境配置 部署环境 部署环境:windows server 2008 r2 enterprise(本文安装环境Win7) 官方安装部署文档:http://www. ...

  8. SpringBoot系列之RabbitMQ使用实用教程

    SpringBoot系列之RabbitMQ使用实用教程 @ 目录 1. 消息队列概述 1.1 MQ的概述 1.2 MQ目的地形式 2. 消息队列实现方式 2.1 常见MQ框架 2.2 MQ实现方式 3 ...

  9. Docker中使用RabbitMQ

    安装Docker yum install docker //安装完成以后,可以查看一下docker的版本 docker -v //Docker version 1.13.1, build 64e998 ...

随机推荐

  1. bzoj 1132: [POI2008]Tro 计算几何

    题目大意: 平面上有N个点. 求出所有以这N个点为顶点的三角形的面积和 N<=3000 题解 我们看到了n的范围,于是我们就知道这一定不是一个线性算法 所以我们尝试枚举三角形的一个点,那么我们现 ...

  2. 使用Sublime编写HTML页面时发现,虽然已经设置好了UTF-8的编码格式,但却发现HTML页面的汉字仍然是乱码。

    相信有些同学在使用Sublime编写HTML页面时发现,虽然已经设置好了UTF-8的编码格式,但却发现HTML页面的汉字仍然是乱码吧.我今天就遇到了这样的问题. 第一步:重新设置一下你的meta,设置 ...

  3. PopupWindow --- 弹出底部窗体

    第一步 : 布局文件 <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:a ...

  4. C++11新标准

    1. 新类型 long long和unsigned long long: char16_t 和 char32_t: 新增原始字符串: 2. 统一的初始化 C++11扩大了用大括号括起的列表(初始化列表 ...

  5. <c和指针>学习笔记5动态内存分配和预处理器

    1 动态内存 比如声明数组得时候,我们需要提前预估数组长度,分配大了浪费,少了就更不好操作了.从而引入动态分配,需要的时候再分配. (1)malloc和free void *malloc(size_t ...

  6. Java堆内存划分

    根据对象的存活率(年龄)Java堆内存划分为3种,新生代,老年代,永久代: 1.新生代 比如我们在方法中区new一个对象,那这方法调用完毕后,对象就会被回收,这就是一个典型的新生代对象. 现在的商业虚 ...

  7. hdu1076

    #include<iostream> using namespace std; int main() { int cases; int k; cin>>cases; while ...

  8. Django 之 logging

    1. logging 1.1 什么是 logging logging 模块是 Python 内置的日志管理模块,不需要额外安装. 使用: import logging logging.critical ...

  9. 《Linux内核设计与实现》读书笔记(三)- Linux的进程

    进程是所有操作系统的核心概念,同样在linux上也不例外. 主要内容: 进程和线程 进程的生命周期 进程的创建 进程的终止 1. 进程和线程 进程和线程是程序运行时状态,是动态变化的,进程和线程的管理 ...

  10. [开发技巧]·Python极简实现滑动平均滤波(基于Numpy.convolve)

    [开发技巧]·Python极简实现滑动平均滤波(基于Numpy.convolve) ​ 1.滑动平均概念 滑动平均滤波法(又称递推平均滤波法),时把连续取N个采样值看成一个队列 ,队列的长度固定为N ...