爱东东

VS.NET,IT,个人,个人网站 爱东东 http://www.idongdong.net

 

Windows服务MQ之拒绝访问错误

设定两个应用程序,应用程序A是Web应用,应用程序B是Windows服务。
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时也可以引用这种思路。

posted on   爱东东  阅读(1170)  评论(1编辑  收藏  举报

导航

点击右上角即可分享
微信分享提示