MFC編 目次

 MFC全般

 

・MFCの開発環境をそろえよう
・MFCをスタティックリンクしたときに出るエラー
・関数追加時に出るエラー
・Windows XPスタイルの外観にする

 文字列操作

 

・CStringの基本1 文字列の連結と追加
・ATL/MFC共有版のCStringについて
・CStringと三項演算子の問題

 DDX/DDV

 

・DDXの基本1
・DDXの基本2
・DDX変数に複数コントロールを割り当てる
・DDX変数を配列にする

 ダイアログ

 

・ダイアログの色変更

 ボタン

 

・ボタンの基本

 チェックボックス

 

・チェックボックスの基本
・プッシュボタンのようなチェックボックス
・チェックボックスの色変更

 エディットボックス

 

・エディットボックスの基本
・エディットボックスの色変更

 コンボボックス

 

・コンボボックスの基本
・コンボボックスに初期データを入れる
・コンボボックスの色変更
・拡張コンボボックス

 リストボックス

 

・リストボックスの基本
・リストボックスの色変更
・チェックリストボックスを作る

 ラジオボタン

 

・ラジオボタンの基本
・ラジオボタンの色変更

 スタティックテキスト

 

・スタティックテキストの内容を動的に変更する
・スタティックテキストに複数行入力する
・スタティックテキストの文字色変更

 リストコントロール

 

・リストコントロールの基本1
・リストコントロールの基本2
・リストコントロールの一行全体を選択する
・リストコントロールを単一行選択にする
・フォーカスが移ったときも選択状態を維持する
・アイテムにユーザデータを付加する
・アイテムにアイコンをつける
・アイテムに状態イメージをつける
・ヘッダ項目にアイコンをつける

 ツリーコントロール

 

・ツリーコントロールの基本

 タブコントロール

 

・タブコントロールの基本1
・タブコントロールの基本2
・タブコントロールをXPスタイルにする

 スライダコントロール

 

・スライダコントロールの基本1
・スライダコントロールの基本2

 スピンコントロール

 

・スピンコントロールの基本

 プログレスバー

 

・プログレスバーの基本

 日時指定コントロール

 

・日時指定コントロールの基本

 月間予定表コントロール

 

・月間予定表コントロールの基本
・月間予定表のプロパティと色変更

 IPアドレスコントロール

 

・IPアドレスコントロールの基本
・IPアドレスコントロールの操作

 ピクチャーコントロール

 

・ピクチャーコントロールの基本

 アニメーションコントロール

 

・アニメーションコントロールの基本

 時刻管理

 

・CTimeとCTimeSpan
・CTimeの引数について

 メニュー

 

・ダイアログにメニューをつける
・ダイアログにポップアップメニューをつける

 ステータスバー

 

・ダイアログにステータスバーをつける
・ステータスバーに文字列を表示する

 プロパティシート

 

・プロパティシートの基本1
・プロパティシートの基本2

 コモンダイアログ

 

・ファイル選択ダイアログ
・フォント選択ダイアログ
・色選択ダイアログ

 ファイル入出力

 

・ファイル入出力の基本
・テキストファイルの入出力
・ファイルの検索、列挙1
・ファイルの検索、列挙2

 ネットワーク

 

・MFCソケット通信の基本 (クライアント編)
・MFCソケット通信の基本 (サーバ編)
・MFC非同期ソケット (クライアント編1)
・MFC非同期ソケット (クライアント編2)
・MFC非同期ソケット(サーバ編1)
・MFC非同期ソケット(サーバ編2)

 デバイスコンテキスト

 

・デバイスコンテキストの基本
・文字列の描画
・ペンを使った描画
・ブラシを使った描画1
・ブラシを使った描画2

 FTPクライアント

 

・FTPクライアントを作る1
・FTPクライアントを作る2
・FTPクライアントを作る3
・FTPクライアントを作る4
・FTPクライアントを作る5

 ドキュメント・ビュー

 

・ドキュメント・ビューの基本
・エディットビューの基本
・リストビューの基本
・ツリービューの基本
・フォームビューの基本

 ダイアログバー

 

・ダイアログバーの基本
・ダイアログにダイアログバーをつける

 

 

トップページへ戻る

FTPクライアントを作る4

 今回はファイル操作関連を実装していきます。まずはファイルの削除です。

// "ファイル削除"ボタン押下
void CFtpClientDlg::OnBnClickedBtnRemovefile()
{
    CString        fileName, str;
    int            sel = 0;
    int            err = 0;
    
    if (!err) if (!m_ftpConP) err = 1;
    
    // ファイル名取得
    if (!err) if ((sel = m_xcList.GetCurSel()) == LB_ERR) err = 1;
    if (!err)
    {
        m_xcList.GetText(sel, fileName);
        if (fileName.Left(3) == _T("[D]")) err = 1;
    }
    
    // ファイル削除
    if (!err) if (!m_ftpConP->Remove(fileName)) err = 1;
    if (!err) Refresh();
    
    // メッセージ表示
    str = (err) ? _T("ファイル削除に失敗しました。") 
            : _T("ファイルを削除しました。");
    MessageBox(str);
}

 ファイルの削除は、CFtpConnection::Remove()関数を使います。

BOOL CFtpConnection::Remove(LPCTSTR pstrFileName);
説明: ファイルの削除
引数: pstrDirName:ファイル名(相対パスまたは絶対パス)
戻り値: 正常終了した場合は0以外、それ以外の場合は0

 次はファイル名の変更です。

// "名前変更"ボタン押下
void CFtpClientDlg::OnBnClickedBtnRename()
{
    CDialogName        nameDlg;
    CString            fileName, str;
    int                sel = 0;
    int                err = 0;
    
    if (!err) if (!m_ftpConP) err = 1;
    
    // 古いファイル名を取得
    if (!err) if ((sel = m_xcList.GetCurSel()) == LB_ERR) err = 1;
    if (!err)
    {
        m_xcList.GetText(sel, fileName);
        if (fileName.Left(3) == _T("[D]")) err = 1;
    }
    
    // 新しいファイル名を入力
    if (!err) if (nameDlg.DoModal() != IDOK) err = 1;
    
    // ファイル名変更
    if (!err) if (!m_ftpConP->Rename(fileName, nameDlg.GetName())) err = 1;
    if (!err) Refresh();
    
    // メッセージ表示
    str = (err) ? _T("ファイル名変更に失敗しました。") 
            : _T("ファイル名を変更しました。");
    MessageBox(str);
}

 前回追加した名前入力のダイアログを使います。CDialog::DoModal()関数でダイアログを表示し、"OK"が押されたら、作成したGetName()関数で新しいファイル名を取得します。ファイル名の変更はCFtpConnection::Rename()関数を使います。

BOOL CFtpConnection::Rename(LPCTSTR pstrExisting, LPCTSTR pstrNew);
説明: ファイル名の変更
引数: pstrExisting:変更前のファイル名(相対パスまたは絶対パス)
pstrNew:新しいファイル名(相対パスまたは絶対パス)
戻り値: 正常終了した場合は0以外、それ以外の場合は0

 それでは、FTPのメインの機能であるファイルのアップロード、ダウンロードを実装していきましょう。まずは"アップロード"ボタン押下時のイベントハンドラです。

// "アップロード"ボタン押下
void CFtpClientDlg::OnBnClickedBtnUpload()
{
    CFileDialog        selDlg(TRUE);
    CString            str;
    int                err = 0;
    
    if (!err) if (!m_ftpConP) err = 1;
    
    // ローカルファイル選択
    if (!err) if (selDlg.DoModal() != IDOK) err = 1;
    
    // アップロード
    if (!err) if (!m_ftpConP->PutFile(
        selDlg.GetPathName(), selDlg.GetFileName())) err = 1;
    
    // メッセージ表示
    str = (err) ? _T("アップロードに失敗しました。") 
            : _T("アップロードしました。");
    MessageBox(str);
}

 まずはどのファイルをアップロードするのか、ローカルのファイルを選択しないといけません。これはコモンダイアログの「ファイル選択ダイアログ」を使うと簡単にできます。CFileDialogクラスのオブジェクトを作成し、DoModal()関数でファイル選択ダイアログを表示します。

 ファイルが選択されたらアップロードします。アップロードにはCFtpConnection::PutFile()関数を使います。

BOOL CFtpConnection::PutFile(
LPCTSTR pstrLocalFile,
LPCTSTR pstrRemoteFile,
DWORD dwFlags = FTP_TRANSFER_TYPE_BINARY,
DWORD_PTR dwContext = 1
);
説明: ファイルのアップロード
引数: pstrLocalFile:ローカルのファイル名(相対パスまたは絶対パス)
pstrRemoteFile:リモートのファイル名(相対パスまたは絶対パス)
dwFlags:転送モード(FTP_TRANSFER_TYPE_BINARYまたはFTP_TRANSFER_TYPE_ASCII)
dwContext:コンテキストID
戻り値: 正常終了した場合は0以外、それ以外の場合は0

 次は"ダウンロード"ボタン押下時のイベントハンドラです。

// "ダウンロード"ボタン押下
void CFtpClientDlg::OnBnClickedBtnDownload()
{
    CString         localName, fileName, str;
    LPTSTR          pszPath = NULL;
    BROWSEINFO      bInfo;
    LPITEMIDLIST    pList;
    int             sel = 0;
    int             err = 0;
    
    if (!err) if (!m_ftpConP) err = 1;
    
    // ローカルフォルダ選択
    if (!err)
    {
        pszPath = localName.GetBufferSetLength(MAX_PATH);
        ZeroMemory(&bInfo, sizeof bInfo);
        bInfo.hwndOwner         = GetSafeHwnd();
        bInfo.pszDisplayName    = pszPath;
        bInfo.ulFlags           = BIF_RETURNONLYFSDIRS;
        
        if ((pList = ::SHBrowseForFolder(&bInfo)) == NULL) err = 1;
    }
    if (!err) if (!::SHGetPathFromIDList(pList, pszPath)) err = 1;
    
    if (pszPath) {localName.ReleaseBuffer(); pszPath = NULL;}
    
    // ファイル名取得
    if (!err) if ((sel = m_xcList.GetCurSel()) == LB_ERR) err = 1;
    if (!err)
    {
        m_xcList.GetText(sel, fileName);
        if (fileName.Left(3) == _T("[D]")) err = 1;
    }
    
    // ダウンロード
    if (!err)
    {
        localName = localName +_T("\\") +fileName;
        if (!m_ftpConP->GetFile(fileName, localName)) err = 1;
    }
    
    // メッセージ表示
    str = (err) ? _T("ダウンロードに失敗しました。") 
            : _T("ダウンロードしました。");
    MessageBox(str);
}

 ダウンロード時はダウンロード先のローカルのディレクトリを指定しないといけません。ディレクトリ選択のダイアログはAPIのSHBrowseForFolder()関数を使って出すことができます。

 現在選択されているファイルをリストボックスから取得し、ダウンロードします。ダウンロードにはCFtpConnection::GetFile()関数を使います。

BOOL CFtpConnection::GetFile(
LPCTSTR pstrRemoteFile,
LPCTSTR pstrLocalFile,
BOOL bFailIfExists = TRUE,
DWORD dwAttributes = FILE_ATTRIBUTE_NORMAL,
DWORD dwFlags = FTP_TRANSFER_TYPE_BINARY,
DWORD_PTR dwContext = 1
);
説明: ファイルのダウンロード
引数: pstrRemoteFile:リモートのファイル名(相対パスまたは絶対パス)
pstrLocalFile:ローカルのファイル名(相対パスまたは絶対パス)
bFailIfExists:TRUEの場合既存のファイルを上書きしない。FALSEの場合既存のファイルを上書きする。
dwAttributes:ファイルの属性
dwFlags:転送モード(FTP_TRANSFER_TYPE_BINARYまたはFTP_TRANSFER_TYPE_ASCII)
dwContext:コンテキストID
戻り値: 正常終了した場合は0以外、それ以外の場合は0

 これでほぼ必要な機能はできました。FTPの機能は関数を1つ呼ぶだけなので非常に簡単ですね。次回は最後にもう一つ機能を追加します。