次の方法で共有


GetFinalPathNameByHandleW 関数 (fileapi.h)

指定したファイルの最終的なパスを取得します。

ファイル名とパス名の詳細については、「ファイルの名前付け」を参照してください。

構文

DWORD GetFinalPathNameByHandleW(
  [in]  HANDLE hFile,
  [out] LPWSTR lpszFilePath,
  [in]  DWORD  cchFilePath,
  [in]  DWORD  dwFlags
);

パラメーター

[in] hFile

ファイルまたはディレクトリへのハンドル。

[out] lpszFilePath

hFileのパス 受け取るバッファーへのポインター。

[in] cchFilePath

lpszFilePathのサイズ (TCHAR単位)。 この値には、NULL 終了文字を含める必要があります。

[in] dwFlags

返される結果の型。 このパラメーターには、次のいずれかの値を指定できます。

価値 意味
FILE_NAME_NORMALIZED
0x0
正規化されたドライブ名を返します。 これが既定値です。
FILE_NAME_OPENED
0x8
開いているファイル名 (正規化されていない) を返します。
 

このパラメーターには、次のいずれかの値を含めることもできます。

価値 意味
VOLUME_NAME_DOS
0x0
ドライブ文字を含むパスを返します。 これが既定値です。
VOLUME_NAME_GUID
0x1
ドライブ名ではなく、ボリューム GUID パスを含むパスを返します。
VOLUME_NAME_NONE
0x4
ドライブ情報のないパスを返します。
VOLUME_NAME_NT
0x2
NT デバイス オブジェクト のパスを返します。

戻り値

関数が成功した場合、戻り値は、lpszFilePathが受け取った文字列の長さ (TCHAR単位) です。 この値には、終端の null 文字のサイズは含まれません。

Windows Server 2008 および Windows Vista: この関数の ANSI バージョンの場合、GetFinalPathNameByHandleA、戻り値には終端の null 文字のサイズが含まれます。

lpszFilePath が小さすぎて文字列と終端の null 文字を保持できないために関数が失敗した場合、戻り値は必要なバッファー サイズ (TCHAR) です。 この値には、終端の null 文字のサイズが含まれます。

その他の理由で関数が失敗した場合、戻り値は 0 になります。 拡張エラー情報を取得するには、GetLastError呼び出します。

リターン コード 形容
ERROR_PATH_NOT_FOUND
ドライブ文字を検索していて、存在しない場合に返すことができます。 たとえば、現在マウントされていないドライブでハンドルが開かれた場合や、ボリュームを作成してドライブ文字を割り当てない場合などです。 ボリュームにドライブ文字がない場合は、GUID パス ボリュームを使用して識別できます。

この戻り値は、ネットワーク共有の GUID パス ボリュームを検索している場合にも返すことができます。 ボリューム GUID パスは、ネットワーク共有用に作成されません。

ERROR_NOT_ENOUGH_MEMORY
操作を完了するためのメモリが不足しています。
ERROR_INVALID_PARAMETER
dwFlagsに無効なフラグが指定されました。

備考

サーバー メッセージ ブロック (SMB) プロトコルは、正規化されたパスのクエリをサポートしていません。 したがって、SMB を使用して開かれたファイルのハンドルを渡し、FILE_NAME_NORMALIZED フラグを使用してこの関数を呼び出すと、関数はパスをそのコンポーネントに分割し、それらの各コンポーネントの正規化された名前を順番に照会しようとします。 ユーザーがこれらのコンポーネントのいずれかに対するアクセス許可を持たない場合、関数呼び出しはERROR_ACCESS_DENIEDで失敗します。

最後のパスは、パスが完全に解決されたときに返されるパスです。 たとえば、"D:\yourdir" を指す "C:\tmp\mydir" という名前のシンボリック リンクの場合、最終的なパスは "D:\yourdir" になります。

VOLUME_NAME_DOSを使用する場合、この関数によって返される文字列は "\\?\" 構文を使用します。 詳細については、「CreateFile」を参照してください。

VOLUME_NAME_GUIDを使用する場合、返されるパスは、"\\?\Volume{xxxxxxxx-xxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx}\" のような形式のボリューム GUID パスで始まります。

VOLUME_NAME_NTを使用する場合、返されるパスは NT デバイス オブジェクト用であり、"\Device\HarddiskVolume1\" などのデバイス名で始まります。 この種類のパスは、相対パスに似ているため、Windows プログラムで直接使用することはできません。

一部のサード パーティ製ドライバーは、マウント マネージャーを使用せずにドライブ文字またはマウント ポイントを作成できます。 マウント マネージャーを使用してドライブを作成しなかった場合、VOLUME_NAME_DOS または VOLUME_NAME_GUID は成功しません。VOLUME_NAME_NT のみが使用できます。 ボリューム デバイス パスのドライブ文字を確認するには、一致するデバイス名が見つかるまで、すべてのドライブ文字で QueryDosDevice 関数を使用します。

Windows 8 および Windows Server 2012 では、この関数は次のテクノロジでサポートされています。

テクノロジー サポート
サーバー メッセージ ブロック (SMB) 3.0 プロトコル はい
SMB 3.0 透過的フェールオーバー (TFO) はい
SMB 3.0 とスケールアウト ファイル共有 (SO) はい
クラスター共有ボリューム ファイル システム (CsvFS) はい
回復性のあるファイル システム (ReFS) はい

次の例では、GetFinalPathNameByHandle 関数の使用を示します。

#include <windows.h>
#include <tchar.h>
#include <stdio.h>

#define BUFSIZE MAX_PATH

void __cdecl _tmain(int argc, TCHAR *argv[])
{
    TCHAR Path[BUFSIZE];
    HANDLE hFile;
    DWORD dwRet;

    printf("\n");
    if( argc != 2 )
    {
        printf("ERROR:\tIncorrect number of arguments\n\n");
        printf("%s <file_name>\n", argv[0]);
        return;
    }

    hFile = CreateFile(argv[1],               // file to open
                       GENERIC_READ,          // open for reading
                       FILE_SHARE_READ,       // share for reading
                       NULL,                  // default security
                       OPEN_EXISTING,         // existing file only
                       FILE_ATTRIBUTE_NORMAL, // normal file
                       NULL);                 // no attr. template

    if( hFile == INVALID_HANDLE_VALUE)
    {
        printf("Could not open file (error %d\n)", GetLastError());
        return;
    }

    dwRet = GetFinalPathNameByHandle( hFile, Path, BUFSIZE, VOLUME_NAME_NT );
    if(dwRet < BUFSIZE)
    {
        _tprintf(TEXT("\nThe final path is: %s\n"), Path);
    }
    else printf("\nThe required buffer size is %d.\n", dwRet);

    CloseHandle(hFile);
}

手記

fileapi.h ヘッダーは、Unicode プリプロセッサ定数の定義に基づいて、この関数の ANSI または Unicode バージョンを自動的に選択するエイリアスとして GetFinalPathNameByHandle を定義します。 エンコードに依存しないエイリアスをエンコードに依存しないコードと組み合わせて使用すると、コンパイルエラーやランタイム エラーが発生する不一致が発生する可能性があります。 詳細については、「関数プロトタイプの 規則」を参照してください。

必要条件

要件 価値
サポートされる最小クライアント Windows Vista [デスクトップ アプリ |UWP アプリ]
サポートされる最小サーバー Windows Server 2008 [デスクトップ アプリ |UWP アプリ]
ターゲット プラットフォーム の ウィンドウズ
ヘッダー fileapi.h (Windows.h を含む)
ライブラリ Kernel32.lib
DLL Kernel32.dll

関連項目

ファイル管理機能の