ネットワークプログラ ..
[2ch|▼Menu]
212:デフォルトの名無しさん
09/11/17 15:47:40
>>204です。
お返事ありがとうございます。
RFC2616やグーグルしたところ、HTTP/1.1はHost: URLを記述しなければいけないとのことだったので
記述し、2回目のデータ要求ではConnection: Closeを記述したところ2回、データを要求することが出来ました。
2回目はBad Requestになってしまいますが。。
RFCを見て、少しやる気をなくしてしまいましたが
出来たらネットワークの勉強に励み、この問題をいつかは解決したいと思います。
ありがとうございました。

213:デフォルトの名無しさん
09/11/20 00:14:01
UDPのブロードキャストについて質問です
pythonとCで書いてます。(例はpythonで書きます)
ブロードキャストでデータを送りたいのですが、
setsockoptでSO_BROADCASTを有効にし、
# pythonの例
sock.sendto( data, ( "255.255.255.255", 1234 ) )
としても、受信側で受信できません。
# 受信側のIPアドレスは192.168.11.4
sock.sendto( data, ( "192.168.11.4", 1234 ) )
として、ユニキャストだと受信できることを確認しています。
環境はlinuxです。
ブロードキャストアドレスとして255.255.255.255を使うのは間違ってますか?

214:デフォルトの名無しさん
09/11/20 03:25:47
それは自分の所属するサブネットの中なの?外なの?

215:デフォルトの名無しさん
09/11/20 06:15:52
>ブロードキャストアドレスとして255.255.255.255を使うのは間違ってますか?

はい

216:デフォルトの名無しさん
09/11/20 07:06:20
rootにならないとできないとかそういうのもあるよね。

217:デフォルトの名無しさん
09/11/20 08:36:47
ブロードキャストアドレスとして192.168.11.255と設定してあるだろ。
それ使えよ。

218:デフォルトの名無しさん
09/11/20 13:28:28
基本的にネットの負荷が上がるのでブロードキャスト非推奨。

つ ブロードキャストストーム
輻輳を検知するとポート綴じちゃうスイッチも有るよ。

219:デフォルトの名無しさん
09/11/20 18:32:47
>>214
自サブネット内です。
>>215
はい
ありがとうございます
>>216
rootになっても変わりませんでした。
>>217
確かに/24で切ってるので、192.168.11.255も試したのですが変わりませんでした。

ハード的におかしいのかと思い、
192.168.11.4を持つマシン上で、サーバとクライアントを動かしたのですが、
結局受信しませんでした。
wiresharkでみるとパケットは観測されてたのですが・・・

220:デフォルトの名無しさん
09/11/20 18:44:37
promiscus

221:デフォルトの名無しさん
09/11/20 19:02:55
× promiscus
○ promiscuous

222:デフォルトの名無しさん
09/11/20 23:24:41
>>219
受信側はどうバインドしてるの? 例えば'192.168.11.4’にバインドしてたらそのアドレスへのユニキャストしか受信出来ない。 ブロードキャストも受け取りたいならアドレスは'' (空文字列)でバインドしなければだめ。


223:デフォルトの名無しさん
09/11/21 19:20:27
空文字列?
192.168.11.255にバインドするべきじゃないの?

224:デフォルトの名無しさん
09/11/21 19:21:12
どうみても 0.0.0.0 にバインドです本当にありがとうございました

225:デフォルトの名無しさん
09/11/21 19:39:22
まったく知識がないんだがどこから手をつければいいのか教えろカスども

226:デフォルトの名無しさん
09/11/21 19:50:51
.255なんて使うなよw

227:デフォルトの名無しさん
09/11/21 19:56:40
まずお前が何をしたいのか教えろよカスが

228:デフォルトの名無しさん
09/11/21 19:57:53
SEXしたい;;

229:デフォルトの名無しさん
09/11/21 20:06:44
おまえら!

N88ベーシックの時代を思い出せ!
使ってるだけじゃだめなんだよ!
利用者全員がプログラマーにならなきゃ世の中は良くならない!
そうだろうみんな!!


230:デフォルトの名無しさん
09/11/21 20:07:39
食いっぱぐれます

231:デフォルトの名無しさん
09/11/21 22:21:39
せんせー
IPアドレスからgethostbyaddrでホスト名とってくるプログラムをVC++(まあなんでも出来るが)で組んだのだけれど、
もし取ってこれなかった場合
>初回の例外が発生しました: 0x000006BA: RPC サーバーを利用できません。
みたいなのが出力パネルに無視して平気?
一応host名がNULLだった時の退避路はあるし、エラーでプログラムが止まるわけじゃないんだけど
なんかわざわざ一回づつ排出するもんだから気になって

232:デフォルトの名無しさん
09/11/21 23:24:51
try catch

233:デフォルトの名無しさん
09/11/22 02:37:25
これかな
URLリンク(support.microsoft.com)

234:デフォルトの名無しさん
09/11/24 19:49:11
ソケット生成してbindした時点で、データが送られてくると
受信はされるのでしょうか?
そこから、recvformで取り出すといった感じなのでしょうか?

データを一定間隔で送信し、送信した結果複数の個所からデータが返ってくる
とした場合、最初に返ってきたデータだけをデータとして取り込みたいのですが
こういった場合、どうするのが最適でしょうか?

235:デフォルトの名無しさん
09/11/24 20:32:30
bindってよく考えたら、0.0.0.0でbindしておけば
自分のIPが192.168.11.4でも recvfromで192.168.11.100 宛のデータも受信できるのでしょうか?
(ポート等は同じで、ARPで関連づけておくとして)

236:デフォルトの名無しさん
09/11/24 20:44:28
promiscuous

237:デフォルトの名無しさん
09/11/24 21:35:41
promiscuous は関係ない

238:デフォルトの名無しさん
09/11/24 21:42:51
それより質問の仕方が悪い

239:デフォルトの名無しさん
09/11/24 22:43:16
通常のモードだと自分のMAC宛のパケットしか受信できない

240:デフォルトの名無しさん
09/11/24 22:56:11
>>239
ARPテーブル操作して、自分のmac向けに別のIPを関連づけたら届きますよね
そこで0.0.0.0をbindしておけば自分の今のIPとは違うデータまで受信できるということでしょうか?

241:デフォルトの名無しさん
09/11/24 23:30:36
>>240
MAC判別はネットワークチップの機能だよ

242:デフォルトの名無しさん
09/11/24 23:37:24
>>241
すみません、よくわかってないのですが
MAC判別がどう関係あるのでしょうか?
宛先mac自体は、本来の宛先macをarpテーブルで指定してやりますよね

243:デフォルトの名無しさん
09/11/24 23:42:42
送信する相手のARPテーブルを操作するって事か

それが受信できるかどうかはIP層の実装仕様次第じゃないのか?
普通は出来ないと思うが・・・

244:デフォルトの名無しさん
09/11/24 23:51:53
変なパケットは捨てるのが基本

245:デフォルトの名無しさん
09/11/25 00:00:49
実装仕様とはNICに依存するのでしょうか?

でもmacアドレスはあってる、IP層のIPも送信元がARPテーブル操作してあってる
から届くはずだとはおもうんですが

246:デフォルトの名無しさん
09/11/25 00:52:43
> ARPテーブル操作して、
どこのマシンのARPテーブルいじる気だよ。毒入りarp投げるのか?
オレの管理下で発見したら接続禁止だぞ。上司が土下座しなけりゃつなげさせない。

> そこで0.0.0.0をbindしておけば自分の今のIPとは違うデータまで受信できるということでしょうか?
IPってゆうな。クズ。

例え送信元のARPテーブル操作してパケットが届いたとしても出来ない。
0.0.0.0は自マシンのアドレスに対するワイルドカードだからだ。

もう一回言っておく。IPってゆうな。クズ。

247:デフォルトの名無しさん
09/11/25 01:18:53
受信したいマシンが 192.168.11.100 というIPを持っていないから無理
RawIPでも使え

248:デフォルトの名無しさん
09/11/25 01:28:28
IPってゆうな。クズ。

249:デフォルトの名無しさん
09/11/25 01:37:02
単にアドレスって言うのもハンパだろ?

250:デフォルトの名無しさん
09/11/25 01:45:49
IPアドレスを省略するときは単に「アドレス」って言う
IPは知的財産の省略形として稀に使うぐらい

251:デフォルトの名無しさん
09/11/25 02:01:57
ネット盗聴ソフトか不正アクセスでもするソフトでも作ってるのかw

252:デフォルトの名無しさん
09/11/25 03:27:17
>>235
環境による
>>240
環境による


253:デフォルトの名無しさん
09/11/25 06:53:48
promiscuous

254:デフォルトの名無しさん
09/11/25 07:32:45
>>246 >>247

>>252
さんがいうには、環境によってはできるとのことですが

255:デフォルトの名無しさん
09/11/25 07:33:57
俺の自作スタックなら何でも出来る

256:デフォルトの名無しさん
09/11/25 08:02:59
>>252
かなりめずらしい環境でないか? 組み込み系のマイナーな
スタックとか?

257:デフォルトの名無しさん
09/11/25 17:54:55
WinSockのWSAAsyncSelectについて質問です。

今まで使い方を間違えていたらしく、あちこちのサンプルでは

(1)
リスニングソケットにはFD_ACCEPTを設定し
WSAAsyncSelect(socketListen, hWnd, (WM_APP + 1), FD_ACCEPT))

(2)
case FD_ACCEPT内で
SOCKET socket = accept(m_sckListen, &addr, &nLength);
WSAAsyncSelect(socket, hWnd, (WM_APP + 1), FD_READ | FD_CLOSE)

と、個別にFD_READやらFD_CLOSEを設定するのが正解のようです。

今まで私は(1)で FD_ACCEPT | FD_READ | FD_CLOSE と設定し、(2)ではWSAAsyncSelect自体を呼び出していませんでした。
ですが、この状態でもsocket側に通信データが送られてきた際に、きちんとwParam == socketな状態でWD_READが呼び出されていました。

これは、正規の仕様に乗っ取った挙動なのでしょうか?
例えば「リスニングソケットにFD_READなどを設定しておくと、そのリスニングソケットでacceptされたソケット全部にFD_READが自動的にセットされる」とかでしょうか?


258:デフォルトの名無しさん
09/11/25 18:11:24
asyncも分かってないしselectも分かってないな

259:デフォルトの名無しさん
09/11/25 20:36:58
ソケット生成してbindした時点で、データが送られてくると
受信はされるのでしょうか?
そこから、recvformで取り出すといった感じなのでしょうか?

データを一定間隔で送信し、送信した結果複数の個所からデータが返ってくる
とした場合、最初に返ってきたデータだけをデータとして取り込みたいのですが
こういった場合、どうするのが最適でしょうか?

260:デフォルトの名無しさん
09/11/25 20:48:26
スタックって自作できるのでしょうか?
スタックを自作すれば、L1レベルから入ってきたデータを好きなように取り込めるのでしょうか?


261:デフォルトの名無しさん
09/11/25 21:07:50
IEの仕様書はどこにありますか
MicroSoftのサイトの情報見ても全然かゆいところに手が届かない

262:デフォルトの名無しさん
09/11/25 21:23:21
>>259
TCPだとそうだね。acceptしてからだけど。
他のは捨てたいって事なら読んでから捨ててクローズすればいい。
読まずに捨てたいってことなら、それはやらない方がいい。
理由はFAQ読んで。上にも話題に出てる。


263:デフォルトの名無しさん
09/11/25 21:24:03
>>260
> スタックって自作できるのでしょうか?

あなたの能力次第。

264:デフォルトの名無しさん
09/11/25 21:25:05
>>259
お前はまずProgramming UNIX Socket FAQを全部嫁。

>>260
できないと思うのなら、それはお前の知識が無いからだ。

>>261
ないんじゃないの?何が知りたいの?

265:264
09/11/25 21:25:51
うお、かぶりまくったぜ。

266:デフォルトの名無しさん
09/11/25 22:10:46
>>264
FAQよんだのですが、bindした時点でデータがきているかはのってないのですが

267:デフォルトの名無しさん
09/11/25 22:38:57
>>266
自覚して無いかもしれないが、日本語に難ありすぎて意味不明

268:デフォルトの名無しさん
09/11/25 22:42:18
おそらく
「bindしたあと、recvfromをする前に到着したメッセージは
全て、その後の recvfrom で読み出せるのか?」
と質問したいんだろう

269:デフォルトの名無しさん
09/11/25 23:10:46
>>260
BSDのドライバのソースを読む
Linuxはダメ!絶対

270:デフォルトの名無しさん
09/11/26 09:12:07
257です。
>「リスニングソケットにFD_READなどを設定しておくと、そのリスニングソケットでacceptされたソケット全部にFD_READが自動的にセットされる」
これが仕様に基づく正しい動作であることを、英語版MSDNページで確認しました。

271:デフォルトの名無しさん
09/11/26 11:52:31
こんな何の情報もくれないスレに、律義だなぁ

272:デフォルトの名無しさん
09/11/26 11:55:16
Arduinoとイーサネットシールドを勉強すれば
プロトコルスタックも作れるよ

273:デフォルトの名無しさん
09/11/27 00:25:46
IE8に導入されたInPrivateブラウズって、保存済みのクッキーすら読み込んでくれないん?
クッキーは保存してあるのにリクエストに含まれてこない。
本家サイトみても、”新しくクッキーを保存することはないよん”としか書いてなくてよくわからん。

274:デフォルトの名無しさん
09/11/27 07:14:43
c+winsockでHTTPプロキシ作ろうとしてるんだが
ブラウザから送られてきたhostヘッダの部分を接続先にして
データを受け流す、みたいな感じでいいのか?
その場合httpsの通信はどうするの?

275:デフォルトの名無しさん
09/11/27 07:50:13
hostヘッダがないときでも相手につながないといけないわけだが

276:デフォルトの名無しさん
09/12/01 22:58:35
ブロードキャストで送信しているソケットで、受信もしていて

そのソケット宛に、VBのwinsockでブロードキャストで送信しようとすると
ローカルコンピュータからは利用できませんとエラーがでたり、
二つのパソコン用意して、同様にVBからHUBを介してそのソケット宛にデータ送ろうとすると
片方はブロードキャストでおくれるのだが、もう片方はデータすらおくれない

同じネットワークにブロードキャスト送信できる数とかに制限あるのかな

277:デフォルトの名無しさん
09/12/02 00:39:07
TCP/IPにはそのような制限はない。
WinsockやVBについては知らないので他の人お願い。

278:デフォルトの名無しさん
09/12/02 00:50:18
知らないなら黙ってればいいのに

279:デフォルトの名無しさん
09/12/02 04:36:18
そりゃブロードキャストで送ればネットワークに負担がかかるし、不要なPCにもパケット送りつける事になってしまうからなあ。

280:デフォルトの名無しさん
09/12/02 13:41:20
だから何だよ?

281:デフォルトの名無しさん
09/12/02 15:18:33
ブロードキャストって何?

282:デフォルトの名無しさん
09/12/02 17:14:15
放送

283:デフォルトの名無しさん
09/12/02 19:57:05
PC-HUB-PC でUDPにてお互い同時に周期的に送信していて、たまにパケットが喪失するのですが
これってどんな原因が考えられますか?

284:デフォルトの名無しさん
09/12/02 20:16:18
気にする方向を間違えている
その件に関して我々は原因を追究するべきではない

285:デフォルトの名無しさん
09/12/02 20:24:28
>>283
天使の取り分

286:デフォルトの名無しさん
09/12/02 21:46:07
udpでもtcpでもパケットは消失するものなんだよ。
tcp: osがどうにかしてくれる。
udp: 自分でどうにかするか諦める。

287:デフォルトの名無しさん
09/12/02 21:52:35
ただ、HUBを介して単純に超近くのネットワークなのに、他にそのパソコン以外通信なし
でも頻繁に損失するものなのかなーとおもいまして

何回に1回とか大体の確率っておおよそでいいからわかるのかなぁ

288:デフォルトの名無しさん
09/12/02 21:56:49
消失が完全に予測出来るなら暗号に使えるな

289:デフォルトの名無しさん
09/12/02 22:01:07
LAN側に古いハブ使ってるがコリジョンランプがガンガンつきまくってる
仕組みはよくわからんが、よく通信できてるもんだと関心するほどだ

290:デフォルトの名無しさん
09/12/02 22:51:42
HUBを介すのと介さないのでは喪失しやすくなったりするのかね

291:デフォルトの名無しさん
09/12/02 23:15:48
お互いに交互に投げ合ってるならぶつからないだろうけど
同時に投げてるならぶつかるんじゃないのか?

292:デフォルトの名無しさん
09/12/03 00:03:33
交互に投げ合っててもいつか同時のタイミングが発生しそうな

293:デフォルトの名無しさん
09/12/03 00:11:30
CSMA/CDか
久しぶりに思い出したんで忘れかけてたよ

294:デフォルトの名無しさん
09/12/03 00:22:50
>>290-292
お前等スイッチングハブの「スイッチ」の意味知らないだろ。
パーフェクトシャッフルとかバタフライネットワークとか。

295:デフォルトの名無しさん
09/12/03 00:25:44
なにはともあれ、今つかってるバカハブは捨てるべきだな。俺。
末端のTVとDVDレコ用だけど・・・

296:デフォルトの名無しさん
09/12/03 00:36:53
PC−PC のように単純にケーブル1本でお互い送受信していても
UDPならパケットの衝突か消失がありうるということ?

297:デフォルトの名無しさん
09/12/03 00:44:04
何がおこってもおかしくはない
ノイズやバッファオーバーなど色々あるんじゃない?
UDPがそれらに保障されてないんだから、プログラマとしてはそれを考慮してプログラムを組むしかない

298:デフォルトの名無しさん
09/12/03 00:50:43
>>296
ループバックインターフェースでも消失はありうる。

299:デフォルトの名無しさん
09/12/03 01:00:56
>>297
バッファオーバーはデータのサイズを小さくもてば少なくなるのかなぁ
ノイズでそんなに頻繁になくなるのかな PC-PCとかでも

1分間に10回ほど消失するって大きい?

300:デフォルトの名無しさん
09/12/03 01:20:10
今では低速なRS232Cでも電気的に失敗することはある
クロックだのなんだの、下位の仕事してたころにはこれでいいのかなと疑問に思いながら作ってたもんだ…
もちろん通信の失敗を考慮してプログラムしてたが

301:デフォルトの名無しさん
09/12/03 01:52:47
今時ノイズは余り関係ない。イーサネットで距離も短ければ。

302:デフォルトの名無しさん
09/12/03 02:02:47
プログラム組む側としては、そんな話はどうでもいいんだって。

303:デフォルトの名無しさん
09/12/03 02:05:58
距離も短くノイズも関係ないとすればたかだがPC間伝送でパケット消失する理由って・・・

304:デフォルトの名無しさん
09/12/03 02:10:04
バッファなりなんなり能力以上の処理が必要になれば当
然パケットは落ちる。忙しい状況は自分のプログラムと
は無関係に発生するかも知れない。TCP は再送する。
UDP は再送しない。

305:デフォルトの名無しさん
09/12/03 08:35:33
バカハブは貴重品だぞ。
簡単には手に入らないが価値をしらないバカの手元にあるのはもったいない。

306:デフォルトの名無しさん
09/12/03 09:22:54
スニファ作るとか?

307:デフォルトの名無しさん
09/12/03 09:24:49
開発用にリピータハブ重宝しております

308:デフォルトの名無しさん
09/12/03 11:12:41
>>299
ping 1時間くらい投げ続けてlossどれくらい?

309:デフォルトの名無しさん
09/12/03 17:30:01
初歩的な質問ですいません。
よくある「"ABCDEFGH"と送信しても"ABC""DE""FGH"と3回で受信されることもある」という例ですが、
この例は送信がTCP/UDPレベルで計3パケットに分割されたということなるのでしょうか?

310:デフォルトの名無しさん
09/12/03 17:31:36
送信かもしれない
途中の道かもしれない
受信かもしれない

311:デフォルトの名無しさん
09/12/03 17:33:06
逆に2回にわけて送ったやつがくっついてることもある

312:デフォルトの名無しさん
09/12/03 19:10:15
既にクローズされてるソケットにclosesocket使ったらエラーで強制終了される?

313:デフォルトの名無しさん
09/12/03 19:25:44
エラーだが強制終了されない

314:デフォルトの名無しさん
09/12/03 22:20:48
>>309
UDPならAPIレベルでは分割されないよ。
データグラム通信を提供するサービスだから。

315:デフォルトの名無しさん
09/12/04 00:44:49
何か障害出まくるアプリケーションが多いのがよくわかるスレだ。
絶対はないから、ちゃんと回避手順を考えてプログラム組むべき。
エラーになったらどうするのか。想定してなかったので、そのまま終了じゃゴミ。

316:デフォルトの名無しさん
09/12/04 22:21:18
オーストリッチアルゴリズム最強

317:デフォルトの名無しさん
09/12/11 00:06:40
プロキシを作りたいのですが
どうやって作ればいいのでしょうか?

書籍とかあれば教えてください

318:デフォルトの名無しさん
09/12/11 00:09:04
プロ棋士?

319:デフォルトの名無しさん
09/12/11 00:10:07
どのような情報を盗み見たいの?それによって作り方変えないと

320:デフォルトの名無しさん
09/12/11 00:17:04
>>319
透過プロキシ+多層です

321:デフォルトの名無しさん
09/12/11 00:20:31
>>319
サイバー犯罪幇助で通報しますた

322:デフォルトの名無しさん
09/12/11 02:48:29
つまり勝手にパケット横取りしてナニしたいと。

323:デフォルトの名無しさん
09/12/11 03:10:33
誰かが串通して児ポとかダウンロードした日には死ねるなw

324:デフォルトの名無しさん
09/12/11 03:24:38
透過プロキシ - Google 検索
URLリンク(www.google.co.jp)透過プロキシ


325:デフォルトの名無しさん
09/12/11 09:08:36
URLリンク(homepage2.nifty.com)

326:デフォルトの名無しさん
09/12/11 12:47:22
recvに渡した最大受信バイト数を超えるデータを受け取ると
文字列が途切れて文字列操作に支障が出ることがあるんだが
バッファサイズデカくするしか無いの?

327:デフォルトの名無しさん
09/12/11 12:49:03
最大受信バイト数を超えるデータを受信するわけないじゃんw

328:デフォルトの名無しさん
09/12/11 17:31:06
>>326
n回受信→連結 してから操作しちゃだめなん?

多分 TCP だと思うが、
分割されることだって(1回の send なのに 受け側は recv 2回になった)あるし
まとまることだって(2回の send が、受け側は recv 1回でまとまって読めた)ある

329:デフォルトの名無しさん
09/12/11 19:04:45
>>326
バッファサイズをでかくするか、
自分でバッファリングするなりしてやらないとダメだよ

330:デフォルトの名無しさん
09/12/11 22:14:24
proxyってどうやって作るの?

331:デフォルトの名無しさん
09/12/11 22:31:27
そんなレベルの人には関係ありません

332:デフォルトの名無しさん
09/12/11 23:39:31
アプリケーション層じゃなくて
なんとか層とかいうレベルの処理をするんだっけ?

333:デフォルトの名無しさん
09/12/11 23:43:08
そうかお前らスキル低いから答えられないのか
それなら仕方ないな

334:デフォルトの名無しさん
09/12/11 23:45:25
はいはいそうでちゅよ〜

335:デフォルトの名無しさん
09/12/12 00:13:27
中途半端に教えたところでレベルの低い人間には無意味だしね

336:デフォルトの名無しさん
09/12/12 00:35:31
UDPのrecvfromで、サイズを指定しますよね
そのサイズって、たとえば1400バイトのデータが送られてきて
recvfromの引数でサイズを400で指定してやると、400バイトだけ
バッファにため込みますよね

残りの1000バイトはどうなるのでしょうか?
次にrecvfromしたときに400バイトだけそこからまたよみこむのでしょうか?

337:デフォルトの名無しさん
09/12/12 00:40:06
yes

338:デフォルトの名無しさん
09/12/12 00:40:47
嘘を教える奴は最低な奴だと思う

339:デフォルトの名無しさん
09/12/12 01:02:15
>>336
残りの1000バイトは粉みじんになって死んだ・・・

340:デフォルトの名無しさん
09/12/12 01:04:35
では、1400バイトのデータが2回に分けて連続して送信されてきました。

2回送信されたあとに、recvfromで400バイト読んだとすると、
残りのデータはすべて消えるのでしょうか?
あるいは、3000バイト読めば全て読めるということでしょうか

341:デフォルトの名無しさん
09/12/12 01:07:44
せめて試してから質問しろよな

342:デフォルトの名無しさん
09/12/12 01:08:57
>>340
1回目の送信が1000バイト、2回目が400バイトだったとしよう。

1回目を400バイトのバッファで受信したら、残り600バイトはパァだ。
2回目の400バイトは・・・おめでとう、すべて受信出来たな。

343:デフォルトの名無しさん
09/12/12 01:09:54
recvfrom 受信バイト - Google 検索
URLリンク(www.google.co.jp)受信バイト




344:デフォルトの名無しさん
09/12/12 01:10:10
>>343
Opera使いか?

345:デフォルトの名無しさん
09/12/12 01:13:52
>>1-7のテンプレは読んだのか?

346:デフォルトの名無しさん
09/12/12 01:14:35
>>345
イミフ

347:デフォルトの名無しさん
09/12/12 04:10:17
ipは途中でルータが処理するの辛く成ったら捨てていいよって通信手順だしな。
届かなきゃ、再送するしか無い。まあ再送しまくると余計にルータが辛く成って捨てられるけどなw
お利口なルータは捨てたら一応icmpで通知はしてくれる。ファイヤウォールとかでicmp捨ててたら当然届かないけどw

348:デフォルトの名無しさん
09/12/12 11:14:57
>>342
バッファって、どこのバッファですか?

349:デフォルトの名無しさん
09/12/12 12:07:31
>>348
あなたがデータを受け取るためにrecvfromの第2引数に指定したバッファ

350:デフォルトの名無しさん
09/12/12 12:34:01
UDPのカーネル内での受信バッファサイズって
どこで規定されてたっけ?defineとかあった?

あと、これは勉強不足から来る質問なんだけど
IPv6でも65536-20-8=65516が最大サイズでおk?

351:デフォルトの名無しさん
09/12/12 15:40:03
>>349
ありがとうございます

ただ、1000バイトと400バイトのデータが送られてきて
ソケットのバッファ?にたまってますよね

それをrecvfromで400バイトずつ取り出すと、残り600バイトが
パーになるとのことですが、

どうやってrecvfromは、1回目の1000バイトと2回目の400バイトを
別として見分けるのでしょうか

352:デフォルトの名無しさん
09/12/12 15:43:23
UPDの仕様は理解したうえでの質問なんだよな?

353:デフォルトの名無しさん
09/12/12 15:43:57
ソフトを作る団塊で通信するパケットサイズ決めておくんじゃね?

354:デフォルトの名無しさん
09/12/12 15:45:55
>>351
取り出したらああああああああああああああssssssss

見分けるというか、パケット単位で管理してる。
recvfromでパケットごとに取り出すので
取り出す際に余った分は破棄される

355:デフォルトの名無しさん
09/12/12 15:52:28
そもそもUDPなの?

356:デフォルトの名無しさん
09/12/12 15:58:18
どうせ釣りだろ

357:デフォルトの名無しさん
09/12/12 18:07:41
ほんとにTCP/IPの知識ないのにネットワークプログラミングやろうとする奴多すぎ

358:デフォルトの名無しさん
09/12/12 18:10:11
やれば知識がつくんだからいいじゃない

359:デフォルトの名無しさん
09/12/12 18:11:57
プロトコル層とかなんちゃら層とか

360:デフォルトの名無しさん
09/12/12 18:24:35
>>351
> どうやってrecvfromは、1回目の1000バイトと2回目の400バイトを
> 別として見分けるのでしょうか

>>354 が言う通りパケット毎に管理してる。

そもそも recvfrom() は引数で送信元アドレス/ポート
が取得できるだろ。連続して違う相手から受信したらデー
タが混じるとでも思ってるのか?

361:デフォルトの名無しさん
09/12/12 19:46:46
65536-20-8=65508だったな。計算間違えたぜ。
このサイズ以上はOS側で落とされるな。

362:デフォルトの名無しさん
09/12/12 21:04:26
proxyの作り方教えてください

363:デフォルトの名無しさん
09/12/12 21:13:42
proxy 作り方 - Google 検索
URLリンク(www.google.co.jp)作り方

364:デフォルトの名無しさん
09/12/12 21:14:06
>>360
recvfromがまとめてパケットを1回でとりこむかなとおもいまして・・・
そういう部分は、recvfromの関数がソケットと関連づけられてつくられてるのかな

365:デフォルトの名無しさん
09/12/12 21:24:48
他のプログラムが使用してるソケットにデータを送ることってできないの?
某ネトゲチートツールみたいに

366:デフォルトの名無しさん
09/12/12 21:38:12
>>365
自分で答えを書いているじゃないか。

367:デフォルトの名無しさん
09/12/12 21:47:59
p2proxyみたいに

368:デフォルトの名無しさん
09/12/12 23:20:21
>>365
Windows? Linux?
Linuxなら結構簡単

369:デフォルトの名無しさん
09/12/15 21:34:53
自作したプログラムで(おそらく)存在しないURLにアクセスすると
3000回くらいで、ネットワーク自体から切断されます
ISPにも問い合わせましたが、このプログラムを止めてくれと言うだけで
原因がはっきりしません

ループ文使って sprintf( http, "URLリンク(....%d.jpg)", i );
とURLを作ってるのですが
なにかしらの暗黙のルールなどあるのでしょうか?

WindowsAPI使ってます

370:デフォルトの名無しさん
09/12/15 21:48:30
ISP側に同情するわ

371:デフォルトの名無しさん
09/12/15 21:55:11
>>369
阿呆かお前は
ネットワークプログラムのテストするなら
まずはローカルで試してからだろボケ

致命的なバグを抱えているかも知れんのに
常識を疑われてもしょうがないレベルだな

372:デフォルトの名無しさん
09/12/15 22:01:37
sprintfで外に出ていってしまうん?

373:デフォルトの名無しさん
09/12/15 23:24:59
おまえは何を行っているんだ

374:デフォルトの名無しさん
09/12/16 00:31:54
連番jpgを物故抜きしてんのか?
ネットランナーでも買っとけ

375:デフォルトの名無しさん
09/12/16 00:39:10
>>369
> 原因がはっきりしません

しとるがなw

376:デフォルトの名無しさん
09/12/16 01:07:36
DoSアタックと判断されて蹴られてると考えるのが普通だな
俺が管理者なら攻撃とみなしてISPに通報するね


377:デフォルトの名無しさん
09/12/16 01:11:33
IPS(ISPじゃないよ)で自動的に切断です。

378:デフォルトの名無しさん
09/12/16 01:14:44
IPS インターネット プロバイダ サービス
ISP インターネット サーバー プロトコル

379:デフォルトの名無しさん
09/12/16 02:42:06
>>378
無知を晒して楽しいか?

380:デフォルトの名無しさん
09/12/16 07:19:11
preventionなのかprotectionなのか

381:デフォルトの名無しさん
09/12/16 07:23:39
脳内返答ばかりやな
役に立たんゴミども

382:デフォルトの名無しさん
09/12/16 09:44:38
んなこといったって、状況説明がほとんどないんだから脳内補完して答えるしかねーだろ

とりあえずどうせ、1鯖へのコネクションは同時に2本まで。というルールすら守ってないんだろ・・・

383:デフォルトの名無しさん
09/12/16 09:51:31
負荷下げるためにkeep-alive使ったり、それで性能がほしければ
パイプライニングしたりするべきだが...

384:デフォルトの名無しさん
09/12/16 12:02:10
まあうざいのはdenyされるので、がんばっても無理だけどな。
相手の許容範囲で出来る事を遣るしか無い。

385:デフォルトの名無しさん
09/12/16 15:34:03
>>382
>同時に2本まで。というルールすら
>>369 に、「同時にコネクション張る」甲斐性があるとは思えません。

386:デフォルトの名無しさん
09/12/16 16:44:19
問い合わせたお(^ω^)

テンプレが返ってきたお(;ω;)

お問合せいただきました事象によるネットワークからの切断に
つきましてですが、大変申し訳ございませんが弊社で判断する
ことは困難な状況です。

うんこ様のご利用いただいております電話回線に関しまして、通常時に
故障などが発生した場合には、フレッツサービスに関するお問合せ先が
ございますので、下記フリーダイヤル番号までご連絡いただきますよう
よろしくお願い致します。

とりあえず、コネクション2つ以上とかアホ言ってるやつは士ね

387:デフォルトの名無しさん
09/12/16 17:04:16
サムライ呼ばわりとは是如何に

388:デフォルトの名無しさん
09/12/17 00:38:13
ファイヤーウォールみたいに通信に割り込みかけるのってどうやるの?

389:デフォルトの名無しさん
09/12/17 03:17:17
ちょっと待ってて

390:デフォルトの名無しさん
09/12/17 09:10:01
架空URLに高速連続問い合わせとか、DNS鯖に対する攻撃か・・・?
警告はおろか、実際に査察が来るレベルだぞ

391:デフォルトの名無しさん
09/12/17 11:23:39
友人がPING(のようなもの)を飛ばしまくって、JPNICからリアル警告くらってたな
その話聞くまで都市伝説だと思ってたよ俺も

392:デフォルトの名無しさん
09/12/17 11:25:58
信用できねぇ

393:デフォルトの名無しさん
09/12/17 11:40:10
>>392
一般的に考えるとJPNICからってのが胡散臭い感じがするけど
それが本当なら恐らくmrtgみたいなことしようとして主要IXとかに
pingしまくって怒られたって話なんじゃないかと。

394:デフォルトの名無しさん
09/12/17 11:45:15
むちゃな事をしなけりゃ一生縁の無い話なんだから、どうでもいいなw

395:デフォルトの名無しさん
09/12/17 12:10:06
どうでもいい

396:デフォルトの名無しさん
09/12/17 12:34:03
昔はTCPのスタックの負荷テストするのにテキトーなサイトの
chargenポートに繋いだもんだったw

397:デフォルトの名無しさん
09/12/17 12:41:22
(自慢話は)どうでもいい

398:デフォルトの名無しさん
09/12/17 12:41:54
パソコン通信の時代はプログラム的にはどう接続してたの?
たしか相手先の電話番号にダイヤルアップで直に接続してたんだよね?

399:デフォルトの名無しさん
09/12/17 12:46:20
モデムのシリアル接続で直に。基本はテキストのみ。

バイナリをやりとりする時は XMODEM その他のプロトコルで。

400:デフォルトの名無しさん
09/12/17 13:03:50
相手PCとの同期とかどうしてたの?

401:デフォルトの名無しさん
09/12/17 13:04:55
図書館とかで古いパソコン雑誌見るとパソコン通信の電話番号とかたくさん掲載されててなんかすごかったわw

402:デフォルトの名無しさん
09/12/17 13:07:13
同期もなにも、相手のデータを引っ張り出すだけだからなぁ
telnetとかわらん感じだが

403:デフォルトの名無しさん
09/12/17 13:09:02
なるほど。細かいところはハードウェアかOSあたりが処理してたのか。今と変わらんのか。
今でもやろうと思えばパソコン通信ってできるの?

404:デフォルトの名無しさん
09/12/17 13:09:33
>>400
モデムの上位は無手順。
基本はデータをただ流すだけだけど、
スタートビット、ストップビット、パリティビットなどの取り決めがある。


405:デフォルトの名無しさん
09/12/17 13:11:12
オサーンが多いことだけはわかった

406:デフォルトの名無しさん
09/12/17 13:12:03
>>404
そのビットとかはプログラム側で処理するの?

407:デフォルトの名無しさん
09/12/17 13:14:21
RS232C(COM)プログラムしてみりゃわかる
ただ設定をちょこっと命令するだけ

408:デフォルトの名無しさん
09/12/17 13:15:26
>>406
ちったあ手前で調べろや禿。つーか、シリアルI/Oも知らんのか。
最近のPCは非搭載なのが増えたせいか?

409:デフォルトの名無しさん
09/12/17 13:16:03
周辺機器との通信と同じってことかな?ふ〜ん今のプロトコルとかより簡単そうだね

410:デフォルトの名無しさん
09/12/17 13:16:51
本気で聞く気がなけりゃこんなもんだろう

411:デフォルトの名無しさん
09/12/17 13:17:10
みなさんの貴重はお昼休みをどうもありがとうございました^^

412:デフォルトの名無しさん
09/12/17 13:20:22
テンプレに本気じゃないやつは訊かずに自分で調べろとでもいれとくかw

413:デフォルトの名無しさん
09/12/17 13:26:14
もう232Cでのプログラムなんてやらなくなっちゃったしな
USBばっかだし(USBもシリアルじゃんって言わないの)

414:デフォルトの名無しさん
09/12/17 13:26:32
その通信の先にppp接続がある

415:デフォルトの名無しさん
09/12/17 13:42:58
232Cポートが無くなっても、
最新のLinuxで毎日使う端末画面はボーレート38400bps

416:デフォルトの名無しさん
09/12/17 13:48:44
たった今も機器とのシリアル通信のコード書いてるんだが・・・(マイコン系)

417:デフォルトの名無しさん
09/12/17 14:01:00
>>413
USBシリアルデバイスって知らないの?
USBは上位プロトコルは既存のプロトコルを採用している。

418:デフォルトの名無しさん
09/12/17 14:08:53
知ってて「突っ込むな」と書いてあるように思うんだが。

419:デフォルトの名無しさん
09/12/17 14:13:00
まさかストレートにつっこまれるとは思わなかった

420:デフォルトの名無しさん
09/12/17 14:42:31
最近はマイコンでもシリアル通信用のライブラリがあるからなー
AVRでUARTとMAX232でPCの232Cとシリアル通信したことあるよ。


421:デフォルトの名無しさん
09/12/17 15:02:05
USB仕様が物理層でシリアルなことと、
USBシリアルデバイスがデータリンク層でシリアル型プロトコルであることは別。


422:デフォルトの名無しさん
09/12/17 15:32:15
で?

423:デフォルトの名無しさん
09/12/17 15:35:37
パソコンに繋いだ外部機器との通信とかドライバのことってこのネットワークスレでいいの?

424:デフォルトの名無しさん
09/12/17 15:37:05
マウスとかは勘弁して欲しいけどw、
HP-IBとかそういうのは構わないんじゃないの

425:デフォルトの名無しさん
09/12/17 15:40:53
ども、質問できるスレを確保したので本格的に勉強始めますわ。どもでしたー

426:デフォルトの名無しさん
09/12/17 21:16:44
あいよ−

427:デフォルトの名無しさん
09/12/17 23:57:39
念力はだめだからな

428:デフォルトの名無しさん
09/12/18 10:10:20
ふーん

429:デフォルトの名無しさん
09/12/18 13:26:24
エスパー問題なら俺に任せて。
他人のバグなら7秒で解決する。

430:デフォルトの名無しさん
09/12/20 10:57:32
>>429がデバッグを完了するタイムは、わずか7秒にすぎない。
では、デバッグプロセスをもう一度見てみよう。

431:デフォルトの名無しさん
09/12/21 00:01:19
>>429
エスパーが質問に答えるスレ
スレリンク(tech板)

どうかお帰り下さい

432:デフォルトの名無しさん
09/12/21 18:30:51
エスパーを迫害中ですか

433:デフォルトの名無しさん
09/12/22 01:54:36
そのうち「テラへ」スレになりそうだ

434:デフォルトの名無しさん
09/12/22 02:28:36
雑誌を次々と潰していくエスパーよりはいいかもな

435:デフォルトの名無しさん
09/12/22 03:10:35
>>434
ここ何年かは潰してないだろ!

436:デフォルトの名無しさん
09/12/26 17:17:14
マルチスレッドのクライアントを作ろうとしてるんだけど
なんかエラーが出る件

WSAStartupはメインで1度呼ぶだけでいいんだよね?

437:デフォルトの名無しさん
09/12/26 23:56:55
>>436
はい

438:デフォルトの名無しさん
09/12/27 12:54:52
>>437


439:デフォルトの名無しさん
09/12/27 14:04:18
Yahooでは返答がなかったのでこちらに質問します

HTMLフォームにキーワードを入れてクリックする処理

たとえば URLリンク(www1.axfc.net)
のようなサイトで、ファイルをダウンロードするにはキーワードを入れる必要があります
今回のサンプルでは test といれてクリックすればダウンロードできます
これをプログラムで処理したいのです

短く言うと
フォームにキーワードを入れて、クリックする処理をプログラムで実現したい


C/C++で処理したいと考えてます
サンプルソースなど教えていただけないでしょうか?

OSはWindowsです


440:デフォルトの名無しさん
09/12/27 14:18:28
そんなニッチな作業をするピンポイントなサンプルは無い
キーワードは固定なのか?
ネットワークプログラミングスレでその質問をするということは、
まずソケットの扱い方とHTTPの仕様を理解しなければならないな

441:デフォルトの名無しさん
09/12/27 14:39:02
ネットワークプログラミングじゃねーじゃん
IEコンポでも使えばいいよ

442:デフォルトの名無しさん
09/12/27 14:58:15
>>439
この辺で十分だよ
URLリンク(www.happy2-island.com)


443:デフォルトの名無しさん
09/12/27 15:01:39
>>439
libcurl使え

444:デフォルトの名無しさん
09/12/27 15:05:47
スレリンク(tech板)
スレを勃てるまでもないC/C++の質問はここで 13
スレリンク(tech板)
C/C++の宿題片付けます 133代目

445:デフォルトの名無しさん
09/12/27 16:24:46
Winsock2なんですがサーバアプリケーションで連続してacceptすると100回のうち1〜2回ぐらい、

1)メインスレッドで sock=accept()  −> INVALID_SOCKETではない
2)メインスレッドで sockを別スレッドに渡す
3)別スレッドで event = WSACreateEvent();
4)別スレッドで WSAEventSelect(sock,event,...)  −> SOCKET_ERROR 発生(WSAGetLastError()は10038)

という状態が起きます。

メインスレッドでは accept()後、別スレッドに処理を渡してすぐに戻る仕様です。
また、別スレッド管理は空いているスレッドがなければ作成、アイドル中のスレッドがあればそれを使用、
接続中のスレッドが3コになったら、空きができるまでaccept()には戻りません。

同時に2つ以上の接続要求が来なければ、問題なく動作しているようなのですが接続要求が連続してくると上記のような症状が発生します。

原因になりそうなことが分かる方はいらっしゃいますか?

446:デフォルトの名無しさん
09/12/27 17:08:56
メインスレッドがちゃんと渡してないのでは。

447:デフォルトの名無しさん
09/12/27 17:17:37
Winsock2は詳しくないんだが、エラーコード10038の意味は何?
それを調べる事から調査が始まるのではないかと。

448:デフォルトの名無しさん
09/12/27 18:23:22
>>446
デバッグ用にコードを仕込んで確認しました。
acceptから受けたsock(メインスレッド) と WSAEventSelectに渡されるsock(別スレッド)は同じでした。

>>447
WSAENOTSOCK
10038
Socket operation on nonsocket.
An operation was attempted on something that is not a socket.
Either the socket handle parameter did not reference a valid socket, or for select, a member of an fd_set was not valid.

です。
有効なソケットではないという感じです。


449:445
09/12/27 23:10:32
>接続中のスレッドが3コになったら、空きができるまでaccept()には戻りません。
この部分を1コに変更する(つまり、ひとつの接続が完了するまで次のaccept()には戻らない)と上記のようなエラーは発生しなくなります。

450:デフォルトの名無しさん
09/12/28 13:18:33
メインスレッドからポインタでデータを渡していて
スレッドで読んでる最中に上書きしちゃてるとか

451:デフォルトの名無しさん
09/12/28 14:54:36
タイムアウトのためだけにselect使う場合は
FD_ISSETは使うわなくていいんだよな?

452:デフォルトの名無しさん
09/12/28 15:17:55
>>451
エラー要因はちゃんと見とけよ
割り込みだったら待ちなおしだ

453:445
09/12/28 18:06:48
>>450
SOCKET型変数を値渡ししています。
どこかで上書きしちゃっている可能性も考えたので>>448で実験していましたが
エラー発生時のメインスレッドのsock(SOCKET型) と値渡ししたsock(SOCKET型) は同じ数値でした。
また>>445の1〜4のうち、1と2の間でも、acceptの戻り値がINVALID_SOCKETであるかどうかの確認を行っています。
このときにはINVALID_SOCKETではないのに、別スレッドに渡した後のWSAEventSelect()やWSAEnumNetworkEvents()でSOCKET_ERRORになります。
SOCKET_ERRORの時はif(WSAGetLastError()==WSAEWOULDBLOCK)...の処理を入れてあります。

454:デフォルトの名無しさん
09/12/28 18:39:56
別のとこで同じソケット使おうとしてるんだろ

455:デフォルトの名無しさん
09/12/28 18:41:34
よく分からないけど、WSAEventSelect()のほかのパラメタも
見直してみてはどうかな

第一引数のソケットは正しくても WSAENOTSOCKが返ることも
あるみたいだし
URLリンク(groups.google.co.jp)

456:デフォルトの名無しさん
09/12/28 22:47:31
排他制御が出来て無くて他のスレッドで無効にしてるんだろ。

457:445
09/12/29 00:06:22
>>455
ありがとうございます。
リンク先のURLはWSAEventSelect(...)の2番目の引数はWSAEVENT*ではなく、WSAEVENTだよってことですよね?
(ソースはWSAEVENT**を渡そうとしているようですが)

>第一引数のソケットは正しくても WSAENOTSOCKが返ることもあるみたいだし
SOCKET_ERRORを返した場合でも、一定時間待機後リトライするようにしたところ、成功することがあるということが分かりました。
それでもまだ失敗する場合もあるようですが、かなり改善しました。
いろいろ試してみます。

>>456
それはないと思うのですが。
スレッド間で異なる値のソケットを持っていますし、アドレスで渡してはいないので別スレッドのソケットを参照してしまうこともないです。
スレッド間の排他制御以前の問題だと思います。

458:デフォルトの名無しさん
09/12/29 08:27:42
>>457
> スレッド間の排他制御以前の問題だと思います。
自分のコードが間違っていると言う考えには至らず、システムに原因があると考える、
典型的な初心者。
100%に近い確率でお前のコードのどこかが、SOCKETを無効にしているか無効なソケット
を渡されたのをチェックせず見逃している。

459:デフォルトの名無しさん
09/12/29 10:29:25
コードをうpすれば間違いを指摘してやるのにな

460: ◆0uxK91AxII
09/12/29 10:40:02
>>453
>エラー発生時のメインスレッドのsock(SOCKET型) と値渡ししたsock(SOCKET型) は同じ数値でした。
それは、acceptの戻り値と一致するのかな、っと。

461:445
09/12/29 18:33:55
>>458
>自分のコードが間違っていると言う考えには至らず、システムに原因があると考える、
違いますね。
排他制御以前に自分の「winsock2の取り扱い方」に問題があると思っています。

>>460
>メインスレッドのsock(SOCKET型)
これがacceptの戻り値です。

462:デフォルトの名無しさん
09/12/29 19:09:11
>461
ぐだぐだ言ってねぇでいいからSOCKETを渡してるとこと受け取ってるとこをmutexでくくれ。
話はそれからだ

463:デフォルトの名無しさん
09/12/29 19:29:44
> 排他制御以前に自分の「winsock2の取り扱い方」に問題があると思っています。
socket, acceptでSOCKET作る。使う。閉じる。これだけなのに使いこなせないとは
よほどのヘボということになるが。

464:デフォルトの名無しさん
09/12/29 19:34:22
仕事の話なら「死んでくだしあ」になるけど
趣味ならしょうがないというか、よくある話でしょう。

465:デフォルトの名無しさん
09/12/29 22:03:57
勘違いしてました、とかよくあるからな

466:デフォルトの名無しさん
09/12/29 22:26:02
2ちゃんねるはもっと親切な場所だと勘違いしてました(><)


467:デフォルトの名無しさん
09/12/29 22:44:11
2ちゃんねるが親切とか、どこを見ればそんな勘違いできるんだろう

468:デフォルトの名無しさん
09/12/29 22:47:40
俺がいるからこういう勘違いをさせてしまう

469:デフォルトの名無しさん
09/12/30 02:50:22
オヤギリ・・・ゴクリ

470:デフォルトの名無しさん
09/12/30 11:49:29
みんな、すまん

471:デフォルトの名無しさん
09/12/30 12:04:37
うむ

472:デフォルトの名無しさん
09/12/30 15:49:10
2ちゃんねるは 匿名で知らない新人のかげぐちを言う
最低のゴミクズのチンカス野郎のあつまりですよ(^-^)

473:デフォルトの名無しさん
09/12/30 15:52:37
チンカスって何?

474:デフォルトの名無しさん
09/12/30 16:01:04
>>473
あなたのことですよ(^-^)

475:デフォルトの名無しさん
09/12/30 19:30:21
>>453
> SOCKET_ERRORの時はif(WSAGetLastError()==WSAEWOULDBLOCK)...の処理を入れてあります。

こういうWSAGetLastErrorの使い方されれると、
ドキュメントに書いてあること守っているかどうか気になるなあ。


次ページ
最新レス表示
スレッドの検索
類似スレ一覧
話題のニュース
おまかせリスト
▼オプションを表示
暇つぶし2ch

4823日前に更新/115 KB
担当:undef