বর্ণনা
 ট্র্যাফিক পর্যবেক্ষণ এবং বিশ্লেষণ করতে এবং ফ্লাইটে অনুরোধগুলিকে বাধা দিতে, ব্লক করতে বা সংশোধন করতে chrome.webRequest API ব্যবহার করুন৷
অনুমতি
webRequest প্রয়োজনীয় হোস্ট অনুমতি সহ ওয়েব অনুরোধ API ব্যবহার করার জন্য আপনাকে এক্সটেনশন ম্যানিফেস্টে "webRequest" অনুমতি ঘোষণা করতে হবে। একটি সাব-রিসোর্স রিকোয়েস্টকে আটকাতে, এক্সটেনশনের অনুরোধ করা ইউআরএল এবং এর ইনিশিয়েটর উভয়েরই অ্যাক্সেস থাকতে হবে। যেমন:
{
  "name": "My extension",
  ...
  "permissions": [
    "webRequest"
  ],
  "host_permissions": [
    "*://*.google.com/*"
  ],
  ...
}
 webRequestBlocking
ব্লকিং ইভেন্ট হ্যান্ডলারদের নিবন্ধন করতে হবে। ম্যানিফেস্ট V3 অনুসারে, এটি শুধুমাত্র পলিসি ইনস্টল করা এক্সটেনশনগুলিতে উপলব্ধ।
 webRequestAuthProvider
 onAuthRequired পদ্ধতি ব্যবহার করতে হবে। হ্যান্ডলিং প্রমাণীকরণ দেখুন।
ধারণা এবং ব্যবহার
অনুরোধের জীবনচক্র
ওয়েব রিকোয়েস্ট API ইভেন্টের একটি সেটকে সংজ্ঞায়িত করে যা একটি ওয়েব অনুরোধের জীবনচক্র অনুসরণ করে। আপনি ট্রাফিক পর্যবেক্ষণ এবং বিশ্লেষণ করতে এই ঘটনা ব্যবহার করতে পারেন. কিছু সিঙ্ক্রোনাস ইভেন্ট আপনাকে একটি অনুরোধ আটকাতে, ব্লক করতে বা সংশোধন করতে দেয়।
সফল অনুরোধের জন্য ইভেন্ট জীবন চক্র এখানে চিত্রিত করা হয়েছে, ইভেন্ট সংজ্ঞা দ্বারা অনুসরণ করা হয়েছে:

-  onBeforeRequest(ঐচ্ছিকভাবে সিঙ্ক্রোনাস)
- যখন একটি অনুরোধ ঘটতে চলেছে তখন আগুন লাগে৷ এই ইভেন্টটি টিসিপি সংযোগ তৈরি হওয়ার আগে পাঠানো হয় এবং অনুরোধগুলি বাতিল বা পুনঃনির্দেশ করতে ব্যবহার করা যেতে পারে।
-  onBeforeSendHeaders(ঐচ্ছিকভাবে সিঙ্ক্রোনাস)
-  যখন একটি অনুরোধ ঘটতে চলেছে এবং প্রাথমিক শিরোনামগুলি প্রস্তুত করা হয়েছে তখন আগুন লাগে৷ ইভেন্টটি এক্সটেনশনগুলিকে অনুরোধ শিরোনাম (*) যোগ, সংশোধন এবং মুছে ফেলার অনুমতি দেওয়ার উদ্দেশ্যে। onBeforeSendHeadersইভেন্টটি সমস্ত গ্রাহকদের কাছে পাস করা হয়েছে, তাই বিভিন্ন গ্রাহক অনুরোধটি সংশোধন করার চেষ্টা করতে পারে; এটি কীভাবে পরিচালনা করা হয় তার জন্য বাস্তবায়ন বিবরণ বিভাগটি দেখুন। এই ইভেন্ট অনুরোধ বাতিল করতে ব্যবহার করা যেতে পারে.
-  onSendHeaders
- সমস্ত এক্সটেনশনের অনুরোধের শিরোনাম সংশোধন করার সুযোগ পাওয়ার পরে ফায়ার, এবং চূড়ান্ত (*) সংস্করণ উপস্থাপন করে। নেটওয়ার্কে হেডার পাঠানোর আগে ইভেন্টটি ট্রিগার হয়। এই ইভেন্টটি তথ্যপূর্ণ এবং অ্যাসিঙ্ক্রোনাসভাবে পরিচালনা করা হয়। এটি সংশোধন বা অনুরোধ বাতিল করার অনুমতি দেয় না।
-  onHeadersReceived(ঐচ্ছিকভাবে সিঙ্ক্রোনাস)
- প্রতিবার যখন একটি HTTP(S) প্রতিক্রিয়া শিরোনাম প্রাপ্ত হয় তখন ফায়ার করে। পুনঃনির্দেশ এবং প্রমাণীকরণ অনুরোধের কারণে এটি প্রতি অনুরোধে একাধিকবার ঘটতে পারে। এই ইভেন্টটি এক্সটেনশনগুলিকে প্রতিক্রিয়া শিরোনাম, যেমন ইনকামিং কন্টেন্ট-টাইপ শিরোনামগুলি যোগ, সংশোধন এবং মুছে ফেলার অনুমতি দেওয়ার উদ্দেশ্যে করা হয়েছে৷ এই ইভেন্টটি ট্রিগার হওয়ার আগে ক্যাশিং নির্দেশিকাগুলি প্রক্রিয়া করা হয়, তাই ক্যাশে-কন্ট্রোলের মতো শিরোনামগুলি পরিবর্তন করার ব্রাউজারের ক্যাশে কোনও প্রভাব নেই৷ এটি আপনাকে অনুরোধটি বাতিল বা পুনঃনির্দেশ করার অনুমতি দেয়।
-  onAuthRequired(ঐচ্ছিকভাবে সিঙ্ক্রোনাস)
- একটি অনুরোধ ব্যবহারকারীর প্রমাণীকরণের প্রয়োজন হলে ফায়ার হয়। প্রমাণীকরণ শংসাপত্র প্রদান করতে এই ইভেন্টটি সিঙ্ক্রোনাসভাবে পরিচালনা করা যেতে পারে। মনে রাখবেন যে এক্সটেনশনগুলি অবৈধ প্রমাণপত্রাদি প্রদান করতে পারে৷ বারবার অবৈধ শংসাপত্র প্রদান করে একটি অসীম লুপে প্রবেশ না করার যত্ন নিন। এটি অনুরোধ বাতিল করতেও ব্যবহার করা যেতে পারে।
-  onBeforeRedirect
- যখন একটি পুনঃনির্দেশ কার্যকর হতে চলেছে তখন আগুন লাগে৷ একটি পুনঃনির্দেশ একটি HTTP প্রতিক্রিয়া কোড দ্বারা বা একটি এক্সটেনশন দ্বারা ট্রিগার করা যেতে পারে৷ এই ইভেন্টটি তথ্যপূর্ণ এবং অ্যাসিঙ্ক্রোনাসভাবে পরিচালনা করা হয়। এটি আপনাকে অনুরোধটি সংশোধন বা বাতিল করার অনুমতি দেয় না।
-  onResponseStarted
- রেসপন্স বডির প্রথম বাইট প্রাপ্ত হলে আগুন লাগে। HTTP অনুরোধের জন্য, এর মানে হল স্ট্যাটাস লাইন এবং প্রতিক্রিয়া শিরোনাম উপলব্ধ। এই ইভেন্টটি তথ্যপূর্ণ এবং অ্যাসিঙ্ক্রোনাসভাবে পরিচালনা করা হয়। এটি সংশোধন বা অনুরোধ বাতিল করার অনুমতি দেয় না।
-  onCompleted
- একটি অনুরোধ সফলভাবে প্রক্রিয়া করা হলে আগুন লাগে।
-  onErrorOccurred
- একটি অনুরোধ সফলভাবে প্রক্রিয়া করা না হলে আগুন লাগে।
 ওয়েব রিকোয়েস্ট API গ্যারান্টি দেয় যে প্রতিটি অনুরোধের জন্য, হয় onCompleted বা onErrorOccurred একটি ব্যতিক্রম সহ চূড়ান্ত ইভেন্ট হিসাবে বরখাস্ত করা হয়েছে: যদি একটি অনুরোধ একটি data:// URL-এ পুনঃনির্দেশিত হয়, onBeforeRedirect হল সর্বশেষ রিপোর্ট করা ইভেন্ট।
* মনে রাখবেন যে ওয়েব অনুরোধ API এক্সটেনশনে নেটওয়ার্ক স্ট্যাকের একটি বিমূর্ততা উপস্থাপন করে। অভ্যন্তরীণভাবে, একটি URL অনুরোধকে কয়েকটি HTTP অনুরোধে বিভক্ত করা যেতে পারে (উদাহরণস্বরূপ, একটি বড় ফাইল থেকে পৃথক বাইট রেঞ্জ আনার জন্য) বা নেটওয়ার্কের সাথে যোগাযোগ না করেই নেটওয়ার্ক স্ট্যাক দ্বারা পরিচালনা করা যেতে পারে। এই কারণে, API নেটওয়ার্কে পাঠানো চূড়ান্ত HTTP হেডার প্রদান করে না। উদাহরণস্বরূপ, ক্যাশে সম্পর্কিত সমস্ত শিরোনামগুলি এক্সটেনশনে অদৃশ্য।
 নিম্নলিখিত শিরোনামগুলি বর্তমানে onBeforeSendHeaders ইভেন্টে প্রদান করা হয় না । এই তালিকাটি সম্পূর্ণ বা স্থিতিশীল হওয়ার নিশ্চয়তা নেই।
- অনুমোদন
- ক্যাশে-নিয়ন্ত্রণ
- সংযোগ
- বিষয়বস্তু-দৈর্ঘ্য
- হোস্ট
- যদি-পরিবর্তিত-যখন থেকে
- If-None-Match
- যদি-পরিসীমা
- আংশিক-ডেটা
- প্রাগমা
- প্রক্সি-অনুমোদন
- প্রক্সি-সংযোগ
- স্থানান্তর-এনকোডিং
 Chrome 79 থেকে শুরু করে, হেডার পরিবর্তনের অনুরোধ ক্রস-অরিজিন রিসোর্স শেয়ারিং (CORS) চেককে প্রভাবিত করে। যদি ক্রস-অরিজিন অনুরোধের জন্য পরিবর্তিত শিরোনামগুলি মানদণ্ড পূরণ না করে, তাহলে এই ধরনের শিরোনামগুলি গ্রহণ করা যেতে পারে কিনা তা সার্ভারকে জিজ্ঞাসা করতে একটি CORS প্রিফ্লাইট পাঠানো হবে৷ আপনি যদি সত্যিই CORS প্রোটোকল লঙ্ঘন করার জন্য শিরোনামগুলি পরিবর্তন করতে চান, তাহলে আপনাকে opt_extraInfoSpec এ 'extraHeaders' নির্দিষ্ট করতে হবে। অন্যদিকে, প্রতিক্রিয়া শিরোনাম পরিবর্তনগুলি CORS চেকগুলিকে প্রতারিত করতে কাজ করে না৷ আপনি যদি CORS প্রোটোকলের সাথে প্রতারণা করতে চান তবে প্রতিক্রিয়া পরিবর্তনের জন্য আপনাকে 'extraHeaders' নির্দিষ্ট করতে হবে।
 Chrome 79 থেকে শুরু করে, webRequest API ডিফল্টরূপে CORS প্রিফ্লাইট অনুরোধ এবং প্রতিক্রিয়াগুলিকে বাধা দেয় না । অনুরোধ URL-এর জন্য একটি CORS প্রিফ্লাইট একটি এক্সটেনশনের কাছে দৃশ্যমান হয় যদি অনুরোধ URL-এর জন্য opt_extraInfoSpec এ নির্দিষ্ট 'extraHeaders' সহ শ্রোতা থাকে। onBeforeRequest Chrome 79 থেকে 'extraHeaders' ও নিতে পারে।
 Chrome 79 থেকে শুরু করে, নিম্নলিখিত অনুরোধ শিরোনাম প্রদান করা হয় না এবং opt_extraInfoSpec এ 'extraHeaders' উল্লেখ না করে সংশোধন বা সরানো যাবে না:
- উৎপত্তি
 ক্রোম 72 থেকে শুরু করে, ক্রস অরিজিন রিড ব্লকিং (CORB) প্রতিক্রিয়া ব্লক করার আগে যদি আপনাকে প্রতিক্রিয়াগুলি পরিবর্তন করতে হয়, তাহলে আপনাকে opt_extraInfoSpec এ 'extraHeaders' নির্দিষ্ট করতে হবে।
 Chrome 72 থেকে শুরু করে, নিম্নলিখিত অনুরোধ শিরোনামগুলি প্রদান করা হয় না এবং opt_extraInfoSpec এ 'extraHeaders' উল্লেখ না করে সংশোধন বা সরানো যাবে না:
- স্বীকার-ভাষা
- স্বীকার-এনকোডিং
- রেফারার
- কুকি
 Chrome 72 থেকে শুরু করে, Set-Cookie প্রতিক্রিয়া শিরোনাম প্রদান করা হয় না এবং opt_extraInfoSpec এ 'extraHeaders' উল্লেখ না করে সংশোধন বা সরানো যাবে না।
 Chrome 89 থেকে শুরু করে, X-Frame-Options প্রতিক্রিয়া শিরোনামটি opt_extraInfoSpec এ 'extraHeaders' উল্লেখ না করে কার্যকরভাবে পরিবর্তন বা সরানো যাবে না।
 webRequest API শুধুমাত্র সেই অনুরোধগুলিকে প্রকাশ করে যা এক্সটেনশনের হোস্টের অনুমতিগুলি দেখার অনুমতি রয়েছে৷ তাছাড়া, শুধুমাত্র নিম্নলিখিত স্কিমগুলি অ্যাক্সেসযোগ্য: http:// , https:// , ftp:// , file:// , ws:// (Chrome 58 থেকে), wss:// (Chrome 58 থেকে), urn: (Chrome 91 থেকে), অথবা chrome-extension:// । উপরন্তু, উপরের স্কিমগুলির মধ্যে একটি ব্যবহার করে URL সহ নির্দিষ্ট অনুরোধগুলি লুকানো আছে৷ এর মধ্যে রয়েছে chrome-extension://other_extension_id যেখানে other_extension_id অনুরোধটি পরিচালনা করার জন্য এক্সটেনশনের আইডি নয়, https://www.google.com/chrome , এবং অন্যান্য সংবেদনশীল অনুরোধগুলি ব্রাউজার কার্যকারিতার মূল৷ এছাড়াও আপনার এক্সটেনশন থেকে সিঙ্ক্রোনাস XMLHttpঅনুরোধগুলি অচলাবস্থা প্রতিরোধ করার জন্য ইভেন্ট হ্যান্ডলারদের ব্লক করা থেকে লুকানো হয়৷ নোট করুন যে কিছু সমর্থিত স্কিমগুলির জন্য উপলব্ধ ইভেন্টের সেট সংশ্লিষ্ট প্রোটোকলের প্রকৃতির কারণে সীমিত হতে পারে। উদাহরণস্বরূপ, ফাইলের জন্য: স্কিম, শুধুমাত্র onBeforeRequest , onResponseStarted , onCompleted , এবং onErrorOccurred পাঠানো হতে পারে।
Chrome 58 থেকে শুরু করে, webRequest API WebSocket হ্যান্ডশেক অনুরোধকে বাধা দিতে সমর্থন করে। যেহেতু হ্যান্ডশেক একটি HTTP আপগ্রেড অনুরোধের মাধ্যমে করা হয়, তাই এর প্রবাহ HTTP-ভিত্তিক ওয়েবরিকোয়েস্ট মডেলে ফিট করে। মনে রাখবেন যে API বাধা দেয় না :
- একটি প্রতিষ্ঠিত WebSocket সংযোগের মাধ্যমে পাঠানো পৃথক বার্তা।
- WebSocket বন্ধ সংযোগ.
WebSocket অনুরোধের জন্য পুনঃনির্দেশ সমর্থিত নয় ।
ক্রোম 72 থেকে শুরু করে, একটি এক্সটেনশন শুধুমাত্র অনুরোধ করা ইউআরএল এবং রিকোয়েস্ট ইনিশিয়েটর উভয়ের হোস্টের অনুমতি থাকলেই একটি অনুরোধ আটকাতে সক্ষম হবে।
Chrome 96 থেকে শুরু করে, webRequest API HTTP/3 হ্যান্ডশেক অনুরোধের মাধ্যমে WebTransport-কে বাধা দিতে সমর্থন করে। যেহেতু হ্যান্ডশেক একটি HTTP CONNECT অনুরোধের মাধ্যমে করা হয়, তাই এর প্রবাহ HTTP-ভিত্তিক webRequest মডেলে ফিট করে। উল্লেখ্য যে:
- একবার সেশন প্রতিষ্ঠিত হয়ে গেলে, এক্সটেনশনগুলি ওয়েবরিকোয়েস্ট API-এর মাধ্যমে সেশনে পর্যবেক্ষণ বা হস্তক্ষেপ করতে পারে না।
-  onBeforeSendHeadersএ HTTP অনুরোধ শিরোনাম পরিবর্তন করা উপেক্ষা করা হয়।
- রিডাইরেক্ট এবং প্রমাণীকরণ HTTP/3 এর উপর WebTransport-এ সমর্থিত নয় ।
আইডি অনুরোধ করুন
প্রতিটি অনুরোধ একটি অনুরোধ আইডি দ্বারা চিহ্নিত করা হয়. এই আইডিটি একটি ব্রাউজার সেশন এবং একটি এক্সটেনশনের প্রসঙ্গে অনন্য। এটি একটি অনুরোধের জীবনচক্রের সময় স্থির থাকে এবং একই অনুরোধের জন্য ইভেন্টগুলিকে মেলাতে ব্যবহার করা যেতে পারে। মনে রাখবেন যে HTTP পুনর্নির্দেশ বা HTTP প্রমাণীকরণের ক্ষেত্রে একাধিক HTTP অনুরোধ একটি ওয়েব অনুরোধে ম্যাপ করা হয়।
ইভেন্ট শ্রোতা নিবন্ধন
 একটি ওয়েব অনুরোধের জন্য একটি ইভেন্ট শ্রোতা নিবন্ধন করতে, আপনি স্বাভাবিক addListener() ফাংশনে একটি বৈচিত্র ব্যবহার করেন। একটি কলব্যাক ফাংশন নির্দিষ্ট করার পাশাপাশি, আপনাকে একটি ফিল্টার আর্গুমেন্ট নির্দিষ্ট করতে হবে এবং আপনি একটি ঐচ্ছিক অতিরিক্ত তথ্য আর্গুমেন্ট উল্লেখ করতে পারেন।
 ওয়েব রিকোয়েস্ট API এর addListener() এর তিনটি আর্গুমেন্টের নিম্নলিখিত সংজ্ঞা রয়েছে:
var callback = function(details) {...};
var filter = {...};
var opt_extraInfoSpec = [...];
 onBeforeRequest ইভেন্টটি শোনার একটি উদাহরণ এখানে দেওয়া হল:
chrome.webRequest.onBeforeRequest.addListener(
    callback, filter, opt_extraInfoSpec);
 প্রতিটি addListener() কল প্রথম প্যারামিটার হিসাবে একটি বাধ্যতামূলক কলব্যাক ফাংশন নেয়। এই কলব্যাক ফাংশনটি বর্তমান URL অনুরোধ সম্পর্কে তথ্য ধারণকারী একটি অভিধান পাস করা হয়েছে। এই অভিধানের তথ্য নির্দিষ্ট ইভেন্টের প্রকারের পাশাপাশি opt_extraInfoSpec এর বিষয়বস্তুর উপর নির্ভর করে।
 যদি ঐচ্ছিক opt_extraInfoSpec অ্যারেতে 'blocking' স্ট্রিং থাকে (শুধুমাত্র নির্দিষ্ট ইভেন্টের জন্য অনুমোদিত), কলব্যাক ফাংশনটি সিঙ্ক্রোনাসভাবে পরিচালনা করা হয়। এর মানে হল যে কলব্যাক ফাংশন ফিরে না আসা পর্যন্ত অনুরোধটি ব্লক করা হয়েছে। এই ক্ষেত্রে, কলব্যাক একটি webRequest.BlockingResponse ফেরত দিতে পারে যা অনুরোধের পরবর্তী জীবনচক্র নির্ধারণ করে। প্রেক্ষাপটের উপর নির্ভর করে, এই প্রতিক্রিয়াটি একটি অনুরোধ বাতিল বা পুনঃনির্দেশিত করার অনুমতি দেয় ( onBeforeRequest ), একটি অনুরোধ বাতিল করা বা শিরোনামগুলি সংশোধন করা ( onBeforeSendHeaders , onHeadersReceived ), এবং একটি অনুরোধ বাতিল করা বা প্রমাণীকরণ শংসাপত্র প্রদান করা ( onAuthRequired )৷
 যদি ঐচ্ছিক opt_extraInfoSpec অ্যারে এর পরিবর্তে 'asyncBlocking' স্ট্রিং থাকে (শুধুমাত্র onAuthRequired এর জন্য অনুমোদিত), এক্সটেনশনটি অ্যাসিঙ্ক্রোনাসভাবে webRequest.BlockingResponse তৈরি করতে পারে।
 webRequest.RequestFilter filter বিভিন্ন মাত্রায় ইভেন্টগুলি ট্রিগার করা অনুরোধগুলিকে সীমিত করার অনুমতি দেয়:
- ইউআরএল
-  URL প্যাটার্ন যেমন *://www.google.com/foo*bar।
- প্রকারভেদ
-  অনুরোধের ধরন যেমন main_frame(একটি নথি যা একটি শীর্ষ-স্তরের ফ্রেমের জন্য লোড করা হয়),sub_frame(একটি নথি যা একটি এমবেডেড ফ্রেমের জন্য লোড করা হয়), এবংimage(ওয়েব সাইটের একটি চিত্র)।webRequest.RequestFilterদেখুন।
- ট্যাব আইডি
- একটি ট্যাবের শনাক্তকারী।
- উইন্ডো আইডি
- একটি উইন্ডোর শনাক্তকারী।
 ইভেন্টের প্রকারের উপর নির্ভর করে, অনুরোধ সম্পর্কে অতিরিক্ত তথ্যের জন্য আপনি opt_extraInfoSpec এ স্ট্রিংগুলি নির্দিষ্ট করতে পারেন। এটি শুধুমাত্র স্পষ্টভাবে অনুরোধ করা হলে অনুরোধের ডেটার বিস্তারিত তথ্য প্রদান করতে ব্যবহৃত হয়।
হ্যান্ডলিং প্রমাণীকরণ
 HTTP প্রমাণীকরণের জন্য অনুরোধগুলি পরিচালনা করতে, আপনার ম্যানিফেস্ট ফাইলে "webRequestAuthProvider" অনুমতি যোগ করুন:
{
  "permissions": [
    "webRequest",
    "webRequestAuthProvider"
  ]
}
 মনে রাখবেন যে "webRequestBlocking" অনুমতি সহ একটি নীতি ইনস্টল করা এক্সটেনশনের জন্য এই অনুমতির প্রয়োজন নেই৷
সিঙ্ক্রোনাসভাবে শংসাপত্র প্রদান করতে:
chrome.webRequest.onAuthRequired.addListener((details) => {
    return {
      authCredentials: {
        username: 'guest',
        password: 'guest'
      }
    };
  },
  { urls: ['https://httpbin.org/basic-auth/guest/guest'] },
  ['blocking']
);
অ্যাসিঙ্ক্রোনাসভাবে শংসাপত্র প্রদান করতে:
chrome.webRequest.onAuthRequired.addListener((details, callback) => {
    callback({
      authCredentials: {
        username: 'guest',
        password: 'guest'
      }
    });
  },
  { urls: ['https://httpbin.org/basic-auth/guest/guest'] },
  ['asyncBlocking']
);
বাস্তবায়নের বিবরণ
ওয়েব রিকোয়েস্ট API ব্যবহার করে এমন একটি এক্সটেনশন ডেভেলপ করার সময় বেশ কিছু বাস্তবায়নের বিশদ বুঝতে গুরুত্বপূর্ণ হতে পারে:
ওয়েব_অ্যাক্সেসযোগ্য_সম্পদ
 যখন একটি এক্সটেনশন ওয়েবে অ্যাক্সেসযোগ্য নয় এমন একটি রিসোর্সে পাবলিক রিসোর্স রিডাইরেক্ট করার জন্য webRequest API ব্যবহার করে, তখন এটি ব্লক করা হয় এবং এর ফলে একটি ত্রুটি দেখা দেয়। ওয়েব অ্যাক্সেসযোগ্য নয় এমন সংস্থান পুনঃনির্দেশিত এক্সটেনশনের মালিকানাধীন হলেও উপরেরটি সত্য। declarativeWebRequest API-এর সাথে ব্যবহারের জন্য সংস্থানগুলি ঘোষণা করতে, "web_accessible_resources" অ্যারেকে অবশ্যই এখানে নথিভুক্ত করা ম্যানিফেস্টে ঘোষণা করতে হবে এবং পপুলেট করতে হবে।
দ্বন্দ্ব সমাধান
 ওয়েব রিকোয়েস্ট API-এর বর্তমান বাস্তবায়নে, একটি অনুরোধ বাতিল বলে গণ্য করা হয় যদি অন্তত একটি এক্সটেনশন অনুরোধটি বাতিল করার নির্দেশ দেয়। যদি একটি এক্সটেনশন একটি অনুরোধ বাতিল করে, তবে সমস্ত এক্সটেনশানগুলি একটি onErrorOccurred ইভেন্ট দ্বারা সূচিত হয়৷ শুধুমাত্র একটি এক্সটেনশন একটি অনুরোধ পুনঃনির্দেশ করতে পারে বা একবারে একটি শিরোনাম পরিবর্তন করতে পারে৷ যদি একাধিক এক্সটেনশন অনুরোধটি সংশোধন করার চেষ্টা করে, তবে অতি সম্প্রতি ইনস্টল করা এক্সটেনশন জয়ী হয় এবং অন্য সকলকে উপেক্ষা করা হয়। একটি এক্সটেনশনের সংশোধন বা পুনঃনির্দেশিত করার নির্দেশ উপেক্ষা করা হলে তাকে অবহিত করা হয় না।
ক্যাশিং
 Chrome দুটি ক্যাশে নিয়োগ করে—একটি অন-ডিস্ক ক্যাশে এবং একটি খুব দ্রুত ইন-মেমরি ক্যাশে। একটি ইন-মেমরি ক্যাশের জীবনকাল একটি রেন্ডার প্রক্রিয়ার জীবনকালের সাথে সংযুক্ত থাকে, যা মোটামুটিভাবে একটি ট্যাবের সাথে মিলে যায়। ইন-মেমরি ক্যাশে থেকে উত্তর দেওয়া অনুরোধগুলি ওয়েব অনুরোধ API-এর কাছে অদৃশ্য। যদি একটি অনুরোধ হ্যান্ডলার তার আচরণ পরিবর্তন করে (উদাহরণস্বরূপ, যে আচরণ অনুযায়ী অনুরোধগুলি ব্লক করা হয়), একটি সাধারণ পৃষ্ঠা রিফ্রেশ এই পরিবর্তিত আচরণকে সম্মান নাও করতে পারে। আচরণের পরিবর্তন নিশ্চিত করতে, ইন-মেমরি ক্যাশে ফ্লাশ করতে handlerBehaviorChanged() কল করুন। কিন্তু প্রায়ই এটা করবেন না; ক্যাশে ফ্লাশ করা একটি অত্যন্ত ব্যয়বহুল অপারেশন। একটি ইভেন্ট লিসেনার রেজিস্টার বা আনরেজিস্টার করার পরে আপনাকে handlerBehaviorChanged() কল করার দরকার নেই।
টাইমস্ট্যাম্প
 ওয়েব রিকোয়েস্ট ইভেন্টের timestamp সম্পত্তি শুধুমাত্র অভ্যন্তরীণভাবে সামঞ্জস্যপূর্ণ হওয়ার নিশ্চয়তা। একটি ইভেন্টকে অন্য ইভেন্টের সাথে তুলনা করলে আপনি তাদের মধ্যে সঠিক অফসেট পাবেন, কিন্তু এক্সটেনশনের ভিতরে বর্তমান সময়ের সাথে (new Date()).getTime() মাধ্যমে, উদাহরণস্বরূপ) তাদের তুলনা করা অপ্রত্যাশিত ফলাফল দিতে পারে।
ত্রুটি হ্যান্ডলিং
আপনি যদি অবৈধ আর্গুমেন্ট সহ একটি ইভেন্ট নিবন্ধন করার চেষ্টা করেন, তাহলে একটি জাভাস্ক্রিপ্ট ত্রুটি নিক্ষেপ করা হবে, এবং ইভেন্ট হ্যান্ডলার নিবন্ধিত হবে না। যদি একটি ইভেন্ট পরিচালনা করার সময় একটি ত্রুটি নিক্ষেপ করা হয় বা যদি একটি ইভেন্ট হ্যান্ডলার একটি অবৈধ ব্লকিং প্রতিক্রিয়া প্রদান করে, একটি ত্রুটি বার্তা আপনার এক্সটেনশনের কনসোলে লগ করা হয় এবং সেই অনুরোধের জন্য হ্যান্ডলারকে উপেক্ষা করা হয়৷
উদাহরণ
 নিম্নলিখিত উদাহরণটি ব্যাখ্যা করে কিভাবে www.evil.com এ সমস্ত অনুরোধ ব্লক করতে হয়:
chrome.webRequest.onBeforeRequest.addListener(
  function(details) {
    return {cancel: details.url.indexOf("://www.evil.com/") != -1};
  },
  {urls: ["<all_urls>"]},
  ["blocking"]
);
 যেহেতু এই ফাংশনটি একটি ব্লকিং ইভেন্ট হ্যান্ডলার ব্যবহার করে, এর জন্য ম্যানিফেস্ট ফাইলে "webRequest" এর পাশাপাশি "webRequestBlocking" অনুমতি প্রয়োজন৷
 নিম্নলিখিত উদাহরণটি আরও কার্যকর উপায়ে একই লক্ষ্য অর্জন করে কারণ যে অনুরোধগুলি www.evil.com এ টার্গেট করা হয় না তাদের এক্সটেনশনে পাস করার প্রয়োজন নেই:
chrome.webRequest.onBeforeRequest.addListener(
  function(details) { return {cancel: true}; },
  {urls: ["*://www.evil.com/*"]},
  ["blocking"]
);
নিম্নলিখিত উদাহরণটি ব্যাখ্যা করে কিভাবে সমস্ত অনুরোধ থেকে ব্যবহারকারী-এজেন্ট শিরোনাম মুছে ফেলতে হয়:
chrome.webRequest.onBeforeSendHeaders.addListener(
  function(details) {
    for (var i = 0; i < details.requestHeaders.length; ++i) {
      if (details.requestHeaders[i].name === 'User-Agent') {
        details.requestHeaders.splice(i, 1);
        break;
      }
    }
    return {requestHeaders: details.requestHeaders};
  },
  {urls: ["<all_urls>"]},
  ["blocking", "requestHeaders"]
);
 chrome.webRequest API ব্যবহার করতে, chrome-extension-samples repository থেকে webRequest নমুনা ইনস্টল করুন।
প্রকারভেদ
BlockingResponse
'ব্লকিং' extraInfoSpec প্রয়োগ করা ইভেন্ট হ্যান্ডলারদের জন্য মান প্রদান করে। ইভেন্ট হ্যান্ডলারকে নেটওয়ার্ক অনুরোধগুলি সংশোধন করার অনুমতি দেয়৷
বৈশিষ্ট্য
- প্রমাণপত্রাদিবস্তু ঐচ্ছিক শুধুমাত্র onAuthRequired ইভেন্টের প্রতিক্রিয়া হিসেবে ব্যবহার করা হয়েছে। সেট করা থাকলে, সরবরাহকৃত শংসাপত্র ব্যবহার করে অনুরোধ করা হয়। - পাসওয়ার্ডস্ট্রিং 
- ব্যবহারকারীর নামস্ট্রিং 
 
- বাতিলবুলিয়ান ঐচ্ছিক সত্য হলে, অনুরোধ বাতিল করা হয়। এটি অনুরোধ পাঠানো থেকে বাধা দেয়। এটি onBeforeRequest, onBeforeSendHeaders, onHeadersReceived এবং onAuthRequired ইভেন্টের প্রতিক্রিয়া হিসাবে ব্যবহার করা যেতে পারে। 
- redirectUrlস্ট্রিং ঐচ্ছিক শুধুমাত্র onBeforeRequest এবং onHeadersReceived ইভেন্টগুলির প্রতিক্রিয়া হিসাবে ব্যবহৃত হয়৷ সেট করা থাকলে, আসল অনুরোধ পাঠানো/সম্পূর্ণ হওয়া থেকে বাধা দেওয়া হয় এবং পরিবর্তে প্রদত্ত URL-এ পুনঃনির্দেশিত হয়। নন-HTTP স্কিমগুলিতে পুনঃনির্দেশ যেমন data:অনুমোদিত। একটি পুনঃনির্দেশ ক্রিয়া দ্বারা সূচিত পুনঃনির্দেশগুলি একটি ব্যতিক্রম সহ, পুনঃনির্দেশের জন্য মূল অনুরোধের পদ্ধতি ব্যবহার করে: যদি রিডাইরেক্টটি onHeadersReceived পর্যায়ে শুরু করা হয়, তাহলে GET পদ্ধতি ব্যবহার করে পুনঃনির্দেশ জারি করা হবে।ws://এবংwss://স্কিমগুলির সাথে URL থেকে পুনঃনির্দেশ উপেক্ষা করা হয়।
- অনুরোধ শিরোনামHttpHeaders ঐচ্ছিক শুধুমাত্র onBeforeSendHeaders ইভেন্টের প্রতিক্রিয়া হিসাবে ব্যবহৃত হয়। যদি সেট করা হয়, অনুরোধটি পরিবর্তে এই অনুরোধ শিরোনাম দিয়ে করা হয়। 
- প্রতিক্রিয়া শিরোনামHttpHeaders ঐচ্ছিক শুধুমাত্র onHeadersReceived ইভেন্টের প্রতিক্রিয়া হিসেবে ব্যবহার করা হয়েছে। সেট করা হলে, সার্ভার পরিবর্তে এই প্রতিক্রিয়া শিরোনামগুলির সাথে সাড়া দিয়েছে বলে ধরে নেওয়া হয়। আপনি যদি সত্যিই দ্বন্দ্বের সংখ্যা সীমিত করার জন্য শিরোনামগুলি পরিবর্তন করতে চান তবে শুধুমাত্র responseHeadersফেরত দিন (প্রতিটি অনুরোধের জন্য শুধুমাত্র একটি এক্সটেনশনresponseHeadersপরিবর্তন করতে পারে)৷
FormDataItem
ফর্ম ডেটার মধ্যে পাস করা ডেটা রয়েছে। urlencoded ফর্মের জন্য এটি স্ট্রিং হিসাবে সংরক্ষণ করা হয় যদি ডেটা utf-8 স্ট্রিং হয় এবং অন্যথায় ArrayBuffer হিসাবে। ফর্ম-ডেটার জন্য এটি ArrayBuffer। যদি ফর্ম-ডেটা আপলোড করা ফাইলের প্রতিনিধিত্ব করে, তাহলে এটি ফাইলের নামের সাথে স্ট্রিং, যদি ফাইলের নাম দেওয়া হয়।
এনাম
 ArrayBuffer   স্ট্রিং
HttpHeaders
HTTP শিরোনামগুলির একটি অ্যারে। প্রতিটি শিরোনাম একটি অভিধান হিসাবে উপস্থাপন করা হয় যাতে কীগুলির name এবং হয় value বা binaryValue থাকে। 
টাইপ
বস্তু[]
বৈশিষ্ট্য
- বাইনারি ভ্যালুসংখ্যা[] ঐচ্ছিক HTTP হেডারের মান যদি এটি UTF-8 দ্বারা প্রতিনিধিত্ব করা না যায়, তবে পৃথক বাইট মান (0..255) হিসাবে সংরক্ষণ করা হয়। 
- নামস্ট্রিং HTTP হেডারের নাম। 
- মানস্ট্রিং ঐচ্ছিক HTTP হেডারের মান যদি এটি UTF-8 দ্বারা উপস্থাপন করা যায়। 
IgnoredActionType
এনাম
 "পুনঃনির্দেশ"   "অনুরোধ_হেডার"   "প্রতিক্রিয়া_শিরোনাম"   "প্রমাণ_প্রমাণপত্র" 
OnAuthRequiredOptions
এনাম
 "প্রতিক্রিয়া শিরোনাম"  "অবরোধ"  "অসিঙ্কব্লকিং"  "অতিরিক্ত শিরোনাম"
 ইভেন্টে প্রতিক্রিয়া শিরোনাম অন্তর্ভুক্ত করা উচিত তা নির্দিষ্ট করে। 
 কলব্যাক ফাংশন ফিরে না আসা পর্যন্ত অনুরোধটি অবরুদ্ধ করা হয়েছে তা নির্দিষ্ট করে। 
 উল্লেখ করে যে কলব্যাক ফাংশন অ্যাসিঙ্ক্রোনাসভাবে পরিচালনা করা হয়। 
 নির্দিষ্ট করে যে শিরোনামগুলি ক্রস-অরিজিন রিসোর্স শেয়ারিং (CORS) লঙ্ঘন করতে পারে৷
OnBeforeRedirectOptions
এনাম
 "প্রতিক্রিয়া শিরোনাম"  "অতিরিক্ত শিরোনাম"
 ইভেন্টে প্রতিক্রিয়া শিরোনাম অন্তর্ভুক্ত করা উচিত তা নির্দিষ্ট করে। 
 নির্দিষ্ট করে যে শিরোনামগুলি ক্রস-অরিজিন রিসোর্স শেয়ারিং (CORS) লঙ্ঘন করতে পারে৷
OnBeforeRequestOptions
এনাম
 "অবরোধ"  "রিকোয়েস্টবডি"  "অতিরিক্ত শিরোনাম"
 কলব্যাক ফাংশন ফিরে না আসা পর্যন্ত অনুরোধটি অবরুদ্ধ করা হয়েছে তা নির্দিষ্ট করে। 
 নির্দিষ্ট করে যে অনুরোধের অংশটি ইভেন্টে অন্তর্ভুক্ত করা উচিত। 
 নির্দিষ্ট করে যে শিরোনামগুলি ক্রস-অরিজিন রিসোর্স শেয়ারিং (CORS) লঙ্ঘন করতে পারে৷
OnBeforeSendHeadersOptions
এনাম
 "অনুরোধ শিরোনাম"  "অবরোধ"  "অতিরিক্ত শিরোনাম"
 উল্লেখ করে যে অনুরোধ শিরোনামটি ইভেন্টে অন্তর্ভুক্ত করা উচিত। 
 কলব্যাক ফাংশন ফিরে না আসা পর্যন্ত অনুরোধটি অবরুদ্ধ করা হয়েছে তা নির্দিষ্ট করে। 
 নির্দিষ্ট করে যে শিরোনামগুলি ক্রস-অরিজিন রিসোর্স শেয়ারিং (CORS) লঙ্ঘন করতে পারে৷
OnCompletedOptions
এনাম
 "প্রতিক্রিয়া শিরোনাম"  "অতিরিক্ত শিরোনাম"
 ইভেন্টে প্রতিক্রিয়া শিরোনাম অন্তর্ভুক্ত করা উচিত তা নির্দিষ্ট করে। 
 নির্দিষ্ট করে যে শিরোনামগুলি ক্রস-অরিজিন রিসোর্স শেয়ারিং (CORS) লঙ্ঘন করতে পারে৷
OnErrorOccurredOptions
মান
 "অতিরিক্ত শিরোনাম" 
OnHeadersReceivedOptions
এনাম
 "অবরোধ"  "প্রতিক্রিয়া শিরোনাম"  "অতিরিক্ত শিরোনাম"
 কলব্যাক ফাংশন ফিরে না আসা পর্যন্ত অনুরোধটি অবরুদ্ধ করা হয়েছে তা নির্দিষ্ট করে। 
 ইভেন্টে প্রতিক্রিয়া শিরোনাম অন্তর্ভুক্ত করা উচিত তা নির্দিষ্ট করে। 
 নির্দিষ্ট করে যে শিরোনামগুলি ক্রস-অরিজিন রিসোর্স শেয়ারিং (CORS) লঙ্ঘন করতে পারে৷
OnResponseStartedOptions
এনাম
 "প্রতিক্রিয়া শিরোনাম"  "অতিরিক্ত শিরোনাম"
 ইভেন্টে প্রতিক্রিয়া শিরোনাম অন্তর্ভুক্ত করা উচিত তা নির্দিষ্ট করে। 
 নির্দিষ্ট করে যে শিরোনামগুলি ক্রস-অরিজিন রিসোর্স শেয়ারিং (CORS) লঙ্ঘন করতে পারে৷
OnSendHeadersOptions
এনাম
 "অনুরোধ শিরোনাম"  "অতিরিক্ত শিরোনাম"
 উল্লেখ করে যে অনুরোধ শিরোনামটি ইভেন্টে অন্তর্ভুক্ত করা উচিত। 
 নির্দিষ্ট করে যে শিরোনামগুলি ক্রস-অরিজিন রিসোর্স শেয়ারিং (CORS) লঙ্ঘন করতে পারে৷
RequestFilter
ওয়েব রিকোয়েস্ট ইভেন্টে প্রয়োগ করার জন্য ফিল্টার বর্ণনাকারী একটি বস্তু।
বৈশিষ্ট্য
- ট্যাবআইডিসংখ্যা ঐচ্ছিক 
- প্রকাররিসোর্স টাইপ [] ঐচ্ছিক অনুরোধ ধরনের একটি তালিকা. কোনো প্রকারের সাথে মেলে না এমন অনুরোধ ফিল্টার আউট করা হবে। 
- ইউআরএলস্ট্রিং[] ইউআরএল বা ইউআরএল প্যাটার্নের একটি তালিকা। কোনো URL-এর সাথে মেলে না এমন অনুরোধগুলি ফিল্টার করা হবে৷ 
- উইন্ডো আইডিসংখ্যা ঐচ্ছিক 
ResourceType
এনাম
 "প্রধান_ফ্রেম"  "সাব_ফ্রেম"  "স্টাইলশীট"  "লিপি"  "ছবি"  "ফন্ট"  "বস্তু"  "xmlhttp অনুরোধ"  "পিং"  "csp_report"  "মিডিয়া"  "ওয়েবসকেট"  "ওয়েববান্ডেল"  "অন্য"
 প্রধান ফ্রেম হিসাবে সম্পদ নির্দিষ্ট করে। 
 একটি সাব ফ্রেম হিসাবে সম্পদ নির্দিষ্ট করে। 
 একটি স্টাইলশীট হিসাবে সম্পদ নির্দিষ্ট করে। 
 একটি স্ক্রিপ্ট হিসাবে সম্পদ নির্দিষ্ট করে। 
 একটি ছবি হিসাবে সম্পদ নির্দিষ্ট করে। 
 একটি ফন্ট হিসাবে সম্পদ নির্দিষ্ট করে। 
 একটি বস্তু হিসাবে সম্পদ নির্দিষ্ট করে। 
 একটি XMLHttpRequest হিসাবে সম্পদ নির্দিষ্ট করে। 
 একটি পিং হিসাবে সম্পদ নির্দিষ্ট করে। 
 একটি বিষয়বস্তু নিরাপত্তা নীতি (CSP) রিপোর্ট হিসাবে সম্পদ নির্দিষ্ট করে। 
 একটি মিডিয়া অবজেক্ট হিসাবে সম্পদ নির্দিষ্ট করে। 
 একটি WebSocket হিসাবে সংস্থান নির্দিষ্ট করে। 
 একটি WebBundle হিসাবে সংস্থান নির্দিষ্ট করে। 
 তালিকাভুক্ত প্রকারের মধ্যে অন্তর্ভুক্ত নয় এমন একটি প্রকার হিসাবে সংস্থানকে নির্দিষ্ট করে৷
UploadData
একটি URL অনুরোধে আপলোড করা ডেটা রয়েছে৷
বৈশিষ্ট্য
- বাইটযে কোন ঐচ্ছিক ডেটার একটি অনুলিপি সহ একটি ArrayBuffer। 
- ফাইলস্ট্রিং ঐচ্ছিক ফাইলের পথ এবং নাম সহ একটি স্ট্রিং। 
বৈশিষ্ট্য
MAX_HANDLER_BEHAVIOR_CHANGED_CALLS_PER_10_MINUTES
প্রতি 10 মিনিটের স্থায়ী ব্যবধানে handlerBehaviorChanged সর্বোচ্চ সংখ্যক বার কল করা যেতে পারে। handlerBehaviorChanged একটি ব্যয়বহুল ফাংশন কল যা প্রায়ই কল করা উচিত নয়। 
মান
 20 
পদ্ধতি
handlerBehaviorChanged()
chrome.webRequest.handlerBehaviorChanged(): Promise<void>
ক্যাশিংয়ের কারণে ভুল হ্যান্ডলিং রোধ করতে যখন webRequest হ্যান্ডলারদের আচরণ পরিবর্তিত হয় তখন কল করা প্রয়োজন। এই ফাংশন কল ব্যয়বহুল। এটা প্রায়ই কল করবেন না.
রিটার্নস
- প্রতিশ্রুতি <void> Chrome 116+
ঘটনা
onActionIgnored
chrome.webRequest.onActionIgnored.addListener(
callback: function,
)
একটি নেটওয়ার্ক অনুরোধে একটি এক্সটেনশনের প্রস্তাবিত পরিবর্তন উপেক্ষা করা হলে বহিস্কার করা হয়৷ অন্যান্য এক্সটেনশনের সাথে দ্বন্দ্বের ক্ষেত্রে এটি ঘটে।
পরামিতি
- কলব্যাকফাংশন callbackপ্যারামিটারটি এর মতো দেখাচ্ছে:(details: object) => void - বিস্তারিতবস্তু - প্রস্তাবিত পদক্ষেপ যা উপেক্ষা করা হয়েছে। 
- অনুরোধ আইডিস্ট্রিং অনুরোধের আইডি। একটি ব্রাউজার সেশনের মধ্যে অনুরোধ আইডি অনন্য। ফলস্বরূপ, তারা একই অনুরোধের বিভিন্ন ইভেন্টের সাথে সম্পর্কিত করতে ব্যবহার করা যেতে পারে। 
 
 
onAuthRequired
chrome.webRequest.onAuthRequired.addListener(
callback: function,
filter: RequestFilter,
extraInfoSpec?: OnAuthRequiredOptions[],
)
 একটি প্রমাণীকরণ ব্যর্থতা প্রাপ্ত হলে বহিস্কার করা হয়। শ্রোতার কাছে তিনটি বিকল্প রয়েছে: এটি প্রমাণীকরণ শংসাপত্র প্রদান করতে পারে, এটি অনুরোধটি বাতিল করতে পারে এবং ত্রুটি পৃষ্ঠাটি প্রদর্শন করতে পারে, অথবা এটি চ্যালেঞ্জের উপর কোন পদক্ষেপ নিতে পারে না। খারাপ ব্যবহারকারীর শংসাপত্র প্রদান করা হলে, একই অনুরোধের জন্য এটি একাধিকবার কল করা হতে পারে। দ্রষ্টব্য, extraInfoSpec প্যারামিটারে 'blocking' বা 'asyncBlocking' মোডগুলির মধ্যে শুধুমাত্র একটি নির্দিষ্ট করা আবশ্যক। 
পরামিতি
- কলব্যাকফাংশন callbackপ্যারামিটারটি এর মতো দেখাচ্ছে:(details: object, asyncCallback?: function) => BlockingResponse | undefined - বিস্তারিতবস্তু - চ্যালেঞ্জারবস্তু সার্ভার প্রমাণীকরণের অনুরোধ করছে। - হোস্টস্ট্রিং 
- বন্দরসংখ্যা 
 
- ডকুমেন্ট আইডিস্ট্রিং Chrome 106+অনুরোধ করা নথির UUID। 
- নথি জীবনচক্রChrome 106+নথিতে থাকা জীবনচক্র। 
- ফ্রেমআইডিসংখ্যা মান 0 নির্দেশ করে যে অনুরোধটি প্রধান ফ্রেমে ঘটে; একটি ইতিবাচক মান একটি সাবফ্রেমের ID নির্দেশ করে যেখানে অনুরোধটি ঘটে। যদি একটি (সাব-) ফ্রেমের নথি লোড করা হয় ( typeহলmain_frameবাsub_frame),frameIdএই ফ্রেমের আইডি নির্দেশ করে, বাইরের ফ্রেমের আইডি নয়। ফ্রেম আইডি একটি ট্যাবের মধ্যে অনন্য।
- ফ্রেম টাইপChrome 106+যে ধরনের ফ্রেমে অনুরোধ করা হয়েছে। 
- সূচনাকারীস্ট্রিং ঐচ্ছিক Chrome 63+মূল যেখান থেকে অনুরোধ করা হয়েছিল। এটি পুনঃনির্দেশের মাধ্যমে পরিবর্তন হয় না। যদি এটি একটি অস্বচ্ছ উৎপত্তি হয়, স্ট্রিং 'নাল' ব্যবহার করা হবে। 
- isProxyবুলিয়ান প্রক্সি-প্রমাণিকৃতের জন্য সত্য, WWW-প্রমাণিত করার জন্য মিথ্যা। 
- পদ্ধতিস্ট্রিং স্ট্যান্ডার্ড HTTP পদ্ধতি। 
- parentDocumentIdস্ট্রিং ঐচ্ছিক Chrome 106+এই ফ্রেমের মালিক নথির UUID। অভিভাবক না থাকলে এটি সেট করা হয় না। 
- parentFrameIdসংখ্যা ফ্রেমের আইডি যা অনুরোধ পাঠানো ফ্রেমটিকে মোড়ানো। কোন প্যারেন্ট ফ্রেম বিদ্যমান না থাকলে -1 এ সেট করুন। 
- রাজত্বস্ট্রিং ঐচ্ছিক সার্ভার দ্বারা প্রদত্ত প্রমাণীকরণ ক্ষেত্র, যদি একটি থাকে। 
- অনুরোধ আইডিস্ট্রিং অনুরোধের আইডি। একটি ব্রাউজার সেশনের মধ্যে অনুরোধ আইডি অনন্য। ফলস্বরূপ, তারা একই অনুরোধের বিভিন্ন ইভেন্টের সাথে সম্পর্কিত করতে ব্যবহার করা যেতে পারে। 
- প্রতিক্রিয়া শিরোনামHttpHeaders ঐচ্ছিক এই প্রতিক্রিয়া সহ প্রাপ্ত HTTP প্রতিক্রিয়া শিরোনাম. 
- স্কিমস্ট্রিং প্রমাণীকরণ স্কিম, যেমন বেসিক বা ডাইজেস্ট। 
- স্ট্যাটাসকোডসংখ্যা Chrome 43+স্ট্যান্ডার্ড HTTP স্থিতি কোড সার্ভার দ্বারা ফেরত. 
- স্ট্যাটাসলাইনস্ট্রিং প্রতিক্রিয়ার HTTP স্ট্যাটাস লাইন বা HTTP/0.9 প্রতিক্রিয়াগুলির জন্য 'HTTP/0.9 200 OK' স্ট্রিং (অর্থাৎ, যে প্রতিক্রিয়াগুলির একটি স্ট্যাটাস লাইন নেই) অথবা কোনো শিরোনাম না থাকলে একটি খালি স্ট্রিং। 
- ট্যাবআইডিসংখ্যা যে ট্যাবে অনুরোধ করা হয় তার আইডি। অনুরোধটি ট্যাবের সাথে সম্পর্কিত না হলে -1 এ সেট করুন। 
- টাইমস্ট্যাম্পসংখ্যা যুগের পর থেকে মিলিসেকেন্ডে যখন এই সংকেতটি ট্রিগার হয়। 
- প্রকারঅনুরোধকৃত সম্পদ কিভাবে ব্যবহার করা হবে। 
- urlস্ট্রিং 
 
- asyncCallbackফাংশন ঐচ্ছিক Chrome 58+asyncCallbackপ্যারামিটারটি এর মতো দেখাচ্ছে:(response: BlockingResponse) => void - প্রতিক্রিয়া
 
 - রিটার্নব্লকিং রেসপন্স | অনির্ধারিত যদি "অতিরিক্ত ইনফোস্পেক" প্যারামিটারে "ব্লকিং" নির্দিষ্ট করা থাকে, তাহলে ইভেন্ট শ্রোতার এই ধরনের একটি বস্তু ফেরত দেওয়া উচিত। 
 
- ফিল্টার
- extraInfoSpecOnAuthRequiredOptions [] ঐচ্ছিক 
onBeforeRedirect
chrome.webRequest.onBeforeRedirect.addListener(
callback: function,
filter: RequestFilter,
extraInfoSpec?: OnBeforeRedirectOptions[],
)
একটি সার্ভার-ইনিশিয়েটেড রিডাইরেক্ট ঘটতে চলেছে তখন বহিস্কার করা হয়েছে৷
পরামিতি
- কলব্যাকফাংশন callbackপ্যারামিটারটি এর মতো দেখাচ্ছে:(details: object) => void - বিস্তারিতবস্তু - ডকুমেন্ট আইডিস্ট্রিং Chrome 106+অনুরোধ করা নথির UUID। 
- নথি জীবনচক্রChrome 106+নথিটি যে জীবনচক্রে রয়েছে৷ 
- ফ্রেমআইডিসংখ্যা মান 0 নির্দেশ করে যে অনুরোধটি প্রধান ফ্রেমে ঘটে; একটি ইতিবাচক মান একটি সাবফ্রেমের ID নির্দেশ করে যেখানে অনুরোধটি ঘটে। যদি একটি (সাব-) ফ্রেমের নথি লোড করা হয় ( typeহলmain_frameবাsub_frame),frameIdএই ফ্রেমের আইডি নির্দেশ করে, বাইরের ফ্রেমের আইডি নয়। ফ্রেম আইডি একটি ট্যাবের মধ্যে অনন্য।
- ফ্রেম টাইপChrome 106+যে ধরনের ফ্রেমে অনুরোধ করা হয়েছে। 
- ক্যাশে থেকেবুলিয়ান এই প্রতিক্রিয়া ডিস্ক ক্যাশে থেকে আনা হয়েছে কিনা নির্দেশ করে। 
- সূচনাকারীস্ট্রিং ঐচ্ছিক Chrome 63+মূল যেখান থেকে অনুরোধ করা হয়েছিল। এটি পুনঃনির্দেশের মাধ্যমে পরিবর্তন হয় না। যদি এটি একটি অস্বচ্ছ উৎপত্তি হয়, স্ট্রিং 'নাল' ব্যবহার করা হবে। 
- আইপিস্ট্রিং ঐচ্ছিক যে সার্ভারের আইপি অ্যাড্রেসটিতে অনুরোধ পাঠানো হয়েছিল। মনে রাখবেন এটি একটি আক্ষরিক IPv6 ঠিকানা হতে পারে। 
- পদ্ধতিস্ট্রিং স্ট্যান্ডার্ড HTTP পদ্ধতি। 
- parentDocumentIdস্ট্রিং ঐচ্ছিক Chrome 106+এই ফ্রেমের মালিক নথির UUID। অভিভাবক না থাকলে এটি সেট করা হয় না। 
- parentFrameIdসংখ্যা ফ্রেমের আইডি যা অনুরোধ পাঠানো ফ্রেমটিকে মোড়ানো। কোন প্যারেন্ট ফ্রেম বিদ্যমান না থাকলে -1 এ সেট করুন। 
- redirectUrlস্ট্রিং নতুন URL. 
- অনুরোধ আইডিস্ট্রিং অনুরোধের আইডি। একটি ব্রাউজার সেশনের মধ্যে অনুরোধ আইডি অনন্য। ফলস্বরূপ, তারা একই অনুরোধের বিভিন্ন ইভেন্টের সাথে সম্পর্কিত করতে ব্যবহার করা যেতে পারে। 
- প্রতিক্রিয়া শিরোনামHttpHeaders ঐচ্ছিক এই পুনঃনির্দেশের সাথে প্রাপ্ত HTTP প্রতিক্রিয়া শিরোনাম। 
- স্ট্যাটাসকোডসংখ্যা স্ট্যান্ডার্ড HTTP স্থিতি কোড সার্ভার দ্বারা ফেরত. 
- স্ট্যাটাসলাইনস্ট্রিং প্রতিক্রিয়ার HTTP স্ট্যাটাস লাইন বা HTTP/0.9 প্রতিক্রিয়াগুলির জন্য 'HTTP/0.9 200 OK' স্ট্রিং (অর্থাৎ, যে প্রতিক্রিয়াগুলির একটি স্ট্যাটাস লাইন নেই) অথবা কোনো শিরোনাম না থাকলে একটি খালি স্ট্রিং। 
- ট্যাবআইডিসংখ্যা যে ট্যাবে অনুরোধ করা হয় তার আইডি। অনুরোধটি ট্যাবের সাথে সম্পর্কিত না হলে -1 এ সেট করুন। 
- টাইমস্ট্যাম্পসংখ্যা যুগের পর থেকে মিলিসেকেন্ডে যখন এই সংকেতটি ট্রিগার হয়। 
- প্রকারঅনুরোধকৃত সম্পদ কিভাবে ব্যবহার করা হবে। 
- urlস্ট্রিং 
 
 
- ফিল্টার
- extraInfoSpecOnBeforeRedirectOptions [] ঐচ্ছিক 
onBeforeRequest
chrome.webRequest.onBeforeRequest.addListener(
callback: function,
filter: RequestFilter,
extraInfoSpec?: OnBeforeRequestOptions[],
)
যখন একটি অনুরোধ ঘটতে চলেছে তখন বহিস্কার করা হয়েছে৷
পরামিতি
- কলব্যাকফাংশন callbackপ্যারামিটারটি এর মতো দেখাচ্ছে:(details: object) => BlockingResponse | undefined - বিস্তারিতবস্তু - ডকুমেন্ট আইডিস্ট্রিং ঐচ্ছিক Chrome 106+অনুরোধ করা নথির UUID। 
- নথি জীবনচক্রChrome 106+নথিটি যে জীবনচক্রে রয়েছে৷ 
- ফ্রেমআইডিসংখ্যা মান 0 নির্দেশ করে যে অনুরোধটি প্রধান ফ্রেমে ঘটে; একটি ইতিবাচক মান একটি সাবফ্রেমের ID নির্দেশ করে যেখানে অনুরোধটি ঘটে। যদি একটি (সাব-) ফ্রেমের নথি লোড করা হয় ( typeহলmain_frameবাsub_frame),frameIdএই ফ্রেমের আইডি নির্দেশ করে, বাইরের ফ্রেমের আইডি নয়। ফ্রেম আইডি একটি ট্যাবের মধ্যে অনন্য।
- ফ্রেম টাইপextensionTypes.FrameType ঐচ্ছিক Chrome 106+যে ধরনের ফ্রেমে অনুরোধ করা হয়েছে। 
- সূচনাকারীস্ট্রিং ঐচ্ছিক Chrome 63+মূল যেখান থেকে অনুরোধ করা হয়েছিল। এটি পুনঃনির্দেশের মাধ্যমে পরিবর্তন হয় না। যদি এটি একটি অস্বচ্ছ উৎপত্তি হয়, স্ট্রিং 'নাল' ব্যবহার করা হবে। 
- পদ্ধতিস্ট্রিং স্ট্যান্ডার্ড HTTP পদ্ধতি। 
- parentDocumentIdস্ট্রিং ঐচ্ছিক Chrome 106+এই ফ্রেমের মালিক নথির UUID। অভিভাবক না থাকলে এটি সেট করা হয় না। 
- parentFrameIdসংখ্যা ফ্রেমের আইডি যা অনুরোধ পাঠানো ফ্রেমটিকে মোড়ানো। কোন প্যারেন্ট ফ্রেম বিদ্যমান না থাকলে -1 এ সেট করুন। 
- অনুরোধবডিবস্তু ঐচ্ছিক HTTP অনুরোধের বডি ডেটা রয়েছে। শুধুমাত্র extraInfoSpec-এ 'requestBody' থাকলেই দেওয়া হয়। - ত্রুটিস্ট্রিং ঐচ্ছিক অনুরোধের বডি ডেটা পাওয়ার সময় ত্রুটি৷ 
- ফর্ম ডেটাবস্তু ঐচ্ছিক যদি অনুরোধের পদ্ধতিটি POST হয় এবং মূল অংশটি UTF8-এ এনকোড করা কী-মান জোড়ার একটি ক্রম হয়, হয় মাল্টিপার্ট/ফর্ম-ডেটা বা অ্যাপ্লিকেশন/x-www-ফর্ম-urlencoded হিসাবে এনকোড করা হয়, এই অভিধানটি উপস্থিত থাকে এবং প্রতিটি কী-এর জন্য সেই কী-এর জন্য সমস্ত মানের তালিকা থাকে। যদি ডেটা অন্য মিডিয়া টাইপের হয়, অথবা যদি এটি বিকৃত হয়, অভিধানটি উপস্থিত নয়। এই অভিধানের একটি উদাহরণ মান হল {'key': ['value1', 'value2']}। 
- কাঁচাআপলোড ডেটা [] ঐচ্ছিক যদি অনুরোধের পদ্ধতিটি PUT বা POST হয়, এবং বডিটি ইতিমধ্যেই formData-এ পার্স করা না হয়, তাহলে এই অ্যারেতে পার্স না করা অনুরোধের বডি উপাদানগুলি থাকে৷ 
 
- অনুরোধ আইডিস্ট্রিং অনুরোধের আইডি। একটি ব্রাউজার সেশনের মধ্যে অনুরোধ আইডি অনন্য। ফলস্বরূপ, তারা একই অনুরোধের বিভিন্ন ইভেন্টের সাথে সম্পর্কিত করতে ব্যবহার করা যেতে পারে। 
- ট্যাবআইডিসংখ্যা যে ট্যাবে অনুরোধ করা হয় তার আইডি। অনুরোধটি ট্যাবের সাথে সম্পর্কিত না হলে -1 এ সেট করুন। 
- টাইমস্ট্যাম্পসংখ্যা যুগের পর থেকে মিলিসেকেন্ডে যখন এই সংকেতটি ট্রিগার হয়। 
- প্রকারঅনুরোধকৃত সম্পদ কিভাবে ব্যবহার করা হবে। 
- urlস্ট্রিং 
 
 - রিটার্নব্লকিং রেসপন্স | অনির্ধারিত যদি "অতিরিক্ত ইনফোস্পেক" প্যারামিটারে "ব্লকিং" নির্দিষ্ট করা থাকে, তাহলে ইভেন্ট শ্রোতার এই ধরনের একটি বস্তু ফেরত দেওয়া উচিত। 
 
- ফিল্টার
- extraInfoSpecOnBeforeRequestOptions [] ঐচ্ছিক 
onBeforeSendHeaders
chrome.webRequest.onBeforeSendHeaders.addListener(
callback: function,
filter: RequestFilter,
extraInfoSpec?: OnBeforeSendHeadersOptions[],
)
অনুরোধ শিরোনাম উপলব্ধ হলে একটি HTTP অনুরোধ পাঠানোর আগে বহিস্কার করা হয়। সার্ভারে একটি TCP সংযোগ তৈরি হওয়ার পরে এটি ঘটতে পারে, কিন্তু কোনো HTTP ডেটা পাঠানোর আগে।
পরামিতি
- কলব্যাকফাংশন callbackপ্যারামিটারটি এর মতো দেখাচ্ছে:(details: object) => BlockingResponse | undefined - বিস্তারিতবস্তু - ডকুমেন্ট আইডিস্ট্রিং Chrome 106+অনুরোধ করা নথির UUID। 
- নথি জীবনচক্রChrome 106+নথিটি যে জীবনচক্রে রয়েছে৷ 
- ফ্রেমআইডিসংখ্যা মান 0 নির্দেশ করে যে অনুরোধটি প্রধান ফ্রেমে ঘটে; একটি ইতিবাচক মান একটি সাবফ্রেমের ID নির্দেশ করে যেখানে অনুরোধটি ঘটে। যদি একটি (সাব-) ফ্রেমের নথি লোড করা হয় ( typeহলmain_frameবাsub_frame),frameIdএই ফ্রেমের আইডি নির্দেশ করে, বাইরের ফ্রেমের আইডি নয়। ফ্রেম আইডি একটি ট্যাবের মধ্যে অনন্য।
- ফ্রেম টাইপChrome 106+যে ধরনের ফ্রেমে অনুরোধ করা হয়েছে। 
- সূচনাকারীস্ট্রিং ঐচ্ছিক Chrome 63+উত্স যেখানে অনুরোধ শুরু করা হয়েছিল। এটি পুনর্নির্দেশের মাধ্যমে পরিবর্তন হয় না। যদি এটি একটি অস্বচ্ছ উত্স হয় তবে স্ট্রিং 'নাল' ব্যবহার করা হবে। 
- পদ্ধতিস্ট্রিং স্ট্যান্ডার্ড এইচটিটিপি পদ্ধতি। 
- প্যারেন্টডোকামেন্টআইডিস্ট্রিং al চ্ছিক Chrome 106+এই ফ্রেমের মালিকানাধীন প্যারেন্ট ডকুমেন্টের ইউআইডি। পিতা বা মাতা না থাকলে এটি সেট করা হয় না। 
- প্যারেন্টফ্রেমিডসংখ্যা ফ্রেমের আইডি যা ফ্রেমটি মোড়ানো যা অনুরোধটি প্রেরণ করে। কোনও পিতামাতার ফ্রেম না থাকলে -1 এ সেট করুন। 
- অনুরোধ শিরোনামHttpeaders al চ্ছিক এইচটিটিপি অনুরোধ শিরোনামগুলি যা এই অনুরোধটি দিয়ে প্রেরণ করা হবে। 
- অনুরোধ আইডিস্ট্রিং অনুরোধের আইডি। ব্রাউজার সেশনের মধ্যে অনুরোধ আইডিগুলি অনন্য। ফলস্বরূপ, তারা একই অনুরোধের বিভিন্ন ইভেন্ট সম্পর্কিত করতে ব্যবহার করা যেতে পারে। 
- তাবিডসংখ্যা ট্যাবটির আইডি যেখানে অনুরোধটি ঘটে। অনুরোধটি কোনও ট্যাব সম্পর্কিত না হলে -1 এ সেট করুন। 
- টাইমস্ট্যাম্পসংখ্যা এই সংকেতটি ট্রিগার করা হয়, যুগের পর থেকে মিলিসেকেন্ডে। 
- প্রকারঅনুরোধ করা সংস্থানটি কীভাবে ব্যবহৃত হবে। 
- urlস্ট্রিং 
 
 - রিটার্নব্লকিং রেসপন্স | অনির্ধারিত যদি "ব্লকিং" "এক্সট্রেনফোস্পেক" প্যারামিটারে নির্দিষ্ট করা থাকে তবে ইভেন্ট শ্রোতার এই ধরণের কোনও অবজেক্ট ফিরিয়ে দেওয়া উচিত। 
 
- ফিল্টার
- এক্সট্রেনফোস্পেকOnbeforesendheadersoptions [] al চ্ছিক 
onCompleted
chrome.webRequest.onCompleted.addListener(
callback: function,
filter: RequestFilter,
extraInfoSpec?: OnCompletedOptions[],
)
একটি অনুরোধ শেষ হয়ে গেলে বরখাস্ত।
পরামিতি
- কলব্যাকফাংশন callbackপ্যারামিটারটি দেখে মনে হচ্ছে:(details: object) => void - বিস্তারিতবস্তু - ডকুমেন্টআইডিস্ট্রিং Chrome 106+অনুরোধটি তৈরি করে নথির ইউআইডি। 
- ডকুমেন্টলিফেসাইকেলChrome 106+লাইফসাইকেলটি দস্তাবেজটি রয়েছে। 
- ফ্রেমিডসংখ্যা মান 0 ইঙ্গিত করে যে অনুরোধটি মূল ফ্রেমে ঘটে; একটি ইতিবাচক মান একটি সাবফ্রেমের আইডি নির্দেশ করে যেখানে অনুরোধটি ঘটে। যদি এ (সাব-) ফ্রেমের নথিটি লোড করা হয় ( typemain_frameবাsub_frame),frameIdএই ফ্রেমের আইডি নির্দেশ করে, বাইরের ফ্রেমের আইডি নয়। ফ্রেম আইডিগুলি একটি ট্যাবের মধ্যে অনন্য।
- ফ্রেম টাইপChrome 106+অনুরোধটি ফ্রেমের ধরণটি ঘটেছে। 
- ক্যাচ থেকেবুলিয়ান যদি এই প্রতিক্রিয়াটি ডিস্ক ক্যাশে থেকে আনা হয়েছিল তা নির্দেশ করে। 
- সূচনাকারীস্ট্রিং al চ্ছিক Chrome 63+উত্স যেখানে অনুরোধ শুরু করা হয়েছিল। এটি পুনর্নির্দেশের মাধ্যমে পরিবর্তন হয় না। যদি এটি একটি অস্বচ্ছ উত্স হয় তবে স্ট্রিং 'নাল' ব্যবহার করা হবে। 
- আইপিস্ট্রিং al চ্ছিক সার্ভার আইপি ঠিকানা যে অনুরোধটি আসলে প্রেরণ করা হয়েছিল। নোট করুন যে এটি একটি আক্ষরিক আইপিভি 6 ঠিকানা হতে পারে। 
- পদ্ধতিস্ট্রিং স্ট্যান্ডার্ড এইচটিটিপি পদ্ধতি। 
- প্যারেন্টডোকামেন্টআইডিস্ট্রিং al চ্ছিক Chrome 106+এই ফ্রেমের মালিকানাধীন প্যারেন্ট ডকুমেন্টের ইউআইডি। পিতা বা মাতা না থাকলে এটি সেট করা হয় না। 
- প্যারেন্টফ্রেমিডসংখ্যা ফ্রেমের আইডি যা ফ্রেমটি মোড়ানো যা অনুরোধটি প্রেরণ করে। কোনও পিতামাতার ফ্রেম না থাকলে -1 এ সেট করুন। 
- অনুরোধ আইডিস্ট্রিং অনুরোধের আইডি। ব্রাউজার সেশনের মধ্যে অনুরোধ আইডিগুলি অনন্য। ফলস্বরূপ, তারা একই অনুরোধের বিভিন্ন ইভেন্ট সম্পর্কিত করতে ব্যবহার করা যেতে পারে। 
- প্রতিক্রিয়া শিরোনামHttpeaders al চ্ছিক এই প্রতিক্রিয়া সহ প্রাপ্ত এইচটিটিপি প্রতিক্রিয়া শিরোনামগুলি। 
- স্ট্যাটাসকোডসংখ্যা স্ট্যান্ডার্ড এইচটিটিপি স্থিতি কোড সার্ভার দ্বারা ফিরে। 
- স্ট্যাটাসলাইনস্ট্রিং প্রতিক্রিয়াটির HTTP স্ট্যাটাস লাইন বা এইচটিটিপি/0.9 প্রতিক্রিয়াগুলির জন্য 'এইচটিটিপি/0.9 200 ওকে' স্ট্রিং (অর্থাত্ কোনও স্ট্যাটাস লাইনের অভাব রয়েছে) বা কোনও খালি স্ট্রিং যদি কোনও শিরোনাম না থাকে। 
- তাবিডসংখ্যা ট্যাবটির আইডি যেখানে অনুরোধটি ঘটে। অনুরোধটি কোনও ট্যাব সম্পর্কিত না হলে -1 এ সেট করুন। 
- টাইমস্ট্যাম্পসংখ্যা এই সংকেতটি ট্রিগার করা হয়, যুগের পর থেকে মিলিসেকেন্ডে। 
- প্রকারঅনুরোধ করা সংস্থানটি কীভাবে ব্যবহৃত হবে। 
- urlস্ট্রিং 
 
 
- ফিল্টার
- এক্সট্রেনফোস্পেকOncompletedoptions [] al চ্ছিক 
onErrorOccurred
chrome.webRequest.onErrorOccurred.addListener(
callback: function,
filter: RequestFilter,
extraInfoSpec?: OnErrorOccurredOptions[],
)
একটি ত্রুটি দেখা দিলে বরখাস্ত।
পরামিতি
- কলব্যাকফাংশন callbackপ্যারামিটারটি দেখে মনে হচ্ছে:(details: object) => void - বিস্তারিতবস্তু - ডকুমেন্টআইডিস্ট্রিং Chrome 106+অনুরোধটি তৈরি করে নথির ইউআইডি। অনুরোধটি কোনও ফ্রেমের নেভিগেশন হলে এই মানটি উপস্থিত নেই। 
- ডকুমেন্টলিফেসাইকেলChrome 106+লাইফসাইকেলটি দস্তাবেজটি রয়েছে। 
- ত্রুটিস্ট্রিং ত্রুটির বিবরণ। এই স্ট্রিংটি রিলিজগুলির মধ্যে পিছনের দিকে সামঞ্জস্যপূর্ণ থাকার গ্যারান্টিযুক্ত নয় । আপনার অবশ্যই এর সামগ্রীর উপর ভিত্তি করে পার্স এবং কাজ করা উচিত নয়। 
- ফ্রেমিডসংখ্যা মান 0 ইঙ্গিত করে যে অনুরোধটি মূল ফ্রেমে ঘটে; একটি ইতিবাচক মান একটি সাবফ্রেমের আইডি নির্দেশ করে যেখানে অনুরোধটি ঘটে। যদি এ (সাব-) ফ্রেমের নথিটি লোড করা হয় ( typemain_frameবাsub_frame),frameIdএই ফ্রেমের আইডি নির্দেশ করে, বাইরের ফ্রেমের আইডি নয়। ফ্রেম আইডিগুলি একটি ট্যাবের মধ্যে অনন্য।
- ফ্রেম টাইপChrome 106+অনুরোধটি ফ্রেমের ধরণটি ঘটেছে। 
- ক্যাচ থেকেবুলিয়ান যদি এই প্রতিক্রিয়াটি ডিস্ক ক্যাশে থেকে আনা হয়েছিল তা নির্দেশ করে। 
- সূচনাকারীস্ট্রিং al চ্ছিক Chrome 63+উত্স যেখানে অনুরোধ শুরু করা হয়েছিল। এটি পুনর্নির্দেশের মাধ্যমে পরিবর্তন হয় না। যদি এটি একটি অস্বচ্ছ উত্স হয় তবে স্ট্রিং 'নাল' ব্যবহার করা হবে। 
- আইপিস্ট্রিং al চ্ছিক সার্ভার আইপি ঠিকানা যে অনুরোধটি আসলে প্রেরণ করা হয়েছিল। নোট করুন যে এটি একটি আক্ষরিক আইপিভি 6 ঠিকানা হতে পারে। 
- পদ্ধতিস্ট্রিং স্ট্যান্ডার্ড এইচটিটিপি পদ্ধতি। 
- প্যারেন্টডোকামেন্টআইডিস্ট্রিং al চ্ছিক Chrome 106+এই ফ্রেমের মালিকানাধীন প্যারেন্ট ডকুমেন্টের ইউআইডি। পিতা বা মাতা না থাকলে এটি সেট করা হয় না। 
- প্যারেন্টফ্রেমিডসংখ্যা ফ্রেমের আইডি যা ফ্রেমটি মোড়ানো যা অনুরোধটি প্রেরণ করে। কোনও পিতামাতার ফ্রেম না থাকলে -1 এ সেট করুন। 
- অনুরোধ আইডিস্ট্রিং অনুরোধের আইডি। ব্রাউজার সেশনের মধ্যে অনুরোধ আইডিগুলি অনন্য। ফলস্বরূপ, তারা একই অনুরোধের বিভিন্ন ইভেন্ট সম্পর্কিত করতে ব্যবহার করা যেতে পারে। 
- তাবিডসংখ্যা ট্যাবটির আইডি যেখানে অনুরোধটি ঘটে। অনুরোধটি কোনও ট্যাব সম্পর্কিত না হলে -1 এ সেট করুন। 
- টাইমস্ট্যাম্পসংখ্যা এই সংকেতটি ট্রিগার করা হয়, যুগের পর থেকে মিলিসেকেন্ডে। 
- প্রকারঅনুরোধ করা সংস্থানটি কীভাবে ব্যবহৃত হবে। 
- urlস্ট্রিং 
 
 
- ফিল্টার
- এক্সট্রেনফোস্পেকOnerroroccurredoptions [] al চ্ছিক 
onHeadersReceived
chrome.webRequest.onHeadersReceived.addListener(
callback: function,
filter: RequestFilter,
extraInfoSpec?: OnHeadersReceivedOptions[],
)
যখন কোনও অনুরোধের HTTP প্রতিক্রিয়া শিরোনামগুলি পাওয়া যায় তখন বরখাস্ত।
পরামিতি
- কলব্যাকফাংশন callbackপ্যারামিটারটি দেখে মনে হচ্ছে:(details: object) => BlockingResponse | undefined - বিস্তারিতবস্তু - ডকুমেন্টআইডিস্ট্রিং Chrome 106+অনুরোধটি তৈরি করে নথির ইউআইডি। 
- ডকুমেন্টলিফেসাইকেলChrome 106+লাইফসাইকেলটি দস্তাবেজটি রয়েছে। 
- ফ্রেমিডসংখ্যা মান 0 ইঙ্গিত করে যে অনুরোধটি মূল ফ্রেমে ঘটে; একটি ইতিবাচক মান একটি সাবফ্রেমের আইডি নির্দেশ করে যেখানে অনুরোধটি ঘটে। যদি এ (সাব-) ফ্রেমের নথিটি লোড করা হয় ( typemain_frameবাsub_frame),frameIdএই ফ্রেমের আইডি নির্দেশ করে, বাইরের ফ্রেমের আইডি নয়। ফ্রেম আইডিগুলি একটি ট্যাবের মধ্যে অনন্য।
- ফ্রেম টাইপChrome 106+অনুরোধটি ফ্রেমের ধরণটি ঘটেছে। 
- সূচনাকারীস্ট্রিং al চ্ছিক Chrome 63+উত্স যেখানে অনুরোধ শুরু করা হয়েছিল। এটি পুনর্নির্দেশের মাধ্যমে পরিবর্তন হয় না। যদি এটি একটি অস্বচ্ছ উত্স হয় তবে স্ট্রিং 'নাল' ব্যবহার করা হবে। 
- পদ্ধতিস্ট্রিং স্ট্যান্ডার্ড এইচটিটিপি পদ্ধতি। 
- প্যারেন্টডোকামেন্টআইডিস্ট্রিং al চ্ছিক Chrome 106+এই ফ্রেমের মালিকানাধীন প্যারেন্ট ডকুমেন্টের ইউআইডি। পিতা বা মাতা না থাকলে এটি সেট করা হয় না। 
- প্যারেন্টফ্রেমিডসংখ্যা ফ্রেমের আইডি যা ফ্রেমটি মোড়ানো যা অনুরোধটি প্রেরণ করে। কোনও পিতামাতার ফ্রেম না থাকলে -1 এ সেট করুন। 
- অনুরোধ আইডিস্ট্রিং অনুরোধের আইডি। ব্রাউজার সেশনের মধ্যে অনুরোধ আইডিগুলি অনন্য। ফলস্বরূপ, তারা একই অনুরোধের বিভিন্ন ইভেন্ট সম্পর্কিত করতে ব্যবহার করা যেতে পারে। 
- প্রতিক্রিয়া শিরোনামHttpeaders al চ্ছিক এই প্রতিক্রিয়াটির সাথে প্রাপ্ত এইচটিটিপি প্রতিক্রিয়া শিরোনামগুলি। 
- স্ট্যাটাসকোডসংখ্যা Chrome 43+স্ট্যান্ডার্ড এইচটিটিপি স্থিতি কোড সার্ভার দ্বারা ফিরে। 
- স্ট্যাটাসলাইনস্ট্রিং প্রতিক্রিয়াটির HTTP স্ট্যাটাস লাইন বা 'HTTP/0.9 200 ওকে' স্ট্রিং এইচটিটিপি/0.9 প্রতিক্রিয়াগুলির জন্য (যেমন, প্রতিক্রিয়াগুলি যা স্ট্যাটাস লাইনের অভাব রয়েছে)। 
- তাবিডসংখ্যা ট্যাবটির আইডি যেখানে অনুরোধটি ঘটে। অনুরোধটি কোনও ট্যাব সম্পর্কিত না হলে -1 এ সেট করুন। 
- টাইমস্ট্যাম্পসংখ্যা এই সংকেতটি ট্রিগার করা হয়, যুগের পর থেকে মিলিসেকেন্ডে। 
- প্রকারঅনুরোধ করা সংস্থানটি কীভাবে ব্যবহৃত হবে। 
- urlস্ট্রিং 
 
 - রিটার্নব্লকিং রেসপন্স | অনির্ধারিত যদি "ব্লকিং" "এক্সট্রেনফোস্পেক" প্যারামিটারে নির্দিষ্ট করা থাকে তবে ইভেন্ট শ্রোতার এই ধরণের কোনও অবজেক্ট ফিরিয়ে দেওয়া উচিত। 
 
- ফিল্টার
- এক্সট্রেনফোস্পেকEleadersreciedoptions [] al চ্ছিক 
onResponseStarted
chrome.webRequest.onResponseStarted.addListener(
callback: function,
filter: RequestFilter,
extraInfoSpec?: OnResponseStartedOptions[],
)
প্রতিক্রিয়া বডি প্রথম বাইট যখন প্রাপ্ত হয় তখন বরখাস্ত। এইচটিটিপি অনুরোধগুলির জন্য, এর অর্থ হ'ল স্ট্যাটাস লাইন এবং প্রতিক্রিয়া শিরোনামগুলি উপলব্ধ।
পরামিতি
- কলব্যাকফাংশন callbackপ্যারামিটারটি দেখে মনে হচ্ছে:(details: object) => void - বিস্তারিতবস্তু - ডকুমেন্টআইডিস্ট্রিং Chrome 106+অনুরোধটি তৈরি করে নথির ইউআইডি। 
- ডকুমেন্টলিফেসাইকেলChrome 106+লাইফসাইকেলটি দস্তাবেজটি রয়েছে। 
- ফ্রেমিডসংখ্যা মান 0 ইঙ্গিত করে যে অনুরোধটি মূল ফ্রেমে ঘটে; একটি ইতিবাচক মান একটি সাবফ্রেমের আইডি নির্দেশ করে যেখানে অনুরোধটি ঘটে। যদি এ (সাব-) ফ্রেমের নথিটি লোড করা হয় ( typemain_frameবাsub_frame),frameIdএই ফ্রেমের আইডি নির্দেশ করে, বাইরের ফ্রেমের আইডি নয়। ফ্রেম আইডিগুলি একটি ট্যাবের মধ্যে অনন্য।
- ফ্রেম টাইপChrome 106+অনুরোধটি ফ্রেমের ধরণটি ঘটেছে। 
- ক্যাচ থেকেবুলিয়ান যদি এই প্রতিক্রিয়াটি ডিস্ক ক্যাশে থেকে আনা হয়েছিল তা নির্দেশ করে। 
- সূচনাকারীস্ট্রিং al চ্ছিক Chrome 63+উত্স যেখানে অনুরোধ শুরু করা হয়েছিল। এটি পুনর্নির্দেশের মাধ্যমে পরিবর্তন হয় না। যদি এটি একটি অস্বচ্ছ উত্স হয় তবে স্ট্রিং 'নাল' ব্যবহার করা হবে। 
- আইপিস্ট্রিং al চ্ছিক সার্ভার আইপি ঠিকানা যে অনুরোধটি আসলে প্রেরণ করা হয়েছিল। নোট করুন যে এটি একটি আক্ষরিক আইপিভি 6 ঠিকানা হতে পারে। 
- পদ্ধতিস্ট্রিং স্ট্যান্ডার্ড এইচটিটিপি পদ্ধতি। 
- প্যারেন্টডোকামেন্টআইডিস্ট্রিং al চ্ছিক Chrome 106+এই ফ্রেমের মালিকানাধীন প্যারেন্ট ডকুমেন্টের ইউআইডি। পিতা বা মাতা না থাকলে এটি সেট করা হয় না। 
- প্যারেন্টফ্রেমিডসংখ্যা ফ্রেমের আইডি যা ফ্রেমটি মোড়ানো যা অনুরোধটি প্রেরণ করে। কোনও পিতামাতার ফ্রেম না থাকলে -1 এ সেট করুন। 
- অনুরোধ আইডিস্ট্রিং অনুরোধের আইডি। ব্রাউজার সেশনের মধ্যে অনুরোধ আইডিগুলি অনন্য। ফলস্বরূপ, তারা একই অনুরোধের বিভিন্ন ইভেন্ট সম্পর্কিত করতে ব্যবহার করা যেতে পারে। 
- প্রতিক্রিয়া শিরোনামHttpeaders al চ্ছিক এই প্রতিক্রিয়া সহ প্রাপ্ত এইচটিটিপি প্রতিক্রিয়া শিরোনামগুলি। 
- স্ট্যাটাসকোডসংখ্যা স্ট্যান্ডার্ড এইচটিটিপি স্থিতি কোড সার্ভার দ্বারা ফিরে। 
- স্ট্যাটাসলাইনস্ট্রিং প্রতিক্রিয়াটির HTTP স্ট্যাটাস লাইন বা এইচটিটিপি/0.9 প্রতিক্রিয়াগুলির জন্য 'এইচটিটিপি/0.9 200 ওকে' স্ট্রিং (অর্থাত্ কোনও স্ট্যাটাস লাইনের অভাব রয়েছে) বা কোনও খালি স্ট্রিং যদি কোনও শিরোনাম না থাকে। 
- তাবিডসংখ্যা ট্যাবটির আইডি যেখানে অনুরোধটি ঘটে। অনুরোধটি কোনও ট্যাব সম্পর্কিত না হলে -1 এ সেট করুন। 
- টাইমস্ট্যাম্পসংখ্যা এই সংকেতটি ট্রিগার করা হয়, যুগের পর থেকে মিলিসেকেন্ডে। 
- প্রকারঅনুরোধ করা সংস্থানটি কীভাবে ব্যবহৃত হবে। 
- urlস্ট্রিং 
 
 
- ফিল্টার
- এক্সট্রেনফোস্পেকOnresponsestartedoptions [] al চ্ছিক 
onSendHeaders
chrome.webRequest.onSendHeaders.addListener(
callback: function,
filter: RequestFilter,
extraInfoSpec?: OnSendHeadersOptions[],
)
সার্ভারে কোনও অনুরোধ প্রেরণের ঠিক আগে বরখাস্ত করা হয়েছে (অনসেন্ডহেডারদের বরখাস্ত করার সময় পূর্ববর্তী অনবফোরসেন্ডেডার্স কলব্যাকগুলির পরিবর্তনগুলি দৃশ্যমান হয়)।
পরামিতি
- কলব্যাকফাংশন callbackপ্যারামিটারটি দেখে মনে হচ্ছে:(details: object) => void - বিস্তারিতবস্তু - ডকুমেন্টআইডিস্ট্রিং Chrome 106+অনুরোধটি তৈরি করে নথির ইউআইডি। 
- ডকুমেন্টলিফেসাইকেলChrome 106+লাইফসাইকেলটি দস্তাবেজটি রয়েছে। 
- ফ্রেমিডসংখ্যা মান 0 ইঙ্গিত করে যে অনুরোধটি মূল ফ্রেমে ঘটে; একটি ইতিবাচক মান একটি সাবফ্রেমের আইডি নির্দেশ করে যেখানে অনুরোধটি ঘটে। যদি এ (সাব-) ফ্রেমের নথিটি লোড করা হয় ( typemain_frameবাsub_frame),frameIdএই ফ্রেমের আইডি নির্দেশ করে, বাইরের ফ্রেমের আইডি নয়। ফ্রেম আইডিগুলি একটি ট্যাবের মধ্যে অনন্য।
- ফ্রেম টাইপChrome 106+অনুরোধটি ফ্রেমের ধরণটি ঘটেছে। 
- সূচনাকারীস্ট্রিং al চ্ছিক Chrome 63+উত্স যেখানে অনুরোধ শুরু করা হয়েছিল। এটি পুনর্নির্দেশের মাধ্যমে পরিবর্তন হয় না। যদি এটি একটি অস্বচ্ছ উত্স হয় তবে স্ট্রিং 'নাল' ব্যবহার করা হবে। 
- পদ্ধতিস্ট্রিং স্ট্যান্ডার্ড এইচটিটিপি পদ্ধতি। 
- প্যারেন্টডোকামেন্টআইডিস্ট্রিং al চ্ছিক Chrome 106+এই ফ্রেমের মালিকানাধীন প্যারেন্ট ডকুমেন্টের ইউআইডি। পিতা বা মাতা না থাকলে এটি সেট করা হয় না। 
- প্যারেন্টফ্রেমিডসংখ্যা ফ্রেমের আইডি যা ফ্রেমটি মোড়ানো যা অনুরোধটি প্রেরণ করে। কোনও পিতামাতার ফ্রেম না থাকলে -1 এ সেট করুন। 
- অনুরোধ শিরোনামHttpeaders al চ্ছিক এইচটিটিপি অনুরোধ শিরোনামগুলি যা এই অনুরোধটি দিয়ে প্রেরণ করা হয়েছে। 
- অনুরোধ আইডিস্ট্রিং অনুরোধের আইডি। ব্রাউজার সেশনের মধ্যে অনুরোধ আইডিগুলি অনন্য। ফলস্বরূপ, তারা একই অনুরোধের বিভিন্ন ইভেন্ট সম্পর্কিত করতে ব্যবহার করা যেতে পারে। 
- তাবিডসংখ্যা ট্যাবটির আইডি যেখানে অনুরোধটি ঘটে। অনুরোধটি কোনও ট্যাব সম্পর্কিত না হলে -1 এ সেট করুন। 
- টাইমস্ট্যাম্পসংখ্যা এই সংকেতটি ট্রিগার করা হয়, যুগের পর থেকে মিলিসেকেন্ডে। 
- প্রকারঅনুরোধ করা সংস্থানটি কীভাবে ব্যবহৃত হবে। 
- urlস্ট্রিং 
 
 
- ফিল্টার
- এক্সট্রেনফোস্পেকঅনসেন্ডহেডারসোপশনস [] al চ্ছিক