質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.46%
Chrome

Google Chromeは携帯、テレビ、デスクトップなどの様々なプラットフォームで利用できるウェブブラウザです。Googleが開発したもので、Blink (レンダリングエンジン) とアプリケーションフレームワークを使用しています。

Node.js

Node.jsとはGoogleのV8 JavaScriptエンジンを使用しているサーバーサイドのイベント駆動型プログラムです。

UDP

UDP(User Datagram Protocol)とは、トランスポート層のプロトコルであり、コネクション型のデータサービスです。IPネットワーク上の別のホストにコンピュータのアプリケーションがメッセージを送ることができ、転送チャンネルやデータ経路を設定する必要はありません。TCPに比べて高速であるが、信頼性が薄いという特徴があります。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

SNMP

SNMPとは【Simple Network Management Protocol)】 ネットワークに接続しているデバイス等の情報を 収集し、ネットワーク監視や制御の管理を行うためのプロトコルです。

Q&A

解決済

2回答

17156閲覧

Webブラウザ上からUDP通信(SNMP検索等)を行いたい

guard_1984

総合スコア13

Chrome

Google Chromeは携帯、テレビ、デスクトップなどの様々なプラットフォームで利用できるウェブブラウザです。Googleが開発したもので、Blink (レンダリングエンジン) とアプリケーションフレームワークを使用しています。

Node.js

Node.jsとはGoogleのV8 JavaScriptエンジンを使用しているサーバーサイドのイベント駆動型プログラムです。

UDP

UDP(User Datagram Protocol)とは、トランスポート層のプロトコルであり、コネクション型のデータサービスです。IPネットワーク上の別のホストにコンピュータのアプリケーションがメッセージを送ることができ、転送チャンネルやデータ経路を設定する必要はありません。TCPに比べて高速であるが、信頼性が薄いという特徴があります。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

SNMP

SNMPとは【Simple Network Management Protocol)】 ネットワークに接続しているデバイス等の情報を 収集し、ネットワーク監視や制御の管理を行うためのプロトコルです。

1グッド

0クリップ

投稿2016/04/10 14:47

編集2016/04/10 16:25

###前提・実現したいこと
お世話になります。
現在Webブラウザ上からプリンタ機器のSNMP検索が出来ないか調査をしています。

前提:まっさらなPC(OSは不問)にWebブラウザ(とりあえずChrome)が入っている状態。
実現したいこと:クライアントサイドのJavaScriptだけでUDP通信を行いたい。

###発生している問題・エラーメッセージ
試そうとしていることは以下になります。
1.Node.jsのnpmからnet-snmp(https://www.npmjs.com/package/net-snmp)をインストール
2.Node.jsのnpmからbrowserify(https://www.npmjs.com/package/browserify)をインストール
3.net-snmpのサンプルコードをbrowserifyで変換
4.Webブラウザで確認

4を実行時にクライアントサイド側でdgram.createsocket is not a functionのエラーが出て失敗しました。

いろいろ調べた結果、dgram内部はNode.js内部で処理しているのでdgramはbrowserify出来ない、
一般論としてクライアントサイド側でWebSocket,XHR,WebRTC以外での通信は出来ないこと、
W3CでUDPソケット通信がドラフトでリタイアされたことは分かりました。
(https://www.w3.org/standards/history/tcp-udp-sockets)

###試したこと
A,dgramをchrome-dgram(https://www.npmjs.com/package/chrome-dgram)に差し替えて試す
dgramがクライアントサイドで利用できないので該当部分をchrome-dgramに差し替えて検証してみました。
この方法だとSNMP検索は出来るのですがChromeアプリをインストール、Chromeアプリ上で実行する為
実現したいこととは少し違います。

B,dgramをdgram-browserify(https://www.npmjs.com/package/dgram-browserify)に差し替えて試す
こちらはdgramを別のパッケージdgram-browserifyに差し替えて試してみました。
結果、dgram-browserifyはdgram.createsocketの部分をWebSocketを代用して作られているため
UDPポートを利用して送信していないためSNMP検索が出来ませんでした。

C,mock-dgram(https://www.npmjs.com/package/mock-dgram)に差し替えて試す
こちらはPC上のメモリをUDP通信と見せかけてデータのやり取りを行っていたので
実際にUDP通信は行われていませんでした。

D,NaCl+PPAPIを利用して外部プログラムからSNMP検索を行う
こちらも実現できていることは確認しましたがA案と同じくWebブラウザ以外に外部プログラムを用意する
必要があるため実現したいこととは少し違います。

JavaScript初心者なのであまりよく分かっていませんが私としては、WebRTC,DNS等でWebブラウザ上から
UDPデータのやり取りが行われているのだからUDP通信できるファイルディスクリプタさえ
JavaScriptで作れたらUDPポートからの通信は出来るんじゃないか?と考えています。

上記手段以外でWebブラウザ上からUDP通信(SNMP検索)を行う手段はあるでしょうか?
以上、よろしくお願いします。

kei344👍を押しています

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

OSCでの通信、bower-dgram等いろいろ調べましたがどれもUDPポートを開くことは出来ませんでした。
現時点ではA案のChromeAppsからChrome.Socket経由でUDP通信を行う方法が堅実そうです。

投稿2016/04/12 15:17

guard_1984

総合スコア13

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

ベストアンサー

Flash / Java Applet ならいけそうな気がします。両方「外部プログラム」といえばそうなのですが、Flash はChromeにはビルトインされているので。

【(技術的な意味で) : UDPパケットを送信する方法まとめ】
http://akiratp.ldblog.jp/archives/65484096.html

投稿2016/04/10 16:02

kei344

総合スコア69462

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guard_1984

2016/04/10 16:15

kei344さん 回答ありがとうございます。 FlashはTCP通信はできるけどUDP通信するにはAdobeAirを入れないと駄目みたいな話をどこかで聞いたので調べてみます。
guard_1984

2016/04/11 11:22 編集

Flashを調べてみたところRTMFPというものが出てきました。  https://ja.wikipedia.org/wiki/Real_Time_Media_Flow_Protocol RTMFPはUDP通信のようですがWebRTCみたいなものでP2Pのチャットなどに使われるようです。ポートも1935および19350〜65535とSNMPとしては使えなさそうです。 JavaアプレットはTCP/UDP通信は出来ますが、Chromeバージョン45で 非サポートになったようなので使うことは難しそうです。 AdobeAirはデスクトップアプリケーションという認識なのでA案と同じく やりたいことと少し違います。 kei344さんの参考サイトを見るとFlashのUDP通信が△になっていますが、 上記のRTMFP以外にUDP送信できる方法ってあるんでしょうか・・・?
kei344

2016/04/11 12:30

RTMFP の事だと思います。Javaアプレットも非推奨になっていたのですね、お役に立てずすいません。 WebRTCのインターネットドラフトにも過去にはSNMPが要求されていたようですが、今の状況は追えませんでした。 【draft-jesup-rtcweb-data-01 - RTCWeb Datagram Connection】 https://tools.ietf.org/html/draft-jesup-rtcweb-data-01#section-10 ただ、Chrome Apps であれば UDP を使えるようです(受信のみ?) 。私の知識ではこのあたりが限界のようです。 【Chrome Apps can now receive broadcast UDP traffic in the latest chromium build¹…】 https://plus.google.com/+FrancoisBeaufort/posts/7w3RouJ471C 【Network Communications - Google Chrome】 https://developer.chrome.com/apps/app_network 【chrome.sockets.udp - Google Chrome】 https://developer.chrome.com/apps/sockets_udp 【GitHub - civic/chrome-app-udpsocket: chrome packaged app sample. UDP packet receive.】 https://github.com/civic/chrome-app-udpsocket 【javascript - Chrome UDP sockets not receiving from remote machine - Stack Overflow】 http://stackoverflow.com/questions/30896044/chrome-udp-sockets-not-receiving-from-remote-machine 【Google Chrome開発版でsocket APIを試す - DiaryException】 http://d.hatena.ne.jp/LaclefYoshi/20120516/1337175348
guard_1984

2016/04/12 15:14

ChromeAppsだとA案ですね。ChromeAppsであればSNMP検索できることは確認しています。 やっぱり拡張機能使わないと実現出来なさそうなんですね。 調べていただきありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.46%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問