background.js 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. // background.js
  2. chrome.runtime.onInstalled.addListener(function () {
  3. console.log("插件已被安装");
  4. });
  5. let pageState = 0; // 0 - 未创建,1 - 已创建
  6. let pageInfo = null;
  7. let pageId = "";
  8. chrome.runtime.onMessage.addListener(async (request, sender, sendResponse) => {
  9. if (request.action === "show_popup") {
  10. pageInfo = request;
  11. try {
  12. await chrome.tabs.get(pageId)
  13. } catch {
  14. pageState = 0; // 说明没找到
  15. }
  16. if (pageState === 0) {
  17. chrome.windows.create({
  18. url: chrome.runtime.getURL("page.html"), // 指向你的弹出页面
  19. type: "popup", // 设置为弹出窗口
  20. }, (newTab) => {
  21. pageId = newTab.tabs[0].id;
  22. pageState = 1;
  23. });
  24. }
  25. else {
  26. sendTabMessage(pageId, { data: pageInfo })
  27. }
  28. }
  29. });
  30. // 监听已更新的标签,以找出何时打开了 page.html
  31. chrome.tabs.onUpdated.addListener((tabId, changeInfo, tab) => {
  32. if (changeInfo.status === 'complete' && tab.url.includes('page.html')) {
  33. sendTabMessage(tabId, { msgToPopup: "发送页面", data: pageInfo })
  34. }
  35. });
  36. function sendTabMessage(tabId, data) {
  37. chrome.tabs.sendMessage(tabId, data);
  38. }
  39. // // background.js
  40. // chrome.runtime.onInstalled.addListener(function () {
  41. // console.log("插件已被安装");
  42. // });
  43. // let jsRequests = [];
  44. // let jsRequestsByTab = {}; // 用于存储每个标签页的请求
  45. // chrome.webRequest.onBeforeRequest.addListener(
  46. // (details) => {
  47. // const tabId = details.tabId; // 获取当前请求的标签页 ID
  48. // const url = details.url;
  49. // let uri = new URL(url);
  50. // if (
  51. // details.initiator &&
  52. // uri.pathname.endsWith(".js") &&
  53. // (uri.protocol.startsWith("http") || uri.protocol.startsWith("https"))
  54. // ) {
  55. // // 确保有个数组来记录当前标签页的请求
  56. // if (!jsRequestsByTab[tabId]) {
  57. // jsRequestsByTab[tabId] = [];
  58. // }
  59. // jsRequestsByTab[tabId].push(url);
  60. // }
  61. // },
  62. // { urls: ["<all_urls>"] }
  63. // );
  64. // chrome.runtime.onMessage.addListener((request, sender, sendResponse) => {
  65. // if (request.action === "getJsRequests") {
  66. // const tabId = sender.tab.id; // 获取请求来源的标签页 ID
  67. // sendResponse(jsRequestsByTab[tabId] || []);
  68. // }
  69. // });
  70. // // 监听标签页更新(包括刷新)事件以清空请求记录
  71. // chrome.tabs.onUpdated.addListener((tabId, changeInfo, tab) => {
  72. // if (changeInfo.status === "loading") {
  73. // // 标签页加载完成时清空请求记录
  74. // delete jsRequestsByTab[tabId];
  75. // }
  76. // });
  77. // // 监听标签页关闭事件以清空请求记录
  78. // chrome.tabs.onRemoved.addListener((tabId) => {
  79. // delete jsRequestsByTab[tabId]; // 清空对应标签页的请求记录
  80. // });