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. 我是怎么一步步用go找出压测性能瓶颈

    欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 本文由mariolu 发表于云+社区专栏 序言: ​ 笔者要在线上服务器load日志并且重放来测一些机器性能指标.模拟机器资源比较少,相对的 ...

  2. 游戏开发者注意!这个音频SDK可以完美兼容所有主流游戏引擎

    欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 本文由腾讯游戏云 发表于云+社区专栏 在网络游戏中,无论是大逃杀.棋牌类.电子竞技类还是娱乐休闲类小游戏,玩家和玩家之间的互动.语音聊天是一 ...

  3. CentOS7 防火墙操作

    1.firewalld的基本使用 启动: systemctl start firewalld 关闭: systemctl stop firewalld 查看状态: systemctl status f ...

  4. 持续集成工具TeamCity配置使用

    持续集成CI(Continuous Integration)主要包括自动化的编译.发布和测试集成,对于我们信息系统项目开发非常有用.一般开发人员机器上会搭建自己的开发环境,整个项目在服务器上会搭建测试 ...

  5. Xcode插件路径、缓存路径、图片压缩工具路径、代码片段路径、symbolicatecrash路径

    Xcode插件路径 ~/Library/Application\ Support/Developer/Shared/Xcode/Plug-ins   Xcode缓存路径 ~/Library/Devel ...

  6. Access入门 2010,数学

    Access入门 2010(高级窗体) 1,创建数据透视图:创建---其他窗体---数据透视图---图标字段列表---选择列表内容---移动到数据透视图的对应位置---完成. 2,创建数据透视表窗体: ...

  7. element ui tabl 输出Html

    在使用element ui的表格的时候有遇到过表格中的数据需要换行的问题,数据是由后台传回的包含分隔符的字符串,在尝试过使用slot和直接输出html后并不能实现 解决方法:使用column的form ...

  8. 6、springboot之根目录设置

    访问的时候用

  9. .net项目常用的库

    1.单元测试框架 Microsoft.VisualStudio.QualityTools.UnitTestFramework.dll 2.Entity Framework 框架

  10. Dockerfile定制镜像

    一.Dockerfile是什么? 镜像定制实质就是定制每一层所添加的配置.文件. Dockerfile就是一个脚本来构建和定制镜像,把每一层的修改.安装.构建.操作都写入脚本.以此来解决体积.镜像构建 ...