在使用DCOM的情况下,最好不要将win98作为三层的服务器。那样配置起来非常复杂。
建议如果一定要用win98作为服务器,那么需要最好用socketconnection.

解决方案 »

  1.   

    你的机子(98)装了DCOM没有
    如果没有的话就不行了
        DCOM中应用程序的分发    客户端的分发和设定    1。如果是使用独立的EXE文件,那么必须拷贝所有的EXE档案以及这些档案使用的OCX,DLL到客户端。你可以使用DELPHI内建的INSTALLSHIELD制作安装磁盘。如果是使用ACTIVEFORM,那么就无需安装客户端的应用程序,因为ACTIVEFORM可以自动的下载到客户端。    2。在客户端机器中必须安装DCOM。    3。拷贝MIDAS。DLL档案到客户端的Windows\System或是Winnt\System32子目录中。你只需要拷贝这个档案到Windows的系统子目录下即可,当客户端应用程序执行时,它会自动注册这个档案到注册表中    服务端的分发和设定    在多层应用系统中,分发服务比较复杂。        1。决定使用存取控制的权限。如果你有WINDOWS NT做为应用程序服务器的平台,那么建议使用‘用户级存取控制’    2。执行应用程序服务器一次以注册应用程序服务器。    3。拷贝MIDAS。DLL到系统子目录中。而且必须注册。你可以使用TREGSRV32来注册MIDAS。DLL    4。拷贝IDPROV32.DLL到BDE数据库引擎的子目录中。    5。使用DCOMCNFG设置应用程序服务器的存取权限。在通常情况下,可以将验证等级设定为‘无’,并且把存取控制和激活控制设置为EVERYONE就可以让所有的客户端用户激活和存取应用程序服务器。    6。如果目前使用的DCOM是对于95的话,强烈建议你升级到98,否则程序员必须自行激活RPCSS。EXE    至此,分发过程已经结束,如果还有问题,请使用DELPHI5的MODULE VIEWER来观察。当程序员使用DELPHI开发分布式多层应用系统后,除了将应用程序序列分发之外,还必须使用DCOM的配置应用程序DCOMCNFG.EXE来进行设置。    在WIN9.X系列中进行DCOM之前,应确认是否装有DCOM,如果没有,可从WWW.Microsoft.com下载。    WIN9.X配置为DCOM服务器    第一步就是将访问控制设置为用户级控制。在‘获取用户及组的列表中’输入该局域网中能提供安全权限的机器名(该计算机必须正在运行)。    第二步就是运行位于系统目录下的\windows\system\Dcomcnfg.exe文件。在应用程序列表中应该能够找到你所编制的应用程序,如果没有列出,请将你所编的程序运行一次。    通常,我们可以通过修改默认属性及默认安全性来达到一定的目的,在‘默认属性’页中,让‘启动该计算机的分布式COM’选项选中,而‘默认的身份验证级别’中‘连接’的意思代表‘只在客户端第一次连结应用程序服务器时检查客户端的权限’。    ‘默认的模拟级别’中‘识别’的意义为‘在这种模式下,服务端可以取得连结的客户端的权限信息,但是服务端无法以连结的客户端的权限存取系统对象’。当其设为‘模拟’时,表明‘服务端可以取得连结的客户端的权限信息,并且能够以连结的客户端的权限存取系统对象’。    在默认属性页中,还有一个‘为跟踪引用提供附加的安全性’的选项。这个设置可以让应用程序服务器使用COM/DCOM的回叫机制以保持COM/DCOM中远程调用参考计数值(reference count)的正确性,以避免客户端应用程序恶意的调用应用服务器并且断线。选中这个选项可以让应用程序服务器有效的管理其生命周期,但是也会减缓应用程序服务执行的速度。    上述的内容其实在DCOMCNFG的帮助之中都有,我这番解说有些画蛇添足,但我对它配置的建议就是,尽量使用默认值。   在NT中的一些配置也极其相似。但要理解以下的概念    激活控制:就是指哪些用户可以激活应用程序服务器。当客户端应用程序执行并且试着在远程机器之中激活应用程序服务器时,COM/DCOM的安全机制会检查这个客户端应用程序登录的用户是否有权限中以激活应用程序。   存取控制:指当应用程序服务器由适当的用户激活后,哪些用户可以存取应用程序服务器所提供的服务。此外,一个应用程序服务器可以提供数种不同的服务,取存控制能够限定特定的用户进行特定的操作   认证控制:是指在数据进行传递时,数据是否加密   鉴定控制:是指应用程序服务器的权限。即指在服务器上登陆的用户,他所执行的应用程序服务器所存取的资源是否在他的权限范围之内。你也要在Y机器上配置服务器首先你要给其他的机器一个登陆名,也就是能直接访问你的机器才行呀
    其次你要配置dcomcnfg才行呀
    在开始-》运行-》dcomcnfg就可以进入配置截面了
    配置方法:
       
      如果在Windows NT环境下正常运行应用服务器,必须进行DCOM配置。配置方法如下:  1.运行NT服务器上的dcomcnfg程序,进行DCOM配置。  2.进入DCOM的总体默认属性页面,将“在这台计算机上启用分布式COM”打上勾,将默认身份级别改为“无”。  3.进入DCOM的总体默认安全机制页面,确认默认访问权限和默认启动权限中的默认值无EveryOne,如果不去掉EveryOne,应用服务器不能正常启动。  4.在常规页面中,双击你的应用服务器,打开你的应用服务器DCOM属性设置。  5.将常规页面中的身份验证级别改为“无”。  6.位置页面中选上“在这台计算机上运行应用程序”。  7.将安全性页面设置中,均选择“使用自定义访问权限”,编辑每一个权限,将EveryOne加入用户列表中。  8.身份标识页面中,选择“交互式用户”。  9.NT的GUEST用户不能禁用。不要太多了相信对你有用
    给分吧:)
     
      

  2.   

    to:chechy(我爱洁洁) 
       那我刚才用一台WIN XP做服务端,但提示的是:
      拒绝访问。
      

  3.   

    需要用dcomcnfg设置DCOM的权限。总之用DCOM配置三层的权限非常复杂。
      

  4.   

    用Socket连接很简单的,但服务器需要运行scktsrvr.exe
      

  5.   

    taxi(游少爷) :
      就因为省事,我才没用Socket,
      

  6.   

    需要用dcomcnfg设置DCOM的权限。总之用DCOM配置三层的权限非常复杂。
      

  7.   

    用socket一样的呀!就是上速度上有点慢!呵呵
      

  8.   

    只在把delphi6/bin/下面的scktsrvr.exe文件拷贝到服务器端,并运行它就可以了,速度不会有影响
      

  9.   

    scktsrvr.exe是个很好的工具,可以用它监控登陆的客户情况
      

  10.   

    DCOM是否就是SYSTEM或SYSTEM32下的DCOMCNFG。EXE文件?