zoukankan      html  css  js  c++  java
  • 查询rabbitmq

    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;
        }
    }
  • 相关阅读:
    AX2009直接交运的bug
    数据库日志
    新蛋中国最新的分类导航,右侧展开菜单,可以修改向左或者向右展开
    用图片代替滚动条的代码
    新蛋网的大图展示效果,缩略图点击显示大图,上一个下一个
    Banner 切换,大小图不同,支持FF和OPERA,IE系列
    下拉菜单,支持所有浏览器
    电容选型
    000.数字电子技术分类
    Altium design16设计技巧
  • 原文地址:https://www.cnblogs.com/tonggc1668/p/6824962.html
Copyright © 2011-2022 走看看