0

我正在编写一个使用套接字与 Java 服务器通信的 chrome JS 扩展。当我使用以下行时:

var socket = chrome.socket || chrome.experimental.socket;
socket.create('tcp',{},function(createInfo) {

我明白了

Error in event handler for 'tabs.onUpdated': Cannot read property 'socket' of undefined TypeError: Cannot read property 'socket' of undefined

错误(JS 代码在 tabs.onUpdated 函数中)。

我的清单文件是:

{
      "manifest_version": 2,

  "name": "MitM Phishing Detector",
  "description": "This extension protects your browser against phishing attacks based on MitM attacks",
  "version": "1.0",

  "background": {
    "scripts": ["notify.js"],
    "persistent": false
  },

  "browser_action": {
    "default_icon": "bluetooth_device.png",
    "default_popup": "choose_device.html"
  },

  "permissions": [
      "tabs", 
      "http://*/*", 
      "background", 
      {"socket": 
       [ "tcp-connect:127.0.0.1:8081" ] 
      },
      "notifications"
  ]
}
4

1 回答 1

0

如果您使用的是 Chrome 的金丝雀/实验性版本,您应该能够做到

chrome.experimental.socket.create('tcp', ...)

打开一个 TCP 套接字。但只是打电话是socket.create行不通的。

请记住,这可能只会在 chrome 上工作...... WebSockets 是一个更便携的解决方案。

要正确设置套接字,我认为这应该可以工作(尚未测试):

var socket = chrome.socket;
if (unfefined !== chrome.experimental.socket)
  socket = chrome.experimental.socket;
if (undefined === chrome.socket)
  throw "Socket unavailable"
于 2013-04-10T13:09:40.290 回答