এই উত্তরটি অনেকগুলি জমি জুড়ে তাই এটি তিন ভাগে বিভক্ত:
- "কোনও অ্যাক্সেস-কন্ট্রোল-অরিজিন-অরিজিন শিরোনাম" সমস্যাগুলির আশেপাশের পেতে কীভাবে একটি সিওআরএস প্রক্সি ব্যবহার করবেন
- কীভাবে সিওআরএস প্রিফলাইট এড়ানো যায়
- কীভাবে "অ্যাক্সেস-নিয়ন্ত্রণ-মঞ্জুরি-উত্স শিরোনাম অবশ্যই ওয়াইল্ডকার্ড না হওয়া উচিত" সমস্যাগুলি
"কোনও অ্যাক্সেস-কন্ট্রোল-অরিজিন-অরিজিন শিরোনাম" সমস্যাগুলির আশেপাশের পেতে কীভাবে একটি সিওআরএস প্রক্সি ব্যবহার করবেন
আপনি যদি সার্ভারটি নিয়ন্ত্রণ না করেন তবে আপনার সীমান্ত জাভাস্ক্রিপ্ট কোডটি একটি অনুরোধ প্রেরণ করছে এবং সেই সার্ভারের প্রতিক্রিয়াটি সমস্যা হ'ল প্রয়োজনীয় Access-Control-Allow-Origin
শিরোনামের অভাব , আপনি এখনও কাজ করার জন্য জিনিসগুলি পেতে পারেন - একটি মাধ্যমে অনুরোধ করে CORS প্রক্সি। এটি কীভাবে কাজ করে তা দেখানোর জন্য প্রথমে এখানে এমন কিছু কোড রয়েছে যা একটি সিওআরএস প্রক্সি ব্যবহার করে না:
const url = "https://example.com"; // site that doesn’t send Access-Control-*
fetch(url)
.then(response => response.text())
.then(contents => console.log(contents))
.catch(() => console.log("Can’t access " + url + " response. Blocked by browser?"))
কারণ catch
ব্লক আঘাত পরার আছে, ব্রাউজার বাধা প্রতিক্রিয়া যা থেকে ফিরে আসে অ্যাক্সেস করা থেকে কোড https://example.com
। এবং ব্রাউজারটি এর কারণটি হল, প্রতিক্রিয়াটিতে Access-Control-Allow-Origin
প্রতিক্রিয়া শিরোনামের অভাব রয়েছে ।
এখন, এখানে ঠিক একই উদাহরণ কিন্তু কেবল একটি CORS প্রক্সি যুক্ত করা হয়েছে:
const proxyurl = "https://cors-anywhere.herokuapp.com/";
const url = "https://example.com"; // site that doesn’t send Access-Control-*
fetch(proxyurl + url) // https://cors-anywhere.herokuapp.com/https://example.com
.then(response => response.text())
.then(contents => console.log(contents))
.catch(() => console.log("Can’t access " + url + " response. Blocked by browser?"))
দ্রষ্টব্য: https://cors-anywhere.herokuapp.com আপনি চেষ্টা করার পরে যদি তা ডাউন বা অনুপলব্ধ থাকে, তবে কীভাবে হিরোকুতে আপনার নিজস্ব সিওআরএস যে কোনও জায়গায় সার্ভার স্থাপন করতে কেবল নীচের ২-৩ মিনিটের মধ্যে দেখুন below
উপরের দ্বিতীয় কোড স্নিপেট সাফল্যের সাথে প্রতিক্রিয়া অ্যাক্সেস করতে পারে কারণ অনুরোধ ইউআরএল গ্রহণ এবং এটি https://cors-anywhere.herokuapp.com/https://example.com- এ পরিবর্তিত হয়েছে - কেবলমাত্র প্রক্সি ইউআরএলটির সাথে এটি উপসর্গ করার কারণে — সেই প্রক্সিটি দিয়ে যাওয়ার অনুরোধ, যা এরপরে:
- ফরওয়ার্ডটি ফরওয়ার্ড করুন
https://example.com
।
- থেকে প্রতিক্রিয়া প্রাপ্ত
https://example.com
।
Access-Control-Allow-Origin
প্রতিক্রিয়াতে শিরোনাম যুক্ত করে ।
- অনুরোধ করা সামনের কোডটিতে ফিরে সেই সংযুক্ত শিরোনাম সহ সেই প্রতিক্রিয়াটি পাস করে।
তারপরে ব্রাউজারটি ফ্রন্টএন্ড কোডটিকে প্রতিক্রিয়া অ্যাক্সেস করার অনুমতি দেয়, কারণ Access-Control-Allow-Origin
প্রতিক্রিয়া শিরোনাম সহ সেই প্রতিক্রিয়া ব্রাউজারটি যা দেখায়।
আপনি https://github.com/Rob--W/cors-anywhere/ থেকে কোড ব্যবহার করে সহজেই নিজের প্রক্সি চালাতে পারেন ।
5 টি কমান্ড সহ আপনি আক্ষরিক মাত্র 2-3 মিনিটে হিরোকুর কাছে নিজের প্রক্সিটি সহজেই স্থাপন করতে পারেন:
git clone https://github.com/Rob--W/cors-anywhere.git
cd cors-anywhere/
npm install
heroku create
git push heroku master
এই কমান্ডগুলি চালনার পরে, আপনি নিজের সিওআরএস যে কোনও জায়গায় যে কোনও সার্ভারের সাথে চলমান শেষ করবেন, যেমন, https://cryptic-headland-94862.herokuapp.com/ । সুতরাং আপনার অনুরোধটি ইউআরএলটির সাথে https://cors-anywhere.herokuapp.com
উপসর্গ করার পরিবর্তে এটি আপনার নিজের উদাহরণের জন্য ইউআরএলকে উপস্থাপন করুন; উদাহরণস্বরূপ, https://cryptic-headland-94862.herokuapp.com/https://example.com ।
সুতরাং আপনি যদি https://cors-anywhere.herokuapp.com ব্যবহার করার চেষ্টা করতে যান, আপনি এটি নীচে পেয়েছেন (যা এটি কখনও কখনও হবে) তবে হিরোকু অ্যাকাউন্ট পাওয়ার বিষয়ে বিবেচনা করুন (যদি আপনি ইতিমধ্যে না থাকেন) এবং 2 নিন বা 3 মিনিটের উপরে হিরোকুতে আপনার নিজস্ব সিওআরএস যে কোনও জায়গায় সার্ভার স্থাপন করতে উপরের পদক্ষেপগুলি করতে।
নির্বিশেষে, আপনি নিজের চালনা করেন বা https://cors-anywhere.herokuapp.com বা অন্যান্য উন্মুক্ত প্রক্সি ব্যবহার করুন না কেন, এই সমাধানটি অনুরোধটি ব্রাউজারদের একটি CORS প্রিফলাইট OPTIONS
অনুরোধটি করতে পরিচালিত করে এমনকী works কারণ সেই ক্ষেত্রে, প্রক্সি এছাড়াও ফেরত পাঠায় Access-Control-Allow-Headers
এবং Access-Control-Allow-Methods
preflight সফল করার জন্য প্রয়োজন হেডার।
কীভাবে সিওআরএস প্রিফলাইট এড়ানো যায়
প্রশ্নটিতে কোডটি একটি কর্স প্রিফলাইটকে ট্রিগার করে - যেহেতু এটি একটি Authorization
শিরোনাম প্রেরণ করে ।
https://developer.mozilla.org/en-US/docs/Web/HTTP/Access_control_CORS#Preflighted_requests
এমনকি এটি ছাড়া, Content-Type: application/json
শিরোনামটি প্রিফলাইটটিও ট্রিগার করবে।
"কি preflight" অর্থ: সামনে ব্রাউজার চেষ্টা POST
প্রশ্নে কোডে, এটি প্রথমে একটি পাঠাব OPTIONS
সার্ভারে অনুরোধ - নির্ধারণ করার জন্য একটি ক্রশ-অরিজিন প্রাপ্তির যদি সার্ভার নির্বাচন-ইন করা হয় POST
যে অন্তর্ভুক্ত Authorization
এবং Content-Type: application/json
হেডার।
এটি একটি ছোট কার্ল স্ক্রিপ্টের সাথে বেশ ভালভাবে কাজ করে - আমি আমার ডেটা পাই।
যথাযথভাবে পরীক্ষা করার জন্য curl
, আপনাকে অবশ্যই OPTIONS
ব্রাউজার প্রিফ্লাইট অনুরোধটি অনুকরণ করতে হবে :
curl -i -X OPTIONS -H "Origin: http://127.0.0.1:3000" \
-H 'Access-Control-Request-Method: POST' \
-H 'Access-Control-Request-Headers: Content-Type, Authorization' \
"https://the.sign_in.url"
… https://the.sign_in.url
আপনার আসল sign_in
ইউআরএল যাই হোক না কেন দ্বারা প্রতিস্থাপিত ।
ব্রাউজারটি সেই OPTIONS
অনুরোধটি থেকে যে প্রতিক্রিয়া দেখতে পাবে তার অবশ্যই এই জাতীয় শিরোনাম অন্তর্ভুক্ত করতে হবে:
Access-Control-Allow-Origin: http://127.0.0.1:3000
Access-Control-Allow-Methods: POST
Access-Control-Allow-Headers: Content-Type, Authorization
যদি OPTIONS
প্রতিক্রিয়াতে এই শিরোনামগুলি অন্তর্ভুক্ত না করা হয় তবে ব্রাউজারটি ঠিক সেখানেই থামবে এবং POST
অনুরোধটি প্রেরণের চেষ্টা করবে না । এছাড়াও, প্রতিক্রিয়াটির জন্য এইচটিটিপি স্থিতি কোডটি অবশ্যই 2Xxx — সাধারণত 200 বা 204 হতে হবে it's এটি যদি অন্য কোনও স্থিতি কোড হয় তবে ব্রাউজারটি ঠিক সেখানেই থামবে।
প্রশ্নের সার্ভারটি OPTIONS
501 স্থিতি কোডের সাথে অনুরোধটির প্রতিক্রিয়া জানাচ্ছে , যা স্পষ্টতই বোঝাতে চাইছে এটি OPTIONS
অনুরোধের জন্য সমর্থনটি কার্যকর করে না এমনটি বোঝানোর চেষ্টা করছে । অন্যান্য সার্ভারগুলি সাধারণত এই ক্ষেত্রে 405 "পদ্ধতি অনুমোদিত নয়" স্থিতি কোড দিয়ে সাড়া দেয়।
সুতরাং POST
সার্ভার যদি OPTIONS
405 বা 501 অথবা 200 বা 204 ব্যতীত অন্য কোনও কিছু দিয়ে যদি অনুরোধটির প্রতিক্রিয়া জানায় বা প্রয়োজনীয় লোকদের সাথে সাড়া না দেয় তবে আপনি কখনই আপনার সম্মুখ সীমান্তের জাভাস্ক্রিপ্ট কোড থেকে সরাসরি সেই সার্ভারে অনুরোধ করতে পারবেন না going প্রতিক্রিয়া শিরোনাম।
প্রশ্নের ক্ষেত্রে প্রিফলাইটটি ট্রিগার না করার উপায় হ'ল:
- যদি সার্ভারটির জন্য
Authorization
অনুরোধ শিরোনামের প্রয়োজন না হয় তবে পরিবর্তে (উদাহরণস্বরূপ) অনুরোধের শিরোনামে POST
বা ক্যোয়ারি প্যারামিটার হিসাবে এম্বেড করা প্রমাণীকরণ ডেটার উপর নির্ভর করে
- সার্ভারের যদি
POST
কোনও Content-Type: application/json
মিডিয়ার প্রকারের জন্য শরীরের প্রয়োজন না হয় তবে পরিবর্তে নামটির (বা যা কিছু) যার মান JSON ডেটা বলে তার সাথে POST
শরীর গ্রহণ করেapplication/x-www-form-urlencoded
json
কীভাবে "অ্যাক্সেস-নিয়ন্ত্রণ-মঞ্জুরি-উত্স শিরোনাম অবশ্যই ওয়াইল্ডকার্ড না হওয়া উচিত" সমস্যাগুলি
আমি আর একটি ত্রুটি বার্তা পাচ্ছি:
অনুরোধের শংসাপত্র মোডে 'অন্তর্ভুক্ত' থাকাকালীন প্রতিক্রিয়াতে 'অ্যাক্সেস-কন্ট্রোল-অলজন-অরিজিন' শিরোনামের মান অবশ্যই ওয়াইল্ডকার্ড '*' হওয়া উচিত নয়। উত্স ' http://127.0.0.1:3000 ' এ অ্যাক্সেসের অনুমতি নেই। XMLHttpRequest দ্বারা শুরু করা অনুরোধগুলির শংসাপত্রের মোডটি শংসাপত্রের বৈশিষ্ট্য সহ নিয়ন্ত্রণ করা হয়।
শংসাপত্রাদি অন্তর্ভুক্ত এমন একটি অনুরোধের জন্য, Access-Control-Allow-Origin
প্রতিক্রিয়া শিরোনামের মানটি থাকলে ব্রাউজারগুলি আপনার অগ্রণী জাভাস্ক্রিপ্ট কোডটিকে প্রতিক্রিয়া অ্যাক্সেস করতে দেয় না *
। পরিবর্তে সেই ক্ষেত্রে মানটি অবশ্যই আপনার ফ্রন্টএন্ড কোডের উত্সের সাথে অবশ্যই মিলবে http://127.0.0.1:3000
।
MDN HTTP অ্যাক্সেস নিয়ন্ত্রণ (সিওআরএস) নিবন্ধে শংসাপত্রযুক্ত অনুরোধ এবং ওয়াইল্ডকার্ডগুলি দেখুন ।
আপনি যদি যে সার্ভারটিতে অনুরোধটি পাঠাচ্ছেন সেটি নিয়ন্ত্রণ করেন, তবে এই ক্ষেত্রে মোকাবেলার একটি সাধারণ উপায় হ'ল Origin
অনুরোধ শিরোনামের মান গ্রহণের জন্য সার্ভারটি কনফিগার করা এবং Access-Control-Allow-Origin
প্রতিক্রিয়া শিরোনামের মানটির প্রতিধ্বনি / প্রতিবিম্বিত করা । উদাহরণস্বরূপ, nginx সহ:
add_header Access-Control-Allow-Origin $http_origin
তবে এটি কেবল একটি উদাহরণ; অন্যান্য (ওয়েব) সার্ভার সিস্টেমগুলি মূল মানগুলি প্রতিধ্বনির অনুরূপ উপায় সরবরাহ করে।
আমি ক্রোম ব্যবহার করছি। আমি সেই ক্রোম সিওআরএস প্লাগইনটি ব্যবহার করার চেষ্টা করেছি
সেই ক্রোম সিওআরএস প্লাগইন স্পষ্টতই সহজ সরলভাবে Access-Control-Allow-Origin: *
ব্রাউজারটির প্রতিক্রিয়াটিতে একটি শিরোনামকে ইনজেক্ট করে। প্লাগইনটি যদি বুদ্ধিমান হয় তবে এটি কী করবে তা সেই জাল Access-Control-Allow-Origin
প্রতিক্রিয়া শিরোনামের মানটিকে আপনার সীমান্ত জাভাস্ক্রিপ্ট কোডের আসল উত্সে সেট করে http://127.0.0.1:3000
।
সুতরাং পরীক্ষার জন্য এমনকি, প্লাগইন ব্যবহার এড়াতে। এটি কেবল একটি বিভ্রান্তি। আপনি যদি সার্ভার থেকে কোনও ব্রাউজার ফিল্টার না করে কী প্রতিক্রিয়া পান তা পরীক্ষা করতে চান তবে curl -H
উপরের মতো ব্যবহার করা ভাল ।
fetch(…)
প্রশ্নে অনুরোধের জন্য যতদূর সীমান্ত জাভাস্ক্রিপ্ট কোড :
headers.append('Access-Control-Allow-Origin', 'http://localhost:3000');
headers.append('Access-Control-Allow-Credentials', 'true');
সেই লাইনগুলি সরান। Access-Control-Allow-*
হেডার হয় প্রতিক্রিয়া হেডার। আপনি তাদের অনুরোধে কখনই প্রেরণ করতে চান না। কেবলমাত্র প্রভাবটি হ'ল একটি প্রিফলাইট করতে ব্রাউজারকে ট্রিগার করা।