Windows服务MQ之拒绝访问错误 - 爱东东
Windows服务MQ之拒绝访问错误
A应用生成名为C的MSMQ(如果存在则引用C),并向C中插入记录。
B应用生成名为C的MSMQ(如果存在则引用C),并从C中读取记录。
两个应用和消息队列在同一台服务器上。
两个应用程序启动时出现如下症状:
在C不存在的情况下。
当A应用先启动,B应用再启动时,正常。
当B应用先启动,A应用再启动时,A无法读取C。出现拒绝访问错误。而且Administrator手工也无法删除C。
查看正常情况下和错误情况下的C的安全信息。发现创建者不同。这个错误是权限原因造成。
在创建或引用MQ的时候加入如下代码(红色部分)。
MessageQueue mq=null;
if(MessageQueue.Exists(@”.\Private$\”+MQName)==false)
{
mq=MessageQueue.Create(@”.\Private$\”+MQName,true);
mq.SetPermissions(“Everyone”,MessageQueueAccessRights.FullControl);
}
else
{
mq=new MessageQueue(@”.\Private$\”+MQName);
}
mq.Formatter = new BinaryMessageFormatter();
红色部分的意思是,当应用程序是Asp.net应用时(WEB应用)-这时的用户是ASPNET,系统默认建立的消息队列是Everyone完全控制的。如果是Windows服务或WinForm应用创建的-这时的用户不是ASPNET是System或Administrator,系统建立消息队列是需要对Everyone赋权。
以上是针对Asp.net的情况,其他的Web应用在与Windows应用竞争MSMQ时也可以引用这种思路。