注册筛选器处理程序
必须注册筛选器处理程序。 还可以通过注册表或使用 ILoadFilter 接口找到给定文件扩展名的现有筛选器处理程序。
本主题按如下所示进行组织:
注意
筛选器处理程序是 IFilter 接口的实现。
注册用于Windows搜索的筛选器处理程序
下表列出了注册新协议处理程序或查找现有协议处理程序所需的 GUID。
| GUID | 定义用户或应用程序 | 说明 |
|---|---|---|
| 89BCB740-6119-101A-BCB7-00DD010655AF | 应用程序 | IFilter 接口 GUID 是所有筛选器处理程序的注册表项常量。 |
| {PersistentHandlerGUID} | User | 这是永久性处理程序的 GUID。 |
| {FilterHandlerCLSID} | User | 这是筛选器处理程序 (CLSID) 的类标识符。 |
| {ApplicationGUID} | User | 这是一个中间 (聚合) GUID。 |
筛选器处理程序必须在HKEY_LOCAL_MACHINE中注册,因为SearchFilterHost.exe在 SYSTEM 帐户下运行,因此无法访问登录用户的HKEY_CURRENT_USER的注册表项。 此外,用户组必须具有对筛选器处理程序.dll本身的读取和执行访问权限,因为SearchFilterHost.exe删除所有管理员权限并仅允许非管理员权限。 由于默认Visual Studio项目位置位于当前用户的目录中,因此不向用户组授予读取权限,因此必须移动.dll或更改 ACL 以允许SearchFilterHost.exe访问。
注册新的筛选器处理程序时,建议使用描述性名称,例如 HTML IFilter。
注册新的筛选器处理程序:
- 指定将使用筛选器处理程序的扩展和持久性处理程序 GUID:
HKEY_LOCAL_MACHINE
Software
Classes
.txt
PersistentHandler
(Default) = {PersistentHandlerGUID}
HKEY_LOCAL_MACHINE
Software
Classes
CLSID
{PersistentHandlerGUID}
PersistentAddinsRegistered
{89BCB740-6119-101A-BCB7-00DD010655AF}l
(Default) = {FilterHandlerCLSID}
- 使用以下键和值注册筛选器处理程序:
HKEY_LOCAL_MACHINE
Software
Classes
CLSID
{FilterHandlerCLSID}
(Default) = {DescriptiveFilterHandlerName}
InprocServer32
(Default) = DLL Install Path
ThreadingModel = Both
用于注册筛选器处理程序的过时方法
不建议使用此方法。 可以为表示组件对象模型 (COM) 类和/或文件扩展名的 CLSID 注册筛选器。 如果需要为类注册筛选器处理程序,以及类中文件扩展名的其他筛选器处理程序,则可以注册这两个筛选器。 请注意,为文件扩展名注册的筛选器处理程序优先于 CLSID 的筛选器处理程序。
这些条目是标准 OLE 注册表项,最多包括类 CLSID\{ApplicationGUID} 的条目。 DLL sample.dll实现.txt类的运行对象行为。 请注意额外的条目 PersistentHandler。 此条目指定负责向示例类的持久对象中转站请求的类。 PersistentAddinsRegistered 下的条目标识负责名为 89BCB740-6119-101A-BCB7-00DD010655AF (IID_IFilter) 的接口的实现。 实现 IID_IFilter 的类具有标准的 OLE 注册表项。 InprocServer32 DLL 通过标准 OLE 机制加载。
Windows搜索观察为筛选器处理程序指定的线程模型。 当线程模型设置为 “两者”时,筛选器处理程序必须是线程安全的;否则,如果不是线程安全,请指定 “单元”。 请注意,筛选器处理程序应始终是线程安全的。
以下示例注册表项适用于为类和文件扩展名注册的筛选器处理程序。 {PersistentHandlerGUID} 和 {FilterHandlerCLSID} 用作指示筛选器处理程序创建者需要指定的值的变量。 这些值的类型为 REG_SZ。
HKEY_LOCAL_MACHINE
Software
Classes
.txt
(Default) = SampleFile
SampleFile
(Default) = Class for Sample Files
CLSID
(Default) = {ApplicationGUID}
CLSID
{ApplicationGUID}
(Default) = Sample Files
InprocServer32
(Default) = sample.dll
PersistentHandler
(Default) = {PersistentHandlerGUID}
{PersistentHandlerGUID}
(Default) = Sample file persistent handler
PersistentAddinsRegistered
{89BCB740-6119-101A-BCB7-00DD010655AF}l
(Default) = {FilterHandlerCLSID}
{FilterHandlerCLSID}
(Default) = Sample Files
InprocServer32
(Default) = sampfilt.dll
ThreadingModel = Both
替换现有筛选器处理程序
建议不要替换常见文件类型的内置筛选器处理程序,例如.txt、.doc、.html、.url 等,因为这样做可能会对其他系统组件产生意外的影响。 例如,为电子邮件正文编制索引取决于.txt、.html和 .rtf 筛选器处理程序。
如果正在将文件类型的新筛选器处理程序安装为现有筛选器注册的替代程序,安装程序应保存当前注册,并在卸载新筛选器处理程序时还原它。 没有链接筛选器的机制。 因此,新筛选器处理程序负责复制旧筛选器的任何必要功能。
查找给定文件扩展名的筛选器处理程序
可以使用 ILoadFilter 接口查找给定文件扩展名的筛选器处理程序。 以下示例注册表项说明了如何对 HTML 文件执行此操作。 在此示例中,HTML 文档的筛选器处理程序nlhtml.dll。 这些值的类型为 REG_SZ。
若要查找给定文件扩展名的筛选器处理程序,请执行以下操作:
- 检查筛选的文件类型的扩展名是否在注册表项 \HKEY_LOCAL_MACHINE\SOFTWARE\Classes.extension 下注册了持久性处理程序。 如果是,请让此密钥为 {PersistentHandlerGUID}。
HKEY_LOCAL_MACHINE
SOFTWARE
Classes
.htm
PersistentHandler
{PersistentHandlerGUID}
- 如果没有为扩展注册的持久性处理程序,请在注册表项 \HKEY_LOCAL_MACHINE\SOFTWARE\Classes 下找到与文档类型关联的 CLSID。 让此密钥为 {ApplicationGUID}。 然后确定是否为 CLSID 注册永久性处理程序:使用 {ApplicationGUID} 查找 \HKEY_LOCAL_MACHINE\SOFTWARE\Classes\CLSID\{ApplicationGUID} 项的永久性处理程序。 让此密钥为 {PersistentHandlerGUID}。
HKEY_LOCAL_MACHINE
SOFTWARE
Classes
htmlfile
(Default) = Class for WWW HTML files
CLSID
(Default) = {25336920-03F9-11CF-8FD0-00AA00686F13}
CLSID
{25336920-03F9-11CF-8FD0-00AA00686F13}
PersistentHandler
(Default) = {PersistentHandlerGUID}
- 确定永久性处理程序的 GUID:使用 {PersistentHandlerGUID} 查找文档类型的持久处理程序 GUID。 注册表项下的值HKEY_LOCAL_MACHINE\SOFTWARE\Classes\CLSID\{PersistentHandlerGUID}\PersistentAddinsRegistered\ 89BCB740-6119-101A-BCB7-00DD010655AF 生成此文档类型的持久处理程序 GUID。 让此密钥为 {FilterHandlerCLSID}。
HKEY_LOCAL_MACHINE
SOFTWARE
Classes
{PersistentHandlerGUID}
(Default) = HTML File Persistent Handler<dl>
REG_SZ {89BCB740-6119-101A-BCB7-00DD010655AF}
REG_SZ (Default) = {EEC97550-47A9-11CF-B952-00AA0051FE20}
- 确定筛选器处理程序:使用在上一步中确定的 {FilterHandlerCLSID} 在条目 \HKEY_LOCAL_MACHINE\SOFTWARE\Classes\CLSID\{FilterHandlerCLSID}\InprocServer32下找到筛选器处理程序。 在此示例中,使用的描述性筛选器处理程序名称是 HTML IFilter。
HKEY_LOCAL_MACHINE
SOFTWARE
Classes
CLSID
{EEC97550-47A9-11CF-B952-00AA0051FE20}
(Default) = HTML IFilter
Data type REG_SZ
InprocServer32
nlhtml.dll
其他资源
- GitHub上提供的IFilterSample 代码示例演示如何创建用于实现 IFilter 接口的 IFilter 基类。
- 有关索引过程的概述,请参阅 “索引过程”。
- 有关文件类型的概述,请参阅 文件类型。
- 若要查询文件类型的文件关联属性,请参阅 PerceivedTypes、SystemFileAssociations 和应用程序注册。