当前位置: 首页 > 图文教程 > 网络编程 > ASP.NET > 关于如何利用COM+,来提高ASP执行权限的问题!

ASP.NET
asp.net 产生随机颜色实现代码
asp.ent(C#)中判断空字符串的3种方法以及性能分析
asp.net 基于forms验证的目录角色权限的实现
ASP.NET 统计图表控件小结
asp.net 动态引用样式表代码
asp.net 获取IP的相关资料
真正的获取客户端真实IP地址及利弊分析
asp.net(c#)文件下载实现代码
asp.net 不用GridView自带删除功能,删除一行数据
asp.net forms身份验证,避免重复造轮子
asp.net 站点URLRewrite使用小记
asp.net Gridview行绑定事件新体会
asp.net MVC实现简单的上传功能
asp.net web.config加密解密方法
aspx实现的 jquery ui 的 flexgrid demo
ASP.NET Internet安全Forms身份验证方法
asp.net使用for循环实现Datalist的分列显示功能
jQuery AJax调用asp.net webservers的实现代码
ASP.NET 页面刷新和定时跳转代码整理
asp.net GridView控件鼠标移动某行改变背景颜色(方法一)

ASP.NET 中的 关于如何利用COM+,来提高ASP执行权限的问题!


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-11-03   浏览: 54 ::
收藏到网摘: n/a


我们知道,想在一个操作系统执行任何一个操作都是需要用户的。然后操作系统会检查该用户是否有权限执行这个操作的权限,如果有,就会执行,如果没,就会拒绝。这和我们浏览网站是一样的道理,当我们在客户端输入一串URL并执行时,其实是向服务端发送要浏览的请求,在操作系统来看,它也是一个操作,也是需要用户的。以windows为例,它是用:匿名访问 Internet 信息服务的内置帐户来执行这个操作的,所以如果你的网页文件如果去掉这个用户(通常是EVERYONE或者是USERS)的权限,就会跳出对话框,要求输入用户名和密码。

但是在实际情况中,我们经常有遇到这样的问题:如何用匿名访问 Internet 信息服务的内置帐户执行它更高的权限。这样说可能很难理解,用实例来说。比如:我们在网站上(匿名访问的那种)做了一个申请用户的功能,也就是说要在ASP代码中建用户,而且是WINDOWS里的用户,不是数据库中的用户。但是,如果要建用户就要到administrators组的权限,很明显,我们不可能把,匿名访问 Internet 信息服务的内置帐户 添加到administrators组里。那么我该如何去做呢?

这个时候就可以用到COM+(当然COM+的好处不只如此),用VB或者VC做一个DLL,里面有新建用户的功能,然后开一个接口出来。然后注册该DLL,把它加到COM+里。

具体操作是:
开始->程序->管理工具->组件服务->组件服务->计算机->我的电脑->COM+应该程序->右击新建->应用程序->下一步->创建一个空的应用程序->输入名称(随便)->选择服务器应用程序->下一步->选择此用户->输入有administrators组里的用户和密码->完成!

接下来,在应用程序下就有刚才建好的应用程序名称,在它的下一级,有一个组件,右击它,新建组件,把自己做好的已经注册的DLL导入进去就可以了!

最后,就是如何在ASP里引用了,其实和引用其它的DLL是一样的,set obj=server.CreateObject("") ,执行那个接口就可以了!本人也在学习当中,希望大家一起交流,如有什么错误请及时指出!