- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我想使用来自PHP应用程序(脚本)的SSL身份验证连接到WebSphere MQ队列。
队列管理器版本为7.0或7.5
MQ客户端版本是8.0
PHP版本是7.0(docker)
使用PHP mqseries pecl扩展v0.15(带有自定义修复程序)
到目前为止,我能够在没有SSL连接的情况下进行连接。
到目前为止,这是我必须执行的步骤:
我已经安装了适用于Linux的WebSphere MQ Client v8(以我的情况为CentOS)
我已经下载了mqseries php扩展的PECL 0.15版本。 (扩展中有一个小错误,我不得不重新编译它才能使其正常工作。我以前在MQGET上遇到了分段错误)。
我将mqseries.so链接到php并启用了扩展名。
我成功(没有SSL)
连接到队列管理器
打开队列进行阅读
获取队列中的消息
关闭连接
当我在脚本中将USE_SSL
设置为true时,我收到错误代码2393,表示“ An MQCONN or MQCONNX call was issued with SSL configuration options specified, but an error occurred during the initialization of the SSL environment.
”。此错误消息非常通用,无法帮助我指出问题出在哪里。MQ_KEYSTORE
设置为/path/to/my/key
,我的文件名是key.kdb
,并且具有与该documentation建议的级别相同的key.sth
脚本中的MQ_SSL_CIPHER_SPEC
与在队列管理器上为指定的MQ_CHANNEL_SSL
指定的相同。多次检查。这些不是与JMS连接一起使用的Cipher Suite
安全高速缓存已在队列管理器上刷新。
在服务器端,我检查了队列管理器的错误日志,但似乎没有看到我的频道名称。我之所以说“似乎”,是因为有很多杂音,并且其中很多???
频道名称。所以我觉得它由于某种原因没有到达队列管理器。
我还使用了在MQ Client安装bin文件夹中找到的“ amqssslc
”命令来测试我的ssl配置。与使用PHP脚本相比,我得到了相同的错误。
我还使用WireShark在相应的MQ_PORT
上嗅探数据包。软件包的内容包含证书信息。因此,有些事情看起来像是SSL握手。
我现在对如何调试外壳一无所知。有谁知道下一步要检查什么?我应该检查MQ Client安装上的连接日志吗?
这是connection using SSL in PHP的示例
这是我的MQ脚本的简化版本(我删除了输出)。为了安全起见,未公开某些常量。
所有MQSERIES_ *常量都在扩展名中定义
所有MQ_ *都是用于测试我的脚本的硬编码参数,但是它们的定义未出现在脚本摘录中。
<?php
// Constants defined here
$options = [
'Version' => MQSERIES_MQCNO_VERSION_4,
'Options' => MQSERIES_MQCNO_STANDARD_BINDING,
'MQCD' => [
'Version' => 7,
'ChannelName' => MQ_CHANNEL,
'ConnectionName' => sprintf('%s(%s)', MQ_HOST, MQ_PORT),
'TransportType' => MQSERIES_MQXPT_TCP,
]
];
if (USE_SSL) {
$options['MQSCO'] = [
'KeyRepository' => MQ_KEYSTORE
];
$options['MQCD']['ChannelName'] = MQ_CHANNEL_SSL;
$options['MQCD']['SSLCipherSpec'] = MQ_SSL_CIPHER_SPEC;
}
mqseries_connx(MQ_QUEUE_MANAGER, $options, $conn, $comp_code, $reason );
$mqods2 = [
'ObjectType' => MQSERIES_MQOT_Q,
'ObjectName' => MQ_QUEUE
];
mqseries_open($conn, $mqods2, MQSERIES_MQOO_INPUT_AS_Q_DEF | MQSERIES_MQOO_FAIL_IF_QUIESCING, $obj, $comp_code, $reason);
$gmd = [];
$gmo = [
'Options' => MQSERIES_MQGMO_FAIL_IF_QUIESCING | MQSERIES_MQGMO_WAIT, 'WaitInterval' => 3000
];
$msg = "";
$data_length = "";
for ($i = 0; $i < 1000; $i++) {
mqseries_get($conn, $obj, $gmd, $gmo, 10000, $msg, $data_length, $comp_code, $reason);
if ($reason === 2033) {
printf("No more messages to process\n");
break;
}
// Business logic
}
mqseries_disc($conn, $comp_code, $reason);
?>
For queue managers and clients respectively, the following sources are searched in sequence for a non-empty value. The first non-empty value determines the certificate label. The certificate label must exist in the key repository. If no matching certificate in the correct case and format is found that matches a label, an error occurs and the SSL or TLS handshake fails.
”
The certificate label cannot contain spaces.
”。
ibmwebspheremq<user_that_runs_the_php_process>
是否实际上影响了有效性。
ikeycmd
,该工具基本上在命令行上提供了相同的功能(减去错误)。要运行该命令,您需要IBM jre(未验证,需要检出)并以
java com.ibm.gsk.ikeyman.ikeycmd
身份运行它。从这里开始,IBM网站上提供了有关如何创建证书,重命名标签,检查详细信息等的大量文档。无数的乐趣!
最佳答案
完整安装IBM MQ客户端后,客户端错误将记录到以下目录:/var/mqm/errors
错误(如果有的话)将记录到文件AMQERR01.LOG
中(它将与另外两个以02
和03
结尾的文件一起轮换。如果错误是MQ所不希望的,它也可能会创建一个以结尾的文件.FDC
以及其他详细信息。
如果在客户端发送通道名称之前进行通道协商期间连接失败,则队列管理器将记录通道名称???
。如果IBM MQ队列管理器正在使用v7.5或更低版本,则直到TLS握手完成后才交换通道名称。
在v8和更高版本的客户端连接到v8和更高版本的队列管理器的情况下,MQ将在TLS协商期间使用TLS SNI交换通道名称,但是我不确定MQ是否也得到了增强,可以记录此通道名称,在以前的版本中它记录的
检查您的客户端
???
是否具有私钥。 MQ使用三种方式来标识要使用的私钥。
在MQ Client v7.5和更早版本中,私钥的标签必须为:
ibmwebspheremq<user_that_runs_the_php_process>
AMQ_SSL_ALLOW_DEFAULT_CERT=1
key.kdb
的
CertificateLabel=anylabelvalue
节中使用
SSL
。下面的例子:
SSL:
CertificateLabel=anylabelvalue
mqclient.ini
设置记录在IBM MQ v8 KC页面“
SSL stanza of the client configuration file”中。
CertificateLabel
复制
mqclient.ini
的模板,并将其放在应用程序执行所在的目录中。也可以通过环境变量指定该位置,如果未设置该变量并且在应用程序执行的同一目录中找不到该变量,则MQ会在文件的其他几个位置中查找。 MQ查找该文件的各种方式记录在IBM MQ v8 KC页面“
Location of the client configuration file”中
关于php - 如何在PHP中使用SSL认证连接到WebSphere MQ队列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46084567/
我在网上搜索但没有找到任何合适的文章解释如何使用 javascript 使用 WCF 服务,尤其是 WebScriptEndpoint。 任何人都可以对此给出任何指导吗? 谢谢 最佳答案 这是一篇关于
我正在编写一个将运行 Linux 命令的 C 程序,例如: cat/etc/passwd | grep 列表 |剪切-c 1-5 我没有任何结果 *这里 parent 等待第一个 child (chi
所以我正在尝试处理文件上传,然后将该文件作为二进制文件存储到数据库中。在我存储它之后,我尝试在给定的 URL 上提供文件。我似乎找不到适合这里的方法。我需要使用数据库,因为我使用 Google 应用引
我正在尝试制作一个宏,将下面的公式添加到单元格中,然后将其拖到整个列中并在 H 列中复制相同的公式 我想在 F 和 H 列中输入公式的数据 Range("F1").formula = "=IF(ISE
问题类似于this one ,但我想使用 OperatorPrecedenceParser 解析带有函数应用程序的表达式在 FParsec . 这是我的 AST: type Expression =
我想通过使用 sequelize 和 node.js 将这个查询更改为代码取决于在哪里 select COUNT(gender) as genderCount from customers where
我正在使用GNU bash,版本5.0.3(1)-发行版(x86_64-pc-linux-gnu),我想知道为什么简单的赋值语句会出现语法错误: #/bin/bash var1=/tmp
这里,为什么我的代码在 IE 中不起作用。我的代码适用于所有浏览器。没有问题。但是当我在 IE 上运行我的项目时,它发现错误。 而且我的 jquery 类和 insertadjacentHTMl 也不
我正在尝试更改标签的innerHTML。我无权访问该表单,因此无法编辑 HTML。标签具有的唯一标识符是“for”属性。 这是输入和标签的结构:
我有一个页面,我可以在其中返回用户帖子,可以使用一些 jquery 代码对这些帖子进行即时评论,在发布新评论后,我在帖子下插入新评论以及删除 按钮。问题是 Delete 按钮在新插入的元素上不起作用,
我有一个大约有 20 列的“管道分隔”文件。我只想使用 sha1sum 散列第一列,它是一个数字,如帐号,并按原样返回其余列。 使用 awk 或 sed 执行此操作的最佳方法是什么? Accounti
我需要将以下内容插入到我的表中...我的用户表有五列 id、用户名、密码、名称、条目。 (我还没有提交任何东西到条目中,我稍后会使用 php 来做)但由于某种原因我不断收到这个错误:#1054 - U
所以我试图有一个输入字段,我可以在其中输入任何字符,但然后将输入的值小写,删除任何非字母数字字符,留下“。”而不是空格。 例如,如果我输入: 地球的 70% 是水,-!*#$^^ & 30% 土地 输
我正在尝试做一些我认为非常简单的事情,但出于某种原因我没有得到想要的结果?我是 javascript 的新手,但对 java 有经验,所以我相信我没有使用某种正确的规则。 这是一个获取输入值、检查选择
我想使用 angularjs 从 mysql 数据库加载数据。 这就是应用程序的工作原理;用户登录,他们的用户名存储在 cookie 中。该用户名显示在主页上 我想获取这个值并通过 angularjs
我正在使用 autoLayout,我想在 UITableViewCell 上放置一个 UIlabel,它应该始终位于单元格的右侧和右侧的中心。 这就是我想要实现的目标 所以在这里你可以看到我正在谈论的
我需要与 MySql 等效的 elasticsearch 查询。我的 sql 查询: SELECT DISTINCT t.product_id AS id FROM tbl_sup_price t
我正在实现代码以使用 JSON。 func setup() { if let flickrURL = NSURL(string: "https://api.flickr.com/
我尝试使用for循环声明变量,然后测试cols和rols是否相同。如果是,它将运行递归函数。但是,我在 javascript 中执行 do 时遇到问题。有人可以帮忙吗? 现在,在比较 col.1 和
我举了一个我正在处理的问题的简短示例。 HTML代码: 1 2 3 CSS 代码: .BB a:hover{ color: #000; } .BB > li:after {
我是一名优秀的程序员,十分优秀!