参见:http://www.phpnotes.top/2017/12/06/php/111/
前提
需要手动在php.ini中开启
[COM_DOT_NET]
extension=php_com_dotnet.dll
COM配置项
名字 | 默认 | 可修改范围 | 更新日志 |
---|---|---|---|
com.allow_dcom | "0" | PHP_INI_SYSTEM | 自 PHP 4.0.5 起可用 |
com.autoregister_typelib | "0" | PHP_INI_ALL | 在 PHP 4 中是 PHP_INI_SYSTEM。自 PHP 4.1.0 起可用 |
com.autoregister_verbose | "0" | PHP_INI_ALL | 在 PHP 4 中是 PHP_INI_SYSTEM。自 PHP 4.1.0 起可用 |
com.autoregister_casesensitive | "1" | PHP_INI_ALL | 在 PHP 4 中是 PHP_INI_SYSTEM。自 PHP 4.1.0 起可用 |
com.code_page | "" | PHP_INI_ALL | 自 PHP 5.0.0 起可用 |
com.typelib_file | "" | PHP_INI_SYSTEM | 自 PHP 4.0.5 起可用 |
com.allow_dcom
如果打开此选项,PHP 将被允许以一个 D-COM(Distributed COM)客户方式操作并允许 PHP 脚本在远程服务器上实例化 COM 对象
com.autoregister_typelib
当打开这个时,PHP将尝试从它实例化的对象类型库中注册常量,如果这些对象实现了获取该信息所需的接口。它所注册的常量的情况敏感性由配置指令控制
com.autoregister_verbose
当打开这个程序时,在对象实例化过程中加载类型库的任何问题都将使用PHP错误机制来报告。缺省值是off,如果出现错误查找或加载类型库,则不会发出任何指示
com.autoregister_casesensitive
当打开这个(默认值)时,在自动加载的类型库中发现的常量将会大小写敏感地注册,点击com_load_typelib()查看更多的细节
com.code_page
它控制在从COM对象传递字符串时使用的默认字符集代码页。如果设置为空字符串,PHP将假定您想要CP_ACP,它是默认系统ANSI代码页。
如果脚本中的文本使用默认设置的不同编码/字符集进行编码,那么设置该指令将使您不必将代码页作为参数传递给COM类构造函数。请注意,通过使用这个指令(和任何PHP配置指令一样),您的PHP脚本变得更不便于携带;您应该尽可能使用COM构造函数参数
com.typelib_file
设置时,该文件应该包含一个文件,该文件包含应该在启动时加载的类型库列表。文件的每一行将被视为类型库名称,并像您调用com_load_typelib()那样加载。常量将持续地注册,以便库只需要加载一次。如果类型库的名称以字符串# cis或#case_insensitive结束,那么该库中的常量将以不区分大小写的方式注册
预定义常量
可以通过get_defined_constants(true)查看具体值,
The COM class
COM类允许实例化一个OLE兼容的COM对象并调用其方法并访问其属性。
$obj = new COM("Application.ID");
COM::__construct ( string $module_name
[, mixed $server_name
[, int $codepage
[, string $typelib
]]] )
COM类构造函数。参数有以下含义
module_name
可以用一个ProgID、类ID或Moniker,当作module_name进行加载组件。ProgID通常是应用程序或DLL名称,然后是一个句点,然后是对象名称。类似:Word.Application。类ID是唯一标识给定类的UUID。Moniker是一种特殊的命名形式,类似于URL scheme的概念,它标识一个资源并指定如何加载它。作为一个示例,您可以加载Word并通过指定Word文档的完整路径作为模块名称来表示Word文档,或者您可以使用LDAP:作为使用ADSI接口到LDAP的名字