INETコントロールを使って、サーバとファイルの送受信をするアプリを作りたいのですが、基本的なところでつまづいています。
サンプルプログラムを見つけたので試してみているのですが。
以下。
Private Sub cmdDownload_Click()
Dim GetBuf() As Byte
Dim FileNum As Integer
GetBuf() = Inet.OpenURL(txtURL.Text, icByteArray)
FileNum = FreeFile
Open txtSavePath.Text For Binary Access Write As FileNum
Put #FileNum, , GetBuf()
Close #FileNum
MsgBox "ダウンロード終了"
End Sub
ここで、txtURL.Text に何を記述したらいいのか、はっきり分かりません。
サーバー名にファイルのあるディレクトリを付けた形、
ftp://servername/home/tmp/test.txt
サーバーのIPアドレスにファイルのあるディレクトリを付けた形、
ftp://172.20.1.17/home/tmp/test.txt
を試してみたのですが、うまくダウンロードできません。
目的のプログラムは Executeメソッドを使ってファイルの送受信をしたいのですが、どちらにしてもURLの記述ができないとダメなのですよね?
どうぞ、よろしくお願いいたします。
No.5ベストアンサー
- 回答日時:
ご指名ありがとうございます。
(←変な飲み屋みたい)こんな感じ?
With Inet1
.URL = "ftp://ftp.hoge.com"
.UserName = "TAGOSAKU7"
.Password = "内緒"
.Execute , " DIR"
End With
UserNameとPasswordは、ExecuteかOpenURLを発行すると同時に送られているようです。
UserNameが空状態であれば "anonymous"を送っているようです。
でも、
>"ftp://user:pwd@URL"
使用方法によってはいいと思いますよ。
画面にさえ表示しなければ・・・
それと、、、
受けのサーバのポートは特に意識する必要はないと思います。
WinSockでもないので、ソケットのことを考える必要もないし、手順を間違わなければサーバに設定を施さなくてもできると思います。
ありがとうございました。
Inet.OpenURL ではうまくいかないのですが、Inet.Execute ではうまくいきました。一行で書くと
Inet.Execute "ftp://username:password@hostname", "GET test.lzh e:\tmp\test.lzh"
みたいな感じです。
GET(ダウンロード)もPUT(アップロード)もこれでいけました。
もちろん
With Inet1
.URL = "ftp://ftp.hoge.com"
.UserName = "TAGOSAKU7"
.Password = "内緒"
.Execute , " DIR"
End With
の書き方でもOKでした。
ところが、問題点がふたつ。
1.ダウンロードやアップロードが終わってアプリケーションを終了するときに、
Inet.Cancel を記述しているのですが、5秒ぐらいかかります。
Private Sub Inet.StateCanged(Byval State As Integer) を記述すると
なぜかすぐ終わります。解せません。
2.GET と PUT はうまくいくのですが、CD や DIR がちゃんと動きません。
まだ、分かっていないところがあるのだと思います。
またいろいろとやってみますが、何かお気づきのことがありましたらお教えください。取り敢えずお礼まで。
No.7
- 回答日時:
なるほど・・・
でも、追記質問部分は自己解決できそうですね^^
サーバの戻りは基本的にStateChangedで行います。
もうひとつの質問
http://oshiete1.goo.ne.jp/kotaeru.php3?q=227737
については、そちらに書いておきます。(回答ではないけど・・・)
No.6
- 回答日時:
※追記質問1について
ごめんなさい。。。
Inetコントロールでは、「ちょっと勉強」と思って触れたぐらいで、内部構造は予想したこともありません。
内部はwininet.dllを参照したAPI郡だと思うのですが、それを追っていったらわかると思います。
ぼくは(4ヶ月経ってまだ作りかけの)FTPソフトはWSock32.dllを使用しています。権限などがInetではできない(と思っている)からです。
http://www.mitene.or.jp/~sugisita/family/papa/vb/
コンポーネント→FTPクラス
ここのサンプルを解読するか、あるいはクラスファイルになっているので、そのままプロジェクトに追加をしてしまう方がよいかも?
※追記質問2について
すいません。CDもDIRもできたのですが・・・
何がどううまくいかないのかわかりません。
コードと、症状を教えてくれたらわかるかも?
この回答への補足
ありがとうございます。
昨夜、本を改めて読んでみてわたしの使い方が間違っているのだと思いました。
というのは、OpenURL のサンプルコードを改変して Execute をやっていたので、次のようなコードで試していました。
Private Sub cmdDownload_Click()
Dim FileName As String
Inet.URL = "ftp://hostname"
Inet.UserName = "username"
Inet.Password = "password"
Inet.Execute , "GET test.lzh " & filename
MsgBox "ダウンロード終了"
End Sub
みたいな感じで。ところが本をよく読んでみたら
Private Sub cmdDownload_Click()
Dim FileName As String
Inet.URL = "ftp://hostname"
Inet.UserName = "username"
Inet.Password = "password"
Inet.Execute , "GET test.lzh " & filename
Do While Inet.StillExecuting = True
DoEvents
Loop
MsgBox "ダウンロード終了"
End Sub
のような感じで、同期をとって終了確認をしています。DIR も CD もそうです。わたしはただ単に Execute を発行していただけなのでここが原因だったかな、と午後にまた仕事先で確認したいと思います。
それと、ついでといっては申し訳ないのですがTAGOSAKU7さんはWinSockの方もお詳しそうなので「質問13」の「Socket通信で送信終了のイベントが発生しない」にもお知恵をいただけないでしょうか?図々しくて申し訳ありませんが。
No.4
- 回答日時:
>サーバはUnix形OS(Soralis)なのです。
それなら、ユーザー名とパスワードを入れる必要があるのでは?
"ftp://user:pwd@172.20.1.17/home/tmp/test.txt"
で動きませんか?
しかし、この方法はセキリティ上問題があるのでお勧め出来ない。
INETコントロールでユーザー名とパスワードを指定するのは
どうするのでしょうか? >TAGOSAKUさん
どうもありがとうございました。
当所の目的(アップロードとダウンロード)の半分はクリアーできました。
問題点をNo5.のTAGOSAKUさんの方へ書きました。
よろしくご指導をお願いいたします。
No.3
- 回答日時:
OpenURLでの取得
これは、ブラウザと同じように
[ファイルにアクセス]して[保存]
という処理です。
どうやらファイル転送とは違い、擬似的な転送と言えます。
なので送信ができません。
FTP接続でのファイル転送は、OpenURLを使用しないで、コマンドで行います。
http://www.microsoft.com/JAPAN/developer/library …
http://www.microsoft.com/JAPAN/developer/library …
に解説とサンプルが出ています。
No.2
- 回答日時:
参考URLと比べてみてもソースに問題はないと思います。
txtURL.text = "ftp://ftp.microsoft.com/developr/drg/Win32/Autor …
としたら動きませんか?
参考URL:http://www.microsoft.com/JAPAN/developer/library …
この回答への補足
ありがとうございます。
サーバはUnix形OS(Soralis)なのです。
ネットワークが繋がっていて、ホスト名(もしくはIPアドレス)が分かっていればFTPポート(21)を使って、FTP送受信できると思っているのですが違うのでしょうか?
No.1
- 回答日時:
今は時間がないのでサンプルを書けないのですが・・・
コードを見るとコマンドボタンのイベントのソースであるように見えますが、ちょっと書くところが違うような気がします。
バッファは何分割かで受信が行われと思ったのですが・・・
Inetの名前を忘れたけどイベント内に
GetBuf() = Inet.OpenURL(txtURL.Text, icByteArray)
を書くように思ったんだけど、違ったらすいません。
それと・・・質問とは無関係の余談ですが・・・
cmdDownload_Click
と書いてあるのを見て、コマンドボタンのクリックイベントだと、すぐわかりました。
コーディング規則に沿ったネーミングをされてると、大変質問も理解しやすいですね。
この回答への補足
ありがとうございます。
返事をいただけて嬉しいです。
お時間のあるときにサンプルもいただけるとなお嬉しいです。
今日も色々と試しているのですがうまくいきません。
何らかのエラーが生じていると思うのですが、
On Error GoTo でも検出されず手がかりがなくて困っています。
どうぞよろしくお願いいたします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) エクセルのマクロについて教えてください。 2 2023/07/15 15:48
- Excel(エクセル) Excelにて、フォルダ内のTextファイルをマクロで統合すると文字化けしてしまう時の解消コード 4 2023/01/01 07:32
- Excel(エクセル) マクロでテキストファイルを読み込んだ際の最終セルにデータと改行が含まれる問題の改善方法 2 2022/03/25 16:50
- Visual Basic(VBA) VBA Userformで一部別シートに転記がしたいのですが 2 2023/05/24 13:08
- Excel(エクセル) エクセルVBA、間違っているコード内容を正して頂けませんか? エクセルワークシートに納品書を作ったの 2 2023/08/02 21:13
- Excel(エクセル) エクセルのVBAについて とあるサイトのコードを参考に、CSVの文字化けを直すVBAを作成しているの 7 2022/11/04 14:15
- Visual Basic(VBA) このVBAでExcelアプリケーションを作成は必要ですか? 3 2023/07/19 21:13
- Visual Basic(VBA) batからexeを実行し戻り値を受け取る バッチからEXEの結果を受け取りたいのですが、 下記のバッ 1 2023/07/04 15:13
- Visual Basic(VBA) 【前回の続きです、ご教示ください】VBAの記述方法がわかりません。 2 2022/08/16 16:44
- Visual Basic(VBA) outlook マクロが終了しません。 1 2022/09/02 11:14
このQ&Aを見た人はこんなQ&Aも見ています
-
とっておきの「夜食」教えて下さい
真夜中に小腹がすいたときにこっそり作るメニュー、こっそり家を抜け出して食べに行くお店… 人には言えない、けど自慢したい、そんなあなたの「とっておきの夜食」を教えて下さい。
-
スマホに会話を聞かれているな!?と思ったことありますか?
スマートフォンで検索はしてないのに、友達と話していた製品の広告が直後に出てきたりすることってありませんか? こんな感じでスマホに会話を聞かれているかも!?と思ったエピソードってありますか?
-
遅刻の「言い訳」選手権
よく遅刻してしまうんです…… 「電車が遅延してしまい遅れました」 「歯医者さんが長引いて、、、」 「病院が混んでいて」 などなどみなさんがこれまで使ってきた遅刻の言い訳がたくさんあるのではないでしょうか?
-
ちょっと先の未来クイズ第5問
日本漢字能力検定協会が主催し、12月12日に発表される、2024年の「今年の漢字」に選ばれる漢字一文字は何でしょう?
-
ギリギリ行けるお一人様のライン
おひとり様需要が増えているというニュースも耳にしますが、 あなたが「ギリギリ一人でも行ける!」という場所や行為を教えてください
-
VB6.0でFTPでのファイルの送受信
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・【大喜利】【投稿~12/2】 国民的アニメ『サザエさん』が打ち切りになった理由を教えてください
- ・ちょっと先の未来クイズ第5問
- ・【お題】ヒーローの謝罪会見
- ・これが怖いの自分だけ?というものありますか?
- ・スマホに会話を聞かれているな!?と思ったことありますか?
- ・それもChatGPT!?と驚いた使用方法を教えてください
- ・見学に行くとしたら【天国】と【地獄】どっち?
- ・【大喜利】【投稿~11/22】このサンタクロースは偽物だと気付いた理由とは?
- ・お風呂の温度、何℃にしてますか?
- ・とっておきの「まかない飯」を教えて下さい!
- ・2024年のうちにやっておきたいこと、ここで宣言しませんか?
- ・いけず言葉しりとり
- ・土曜の昼、学校帰りの昼メシの思い出
- ・忘れられない激○○料理
- ・あなたにとってのゴールデンタイムはいつですか?
- ・とっておきの「夜食」教えて下さい
- ・これまでで一番「情けなかったとき」はいつですか?
- ・プリン+醤油=ウニみたいな組み合わせメニューを教えて!
- ・タイムマシーンがあったら、過去と未来どちらに行く?
- ・遅刻の「言い訳」選手権
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・この人頭いいなと思ったエピソード
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
サブフォルダ含むフォルダ内の...
-
ffftpでファイル取得が0バイト...
-
VBAでCSVファイルを読み込もう...
-
動かなくなってしまった古いVBA...
-
vbs ブック共有を解除
-
フォルダ階層・ファイル名・ペ...
-
ファイルのアクセス回数について
-
エクセルのプロパティーでセキ...
-
エクセルのマクロで特定フォル...
-
エクセルvbaでdocuworksprinter...
-
カンマ区切りのCSVファイルから...
-
VBプロジェクトでのフォルダ構...
-
バッチファイル 別ファイルにリ...
-
frxファイルの役目
-
マインクラフトPCをプレイしよ...
-
ExcelブックをGoogleスプレッド...
-
エクセルのハイパーリンクがコ...
-
マクロから出力されるcsvのダブ...
-
エクセルで複数のコメントのサ...
-
awk getlineをもう一度ファイル...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
動かなくなってしまった古いVBA...
-
サブフォルダ含むフォルダ内の...
-
excel マクロ PDF化の際のエラ...
-
「エクセルファイルが開いてい...
-
VBAでフォルダ内のhtmlファイル...
-
vbs ブック共有を解除
-
vbaサブフォルダーをワイルドカ...
-
ffftpでファイル取得が0バイト...
-
Accessのウインドウサイズの固定
-
VB6でUTF-8ファイルの読取りを
-
エクセルのVBAで開いている...
-
FileDialog オブジェクトでファ...
-
VB.net XMLの作成方法 Iniの代替
-
Long型で表現できないファイル...
-
vbsでのアスタリスクとファイル...
-
タイムスタンプの更新の方法2
-
VBからExcelファイルを開くとき...
-
ファイルを複数選択した時のフ...
-
ファイルを開く時間測定のスク...
-
【VBAマクロ初心者】Excel VBA...
おすすめ情報