InjectNtmsMedia 函数 (ntmsapi.h)
[从 Windows 7 和 Windows Server 2008 R2 起,可移动存储管理器 不再可用。]
InjectNtmsMedia 函数允许将媒体插入指定库的端口。 如果库正忙,RSM 会将 InjectNtmsMedia 排队并返回成功。
语法
DWORD InjectNtmsMedia(
[in] HANDLE hSession,
[in] LPNTMS_GUID lpLibraryId,
[out] LPNTMS_GUID lpInjectOperation,
[in] DWORD dwAction
);
参数
[in] hSession
OpenNtmsSession 函数返回的会话的句柄。
[in] lpLibraryId
库对象的唯一标识符。
[out] lpInjectOperation
插入库操作的 GUID。 如果 dwAction 为NTMS_INJECT_START,则此参数接收操作的 GUID。 如果 dwAction 是NTMS_INJECT_STOP,则必须将此参数设置为 GUID 才能停止操作。
[in] dwAction
此参数的取值可为下列值之一:
返回值
此函数返回以下值之一。
值 | 含义 |
---|---|
|
拒绝NTMS_CONTROL_ACCESS库。 其他安全错误也可能存在,但它们表示存在安全子系统错误。 |
|
数据库不可访问或已损坏。 |
|
数据库已满。 |
|
库已禁用。 |
|
会话 ID 缺失或无效。 |
|
对无效的操作 ID 执行了停止操作。 |
|
缺少库 ID 或操作 ID 指针。 |
|
库 ID 是指无法弹出媒体的脱机库。 |
|
处理期间发生分配失败。 |
|
插入已排队。 |
注解
插入请求排队后,此函数立即返回到应用程序。
如果 InjectNtmsMedia 函数指定的库没有端口,请使用 AccessNtmsLibraryDoor 函数插入和弹出媒体。
此函数不能与脱机库一起使用。
插入开始将媒体插入库的过程。 由于库因 NTMS_IEPORT 对象的功能而异,因此每个设备的运行方式可能略有不同。 以下步骤描述了 RSM 通常如何处理注入:
将媒体插入库
- 允许/解锁/扩展NTMS_IEPORT。
- 轮询完整NTMS_IEPORT、收回NTMS_IEPORT、停止注入命令或超时值。 如果这些都未发生,请继续等待。 (不会扫描多盒插入/弹出端口的完整状态。)
- 发生上述事件之一时,NTMS_IEPORT被锁定,NTMS_IEPORT中的每个媒体都移动到一个槽,并且标识介质命令将针对每个介质排队。
如果没有可用槽, InjectNtmsMedia 函数会收到错误。
要求
要求 | 值 |
---|---|
最低受支持的客户端 | Windows XP [仅限桌面应用] |
最低受支持的服务器 | Windows Server 2003 [仅限桌面应用] |
目标平台 | Windows |
标头 | ntmsapi.h |
Library | Ntmsapi.lib |
DLL | Ntmsapi.dll |