1. package cjf.mq.mqclient;
  2. import com.ibm.mq.MQC;
  3. import com.ibm.mq.MQEnvironment;
  4. import com.ibm.mq.MQException;
  5. import com.ibm.mq.MQGetMessageOptions;
  6. import com.ibm.mq.MQMessage;
  7. import com.ibm.mq.MQPutMessageOptions;
  8. import com.ibm.mq.MQQueue;
  9. import com.ibm.mq.MQQueueManager;
  10. import com.ibm.mq.MQGetMessageOptions;
  11. public class MQClient {
  12. static MQQueueManager qMgr;
  13. static int CCSID = 1381;//WINGBK,1208:UTF-8
  14. static String queueString = "MQ_QUEUE";
  15. public static void connect() throws MQException {
  16. MQEnvironment.hostname = "";
  17. MQEnvironment.channel = "java.channel";
  18. MQEnvironment.port = 1321;
  19. MQEnvironment.CCSID = CCSID;
  20. qMgr = new MQQueueManager("MQ_TEST");
  21. qMgr.disconnect();
  22. }
  23. public static void sendMsg(String msgStr) {
  24. int openOptions = MQC.MQOO_INPUT_AS_Q_DEF | MQC.MQOO_OUTPUT
  25. | MQC.MQOO_INQUIRE;
  26. MQQueue queue = null;
  27. try {
  28. // 建立Q1通道的连接
  29. queue = qMgr
  30. .accessQueue(queueString, openOptions, null, null, null);
  31. MQMessage msg = new MQMessage();// 要写入队列的消息
  32. msg.format = MQC.MQFMT_STRING;
  33. msg.characterSet = CCSID;
  34. msg.encoding = CCSID;
  35. // msg.writeObject(msgStr); //将消息写入消息对象中
  36. msg.writeString(msgStr);
  37. MQPutMessageOptions pmo = new MQPutMessageOptions();
  38. msg.expiry = -1; // 设置消息用不过期
  39. queue.put(msg, pmo);// 将消息放入队列
  40. } catch (Exception e) {
  41. // TODO Auto-generated catch block
  42. e.printStackTrace();
  43. } finally {
  44. if (queue != null) {
  45. try {
  46. queue.close();
  47. } catch (MQException e) {
  48. // TODO Auto-generated catch block
  49. e.printStackTrace();
  50. }
  51. }
  52. }
  53. }
  54. public static void receiveMsg() {
  55. int openOptions = MQC.MQOO_INPUT_AS_Q_DEF | MQC.MQOO_OUTPUT
  56. | MQC.MQOO_INQUIRE;
  57. MQQueue queue = null;
  58. try {
  59. queue = qMgr
  60. .accessQueue(queueString, openOptions, null, null, null);
  61. System.out.println("该队列当前的深度为:" + queue.getCurrentDepth());
  62. System.out.println("===========================");
  63. int depth = queue.getCurrentDepth();
  64. // 将队列的里的消息读出来
  65. while (depth-- > 0) {
  66. MQMessage msg = new MQMessage();// 要读的队列的消息
  67. MQGetMessageOptions gmo = new MQGetMessageOptions();
  68. queue.get(msg, gmo);
  69. System.out.println("消息的大小为:" + msg.getDataLength());
  70. System.out.println("消息的内容:\n"
  71. + msg.readLine());
  72. System.out.println("---------------------------");
  73. }
  74. } catch (Exception e) {
  75. // TODO Auto-generated catch block
  76. e.printStackTrace();
  77. } finally {
  78. if (queue != null) {
  79. try {
  80. queue.close();
  81. } catch (MQException e) {
  82. // TODO Auto-generated catch block
  83. e.printStackTrace();
  84. }
  85. }
  86. }
  87. }
  88. public static void main(String[] args) throws MQException {
  89. connect();
  90. sendMsg("fuck MQ");
  91. receiveMsg();
  92. }
  93. }

Java连接MQ的实例, 测试类的更多相关文章

  1. 功能完善的Java连接池调用实例

    /** * Title: ConnectPool.java * Description: 连接池管理器 * Copyright: Copyright © 2002/12/25 * Company: * ...

  2. 用Java发送HTML格式邮件测试类(支持中文)

    代码由纯Java写成,支持中文,一目了然,只要将Main函数中的相关信息填写正确就直接用了,便于修改,可以在此类基础上任意扩展成自己的类. 注意做HTML形式的邮件,最好把HTML,CSS都写全,只写 ...

  3. java连接mysql数据库实例

    做游戏客户端多一年多了,在大学学的java的SSH,基本上都忘完了,今天看了一下发现基本的连接数据库的都忘了...太可怕了这遗忘的速度. 所以写了个连接的例子吧..安装好mysql数据库之后新建了两张 ...

  4. java连接sqL2008 数据库实例

    package com.lzw; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSe ...

  5. java连接外部接口获取数据工具类

    package com.yqzj.util; import org.apache.log4j.LogManager;import org.apache.log4j.Logger; import jav ...

  6. Java导包后在测试类中执行正确但在Servlet中执行错误报ClassNotFoundException或者ClassDefNotFoundException解决办法

    将原来导的包remove from build path,并复制到Web-root下的lib目录中,再add to build path,

  7. SpringBoot测试类启动错误 java.lang.IllegalStateException: Unable to find a @SpringBootConfiguration, you need to use @ContextConfiguration or @SpringBootTest(classes=...) with your test

    报错 java.lang.IllegalStateException: Unable to find a @SpringBootConfiguration, you need to use @Cont ...

  8. 各种数据库连接代码的测试类(java)

    测试类: public class Mytest { Connection conn=null; Statement stmt=null; String myDriver="com.mysq ...

  9. 【JDBC】Java 连接 MySQL 基本过程以及封装数据库工具类

    一. 常用的JDBC API 1. DriverManager类 : 数据库管理类,用于管理一组JDBC驱动程序的基本服务.应用程序和数据库之间可以通过此类建立连接.常用的静态方法如下 static ...

随机推荐

  1. spring中使用quartz时注入时出现的错误

    错误1: 配置文件: <!-- 任务执行器的线程池 --> <bean id="taskExecutor" class="org.springframe ...

  2. NPM 与前端包管理

    我们很清楚,前端资源及其依赖管理一直是 npm 的重度使用场景,同时这也一直是 Node.js 普及的重要推动力.但这类应用场景到底有多重度?这是一个很难回答的问题.这份 “npm 最常下载的包的清单 ...

  3. [转]MSBuild Target Framework and Target Platform

    本文转自;https://msdn.microsoft.com/en-us/library/hh264221.aspx A project can be built to run on a targe ...

  4. Angular4 step by step.1

    1.官网地址 :https://angular.cn/guide/quickstart 2.在线学习地址:https://embed.plnkr.co/?show=preview 3.效果截图哇哈哈

  5. 一、mysql架构

    一.简介 mysql是一个开源的数据库管理系统,它相对于oracle更加地轻量.成本低,随着功能的日益完善,它变得备受企业喜爱,尤其是中小企业. mysql的整体架构大体包括以下几个方面: 1)主体结 ...

  6. 建一个springboot项目

    1.打开 https://start.spring.io/ 新建一个maven的demo,这里选择的是1.5.18的版本 2.将自动生成的demo导入eclipse,直接选中File里的import, ...

  7. 合理使用线程池 ThreadPool.QueueUserWorkItem()

    //==>自建线程 new Thread(() => { //线程任务 Console.WriteLine(Thread.CurrentThread.ManagedThreadId); } ...

  8. 配置Spring

    搭建Springmvc的时候,出现异常: IOException parsing XML document from ServletContext resource [/WEB-INF/applica ...

  9. AngularJS实现原理

    个人觉得,要很好的理解AngularJS的运行机制,才能尽可能避免掉到坑里面去.在这篇文章中,我将根据网上的资料和自己的理解对AngularJS的在启动后,每一步都做了些什么,做一个比较清楚详细的解析 ...

  10. mui ajax 应用的跨域问题

    1.首先在mui.ajax的error函数里出现: “syntaxerror unexpected token <” 这样的错误,那么在 mui.ajax中的type写成  JSONP ,后台需 ...