时间:2021-05-02
今天挺高兴,项目终于上线使用。只是上线之前遇到的问题折磨得人精疲力尽。。。不过总算解决了。。在这把问题说出来,希望对有需要的朋友提供些帮助~~
项目:DOTNET项目,C#开发,主要功能是通过COM组件访问远程接口。
运行环境:Windows 2003 Server + IIS6.0 + .Net 1.1
问题:COM组件及系统在WINDOWS2000操作系统下都能正常使用,但迁移到WIN2003下,在程序调用组件时进程卡住了,有时会返回服务器出现意外情况的错误~
原因分析:首先,组件在其它操作系统下通过,说明组件应该没问题;注册COM组件及DOTNET项目引用方法均正确,而错误出现在调用组件这一步,而COM组件的功能就是通过IP地址及端口访问远程接口,这里注意有一个远程网络连接的工作;上网搜索类似问题,大部分文章都是组件的权限问题,我也根据文章所写设置了组件,IIS访问用户等的权限,都给予了最大权限,结果还是不行。。快崩溃了。。
解决方法:被这个问题折磨了几天之后,公司联系了微软客户支持,micro给了个方法,查看下IIS6.0里的应用程序池的安全性权限。查看了下,在IIS里的应用程序池属性中,“标识”标签下有个默认的安全性帐户“网络服务”即NetWork Service。Network Service 是 Windows Server 2003 中的内置帐户,其属于IIS_WPG 组,IIS_WPG 的成员具有适当的 NTFS 权限和必要的用户权限,按微软网站上的文章所说,Network Service 帐户具有充当 IIS 6 工作进程的进程标识的充足权限,以及具有访问网络的权限。但不知道为什么,这里的NetWork Service权限不够,造成不能调用组件访问远程接口。解决的方法就是将IIS_WPG帐户设置为读取与执行、列出文件夹目录、读取,而NETWORK SERVICE则需要完全控制权限。根据以上方法,我把NetWork Service赋于到Administrator组 ^_|| ,重启IIS,再运行程序,OK,正常调用组件了~~
因此如果有朋友再有碰到调用COM组件不能用时,考虑一下应用程序池的权限~~
参考以下文章: http://www.microsoft.com/china/technet/community/columns/insider/iisi1203.mspx
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
适用于Windows8.1或Server2012R2Windows8.1和Server2012R2上自带了一个PowerShell组件:“PrintManage
引言:.NETCore源码编译https://github.com/dotnetgitclonehttps://github.com/dotnet/runtim
一个ASP程序用到无组件上传,在本地XPSP3IIS5.1及在WindowsServer2003+IIS6.0上测试均为可以正常上传.到把程序放了windows
为了保护重要数据的安全,我们往往会给自己的计算机同时安装两块或两块以上的硬盘,然后借助Windows2000Server或Windows2003Server系统
一、什么是Windows远程桌面连接Windows远程桌面连接组件是从Windows2000Server开始由微软公司提供的,在WINDOWS2000SERVE