উত্তর:
আপনি যখন কোনও পোষ্ট অনুরোধ করেন তখন আপনাকে সেই ডেটাটি এনকোড করতে হয় যা কোনও উপায়ে অনুরোধের মূল গঠন করে।
এইচটিএমএল ফর্মগুলি এনকোডিংয়ের তিনটি পদ্ধতি সরবরাহ করে।
application/x-www-form-urlencoded
(ডিফল্ট)multipart/form-data
text/plain
যুক্ত করার কাজ চলছে application/json
, তবে তা পরিত্যাগ করা হয়েছে।
(এইচটিটিপি অনুরোধের সাথে এইচটিএমএল ফর্ম জমা দেওয়ার চেয়ে অন্য উপায়গুলির সাহায্যে উত্পন্ন অন্যান্য এনকোডিংগুলি সম্ভব J
ফর্ম্যাটগুলির স্পেসিফিকেশন বেশিরভাগ বিকাশকারীদের কাছে আসে না। গুরুত্বপূর্ণ বিষয়গুলি হ'ল:
text/plain
।আপনি যখন ক্লায়েন্ট-সাইড কোডটি লিখছেন:
multipart/form-data
যখন আপনার ফর্মটিতে কোনও <input type="file">
উপাদান রয়েছে তখন ব্যবহার করুনmultipart/form-data
বা application/x-www-form-urlencoded
তবে application/x-www-form-urlencoded
আরও কার্যকর হবেআপনি যখন সার্ভার-সাইড কোডটি লিখছেন:
বেশিরভাগ (যেমন পার্ল CGI->param
বা পিএইচপি'র দ্বারা উদ্ভাসিত একটি$_POST
সুপারগ্লোবাল ) আপনার জন্য পার্থক্যের যত্ন নেবে। সার্ভার দ্বারা প্রাপ্ত কাঁচা ইনপুট পার্স করার চেষ্টা করে বিরক্ত করবেন না।
কখনও কখনও আপনি একটি লাইব্রেরি পাবেন যা উভয় ফর্ম্যাট পরিচালনা করতে পারে না। ফর্ম ডেটা পরিচালনা করার জন্য নোড.জেএসের সর্বাধিক জনপ্রিয় লাইব্রেরি হ'ল বডি পার্সার যা মাল্টিপার্ট অনুরোধগুলি পরিচালনা করতে পারে না (তবে ডকুমেন্টেশন রয়েছে যা কিছু বিকল্পের প্রস্তাব দেয় যা পারে))
যদি আপনি কাঁচা ডেটা বিশ্লেষণ বা উত্পাদনের জন্য কোনও গ্রন্থাগার লিখছেন (বা ডিবাগ করছেন) তবে আপনাকে ফর্ম্যাটটি নিয়ে চিন্তিত হওয়া শুরু করতে হবে। আপনি আগ্রহের স্বার্থে এটি সম্পর্কে জানতেও চাইতে পারেন।
application/x-www-form-urlencoded
কমপক্ষে URL এর শেষে ক্যোরি স্ট্রিংয়ের মতোই।
multipart/form-data
উল্লেখযোগ্যভাবে আরও জটিল তবে এটি সম্পূর্ণ ফাইলগুলিকে ডেটাতে অন্তর্ভুক্ত করার অনুমতি দেয়। ফলাফলের একটি উদাহরণ এইচটিএমএল 4 স্পেসিফিকেশনে পাওয়া যাবে ।
text/plain
এইচটিএমএল 5 দ্বারা প্রবর্তন করা হয়েছে এবং কেবলমাত্র ডিবাগিংয়ের জন্যই কার্যকর - এই অনুমান থেকে : এগুলি কম্পিউটারের দ্বারা নির্ভরযোগ্যভাবে ব্যাখ্যাযোগ্য নয় - এবং আমি যুক্তি দেব যে অন্যরা সরঞ্জামগুলির সাথে মিলিত হয়েছে ( বেশিরভাগ ব্রাউজারগুলির বিকাশকারী সরঞ্জামগুলির মধ্যে নেটওয়ার্ক প্যানেলের মতো ) আরও ভাল যে জন্য).
আমাদের কখন এটি ব্যবহার করা উচিত
কোয়ান্টিনের উত্তরটি সঠিক: multipart/form-data
ফর্মটিতে কোনও ফাইল আপলোড থাকলে ব্যবহার করুন এবং application/x-www-form-urlencoded
অন্যথায়, যদি আপনি বাদ দেন তবে এটি ডিফল্ট enctype
।
আমি যাচ্ছি:
আছে তিন সম্ভাবনার জন্য enctype
:
application/x-www-form-urlencoded
multipart/form-data
( আরএফসি 7578 এর দিকে নির্দিষ্ট বিন্দু )text/plain
। এটি "কম্পিউটারের দ্বারা নির্ভরযোগ্যভাবে ব্যাখ্যাযোগ্য নয়", সুতরাং এটি কখনও উত্পাদনে ব্যবহার করা উচিত নয় এবং আমরা এটির দিকে আরও তাকাব না।একবার আপনি প্রতিটি পদ্ধতির উদাহরণ দেখতে পেলে এগুলি কীভাবে কাজ করে তা স্পষ্ট হয়ে যায় এবং কখন আপনার প্রতিটি ব্যবহার করা উচিত।
আপনি ব্যবহার করে উদাহরণ তৈরি করতে পারেন:
nc -l
বা একটি ECHO সার্ভার: এইচটিটিপি পরীক্ষা সার্ভার জিইটি / পোস্ট অনুরোধ গ্রহণ করেন্যূনতম .html
ফাইলে ফর্মটি সংরক্ষণ করুন:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8"/>
<title>upload</title>
</head>
<body>
<form action="http://localhost:8000" method="post" enctype="multipart/form-data">
<p><input type="text" name="text1" value="text default">
<p><input type="text" name="text2" value="aωb">
<p><input type="file" name="file1">
<p><input type="file" name="file2">
<p><input type="file" name="file3">
<p><button type="submit">Submit</button>
</form>
</body>
</html>
আমরা ডিফল্ট টেক্সট মান সেট aωb
, যার মানে aωb
কারণ ω
হয় U+03C9
, যা বাইট হয় 61 CF 89 62
হল UTF-8।
আপলোড করার জন্য ফাইলগুলি তৈরি করুন:
echo 'Content of a.txt.' > a.txt
echo '<!DOCTYPE html><title>Content of a.html.</title>' > a.html
# Binary file containing 4 bytes: 'a', 1, 2 and 'b'.
printf 'a\xCF\x89b' > binary
আমাদের ছোট ইকো সার্ভারটি চালান:
while true; do printf '' | nc -l 8000 localhost; done
আপনার ব্রাউজারে এইচটিএমএল খুলুন, ফাইলগুলি নির্বাচন করুন এবং জমাতে ক্লিক করুন এবং টার্মিনালটি পরীক্ষা করুন।
nc
প্রাপ্ত অনুরোধটি মুদ্রণ করে।
পরীক্ষিত: উবুন্টু 14.04.3, nc
বিএসডি 1.105, ফায়ারফক্স 40।
ফায়ারফক্স পাঠানো হয়েছে:
POST / HTTP/1.1
[[ Less interesting headers ... ]]
Content-Type: multipart/form-data; boundary=---------------------------735323031399963166993862150
Content-Length: 834
-----------------------------735323031399963166993862150
Content-Disposition: form-data; name="text1"
text default
-----------------------------735323031399963166993862150
Content-Disposition: form-data; name="text2"
aωb
-----------------------------735323031399963166993862150
Content-Disposition: form-data; name="file1"; filename="a.txt"
Content-Type: text/plain
Content of a.txt.
-----------------------------735323031399963166993862150
Content-Disposition: form-data; name="file2"; filename="a.html"
Content-Type: text/html
<!DOCTYPE html><title>Content of a.html.</title>
-----------------------------735323031399963166993862150
Content-Disposition: form-data; name="file3"; filename="binary"
Content-Type: application/octet-stream
aωb
-----------------------------735323031399963166993862150--
বাইনারি ফাইল এবং পাঠ্য ক্ষেত্রের জন্য, বাইটগুলি 61 CF 89 62
( aωb
ইউটিএফ -8 এ) আক্ষরিকভাবে প্রেরণ করা হয়। আপনি এটি যাচাই করতে পারেন nc -l localhost 8000 | hd
, যা বলে যে বাইটগুলি:
61 CF 89 62
প্রেরণ করা হয়েছিল ( 61
== 'এ' এবং 62
== 'বি')।
সুতরাং এটি পরিষ্কার যে:
Content-Type: multipart/form-data; boundary=---------------------------735323031399963166993862150
সামগ্রীতে প্রকার সেট করে multipart/form-data
এবং বলে যে ক্ষেত্রগুলি প্রদত্ত boundary
স্ট্রিং দ্বারা পৃথক করা হয়েছে ।
তবে লক্ষ করুন যে:
boundary=---------------------------735323031399963166993862150
--
আসল বাধার চেয়ে দুটি কম ড্যাডেস রয়েছে
-----------------------------735323031399963166993862150
এটি কারণ দুটি স্ট্যাশ দিয়ে শুরু করার জন্য স্ট্যান্ডার্ডটির সীমা প্রয়োজন --
। অন্যান্য ড্যাশগুলি ফায়ারফক্স স্বেচ্ছাসেবী সীমানা বাস্তবায়নের জন্য কীভাবে বেছে নিয়েছিল তা প্রদর্শিত হবে। আরএফসি 7578 স্পষ্টভাবে উল্লেখ করেছে যে এই দুটি শীর্ষস্থানীয় ড্যাশগুলি --
প্রয়োজনীয়:
4.1। গুণমান / ফর্ম-ডেটার "সীমানা" পরামিতি
অন্যান্য বহুগুণিত প্রকারের মতো, অংশগুলি সীমানা ডিলিমিটারের সাথে সীমানাযুক্ত, সিআরএলএফ, "-" ব্যবহার করে নির্মিত হয় এবং "সীমানা" প্যারামিটারের মান হয়।
প্রতিটি ক্ষেত্র তার ডেটার আগে কিছু উপ-শিরোনাম পায়: Content-Disposition: form-data;
ক্ষেত্র name
, এর filename
, ডেটা অনুসরণ করে।
সার্ভারটি পরবর্তী সীমানা স্ট্রিং পর্যন্ত ডেটা পড়ে। ব্রাউজারকে অবশ্যই এমন একটি সীমানা বেছে নিতে হবে যা কোনও ক্ষেত্রেই উপস্থিত হবে না, তাই অনুরোধের মধ্যে সীমানা আলাদা হতে পারে।
কারণ আমাদের অনন্য সীমানা, তথ্যের কোনও এনকোডিং প্রয়োজন নেই: বাইনারি ডেটা যেমন পাঠানো হয় তেমন।
টোডো: অনুকূল সীমানা আকার ( log(N)
আমি বাজি রেখেছি), এবং এটি খুঁজে পাওয়া অ্যালগরিদমের নাম / চলমান সময়টি কী? জিজ্ঞাসা করা হয়েছে: /cs/39687/find-the-shortest-sequence-that-is-not-a-sub-sequence-of-a-set-of-sequence
Content-Type
ব্রাউজার দ্বারা স্বয়ংক্রিয়ভাবে নির্ধারিত হয়।
এটি ঠিক কীভাবে নির্ধারণ করা হয় তাতে জিজ্ঞাসা করা হয়েছিল: ব্রাউজার দ্বারা নির্ধারিত কোনও আপলোড করা ফাইলের মাইম কীভাবে হয়?
এখন পরিবর্তন enctype
করতে application/x-www-form-urlencoded
, ব্রাউজার, এবং পুনরায় জমা পুনরায় লোড করুন।
ফায়ারফক্স পাঠানো হয়েছে:
POST / HTTP/1.1
[[ Less interesting headers ... ]]
Content-Type: application/x-www-form-urlencoded
Content-Length: 51
text1=text+default&text2=a%CF%89b&file1=a.txt&file2=a.html&file3=binary
স্পষ্টতই ফাইলের ডেটা প্রেরণ করা হয়নি, কেবলমাত্র বেসনামগুলি। সুতরাং এটি ফাইলগুলির জন্য ব্যবহার করা যাবে না।
টেক্সট ক্ষেত্রের জন্য, আমরা মতো স্বাভাবিক মুদ্রণযোগ্য অক্ষর দেখতে a
এবং b
এক বাইট বার্তা পাঠানো হয়েছে, যখন মত মুদ্রণযোগ্য নয় এমন বেশী 0xCF
এবং 0x89
গ্রহণ 3 বাইট প্রতিটি: %CF%89
!
ফাইল আপলোডগুলিতে প্রায়শই প্রিন্টযোগ্য অক্ষরগুলি থাকে (যেমন চিত্রগুলি), তবে পাঠ্য ফর্মগুলি প্রায়শই হয় না।
যে উদাহরণগুলি আমরা দেখেছি তা থেকে:
multipart/form-data
: বার্তায় সীমানা ওভারহেডের কয়েকটি বাইট যুক্ত করে এবং এটি গণনায় কিছুটা সময় ব্যয় করতে হবে তবে প্রতিটি বাইটকে একটি বাইটে প্রেরণ করে।
application/x-www-form-urlencoded
: ক্ষেত্রের ( &
) প্রতি একক বাইট সীমানা রয়েছে তবে প্রতিটি অপ্রিন্টযোগ্য অক্ষরের জন্য 3x এর লিনিয়ার ওভারহেড ফ্যাক্টর যুক্ত করে।
সুতরাং, আমরা ফাইলগুলি প্রেরণ করতে পারলেও application/x-www-form-urlencoded
, আমরা চাই না, কারণ এটি এতটা অক্ষম।
তবে পাঠ্য ক্ষেত্রগুলিতে মুদ্রণযোগ্য অক্ষরগুলির জন্য, এটি কোনও বিষয় নয় এবং কম ওভারহেড উত্পন্ন করে, তাই আমরা কেবল এটি ব্যবহার করি।
%CF
3 বাইট দীর্ঘ: %
, C
এবং F
:-) এটা মানুষের পাঠযোগ্য উপার্জন গল্প।
nc
উভয় -l
এবং -p
যুক্তি উভয়ই গ্রহণ করবে না । কিন্তু এই আমার জন্য কাজ করে: while true; do printf '' | nc -l 8000; done
।
Content-Type
তার দুটি হাইফেন ( --
) কম রয়েছে, অর্থাত্ যখন বার্তাটির শরীরে সীমানাটি ব্যবহার করার সময় আপনাকে অবশ্যই এটির উপসর্গ দিয়ে যেতে হবে --
। এছাড়াও, শেষ সীমানাটি অবশ্যই প্রত্যয়যুক্ত হওয়া উচিত --
, তবে এটি লক্ষ্য করা যথেষ্ট সহজ। দেখুন stackoverflow.com/questions/3508252/...
enctype='multipart/form-data
একটি এনকোডিং টাইপ যা কোনও পোস্টের মাধ্যমে ফাইলগুলি প্রেরণের অনুমতি দেয় । বেশ সহজভাবে, এই এনকোডিং ব্যতীত ফাইলগুলি পোস্টের মাধ্যমে প্রেরণ করা যায় না ।
আপনি যদি কোনও ব্যবহারকারীকে কোনও ফর্মের মাধ্যমে কোনও ফাইল আপলোড করার অনুমতি দিতে চান তবে আপনাকে অবশ্যই এই এনটাইপটি ব্যবহার করতে হবে ।
multipart/form-data
নন-বাইনারি ফাইল প্রেরণের জন্য ব্যবহার করতে পারেন তবে এটি অদক্ষ। আমি বিশ্বাস করি application/x-www-form-urlencoded
নন-বাইনারি ডেটা প্রেরণের সঠিক উপায় তবে নন-বাইনারি ফাইলগুলির সাথে আরও অভিজ্ঞতার সাথে আমাকে সংশোধন করার প্রয়োজন হতে পারে।
multipart/form-data
কোনও ফাইল প্রেরণের জন্য প্রধান সুবিধাটি হ'ল এটি সম্মুখভাগ এবং ব্যাকএন্ড উভয় ক্ষেত্রে স্বয়ংক্রিয়ভাবে কাজ করবে। আপনাকে কোনও বিশেষ হ্যান্ডলিং করতে হবে না। সমস্ত ফাইল বাইনারি হয় এমনকি যদি তাদের কেবল পাঠ্য থাকে contain application/x-www-form-urlencoded
সংযুক্ত ফাইল ছাড়াই কোনও ফর্ম পোস্ট করার মানক উপায়। multipart/form-data
সংযুক্ত ফাইল (গুলি) সহ একটি ফর্ম পোস্ট করার মানক উপায়। (এছাড়াও যেমন অনেক অন্যান্য এনকোডিং হয় application/json
এবং application/json-patch+json
যা সার্ভার এবং ক্লায়েন্ট মধ্যে যোগাযোগের জন্য সাধারণ।)
multipart/form-data
। আপনি যা করতে পারবেন না তা হ'ল জাভাস্ক্রিপ্ট ছাড়াই একটি সাধারণ এইচটিএমএল ফর্ম জমা ব্যবহার করা। ব্যবহারের multipart/form-data
জন্য ফর্ম সেট করা একমাত্র প্রক্রিয়া যা এইচটিএমএল আপনাকে জাভাস্ক্রিপ্ট ব্যবহার না করেই ফাইল পোস্ট করতে দেয়। আমি মনে করি এটি উত্তরে যথেষ্ট পরিস্কার নয়, এবং একজন নিরীহ পাঠক মনে করতে পারেন যে ফাইলগুলি প্রেরণ করতে অক্ষমতা এইচটিটিপিmultipart/form-data
- র একটি সীমাবদ্ধতা ; এটা কেস নয়।
কোনও ফর্ম জমা দেওয়ার সময়, আপনি আপনার ব্রাউজারটি HTTP প্রোটোকলের মাধ্যমে, নেটওয়ার্কে একটি বার্তা প্রেরণ করতে বলেন, সঠিকভাবে একটি TCP / IP প্রোটোকল বার্তা কাঠামোটিতে আবদ্ধ। এইচটিএমএল পৃষ্ঠার সার্ভারে ডেটা প্রেরণের একটি উপায় রয়েছে: <form>
গুলি ব্যবহার করে ।
যখন কোনও ফর্ম জমা দেওয়া হয়, একটি HTTP অনুরোধ তৈরি করা হয় এবং সার্ভারে প্রেরণ করা হয়, বার্তায় ফর্মের ফিল্ডের নাম এবং ব্যবহারকারীর দ্বারা ভরাট মানগুলি থাকবে contain এই সংক্রমণ সঙ্গে ঘটতে পারে POST
বা GET
HTTP- র পদ্ধতি ।
POST
আপনার ব্রাউজারকে একটি এইচটিটিপি বার্তা তৈরি করতে এবং সমস্ত বিষয়বস্তুকে বার্তাটির শিরোনামে রাখতে বলে (জিনিসগুলি করার একটি খুব কার্যকর উপায়, আরও সুরক্ষিত এবং নমনীয়ও)।GET
ক্যোরিস্ট্রিংয়ে ফর্ম ডেটা জমা দেবে । এটিতে ডেটা উপস্থাপন এবং দৈর্ঘ্য সম্পর্কে কিছু প্রতিবন্ধকতা রয়েছে।মেথড enctype
ব্যবহার POST
করার সময় অ্যাট্রিবিউটের জ্ঞান থাকে । নির্দিষ্ট করা থাকলে, এটি ব্রাউজারটিকে নির্দিষ্ট উপায়ে এনটাক্ট করে ফর্মটি প্রেরণ করতে নির্দেশ দেয়। এমডিএন থেকে - ফর্ম এনটাইপ :
যখন পদ্ধতির বৈশিষ্ট্যের মান পোস্ট হয়, এনক্টাইপ হ'ল মাইম টাইম সামগ্রী যা সার্ভারে ফর্মটি জমা দেওয়ার জন্য ব্যবহৃত হয়।
application/x-www-form-urlencoded
: এটি ডিফল্ট। ফর্মটি প্রেরণ করা হলে, সমস্ত নাম এবং মান সংগ্রহ করা হয় এবং ইউআরএল এনকোডিং চূড়ান্ত স্ট্রিংয়ে সঞ্চালিত হয়।multipart/form-data
: অক্ষরগুলি এনকোড করা হয়নি। যখন ফর্মটিতে একটি ফাইল আপলোড নিয়ন্ত্রণ থাকে তখন এটি গুরুত্বপূর্ণ। আপনি ফাইলটি বাইনারি প্রেরণ করতে চান এবং এটি নিশ্চিত করে যে বিটস্ট্রিম পরিবর্তন করা হয়নি।text/plain
: স্পেসগুলি রূপান্তরিত হয়, তবে আর কোনও এনকোডিং করা হয় না।ফর্মগুলি জমা দেওয়ার সময়, কিছু সুরক্ষা উদ্বেগ আরএফসি 7578 বিভাগ 7 অনুযায়ী বর্ণিত হতে পারে : মাল্টিপার্ট ফর্ম ডেটা - সুরক্ষা বিবেচনা :
সমস্ত ফর্ম-প্রসেসিং সফ্টওয়্যার ব্যবহারকারীর সরবরাহ করা ফর্ম-ডেটা
সংবেদনশীলতার সাথে আচরণ করে , কারণ এতে প্রায়শই গোপনীয় বা ব্যক্তিগতভাবে
সনাক্তকরণের তথ্য থাকে। ওয়েব ব্রাউজারগুলিতে ফর্ম "অটো-ফিল" বৈশিষ্ট্যগুলির ব্যাপক ব্যবহার রয়েছে; এগুলি ব্যবহারকারীর
অজান্তে গোপনীয় তথ্য প্রেরণ করার জন্য ব্যবহার করা হতে পারে অন্যথায়
অসম্পূর্ণ কাজগুলি সম্পন্ন করার সময় । একাধিক / ফর্ম-ডেটা
সততা যাচাই, গোপনীয়তা নিশ্চিতকরণ, ব্যবহারকারীর
বিভ্রান্তি বা অন্যান্য সুরক্ষা বৈশিষ্ট্যগুলি এড়ানোর জন্য কোনও বৈশিষ্ট্য সরবরাহ করে না ; এই উদ্বেগগুলি অবশ্যই
ফর্ম পূরণ এবং ফর্ম-ডেটা-ব্যাখ্যামূলক অ্যাপ্লিকেশন দ্বারা সমাধান করা উচিত।যে অ্যাপ্লিকেশনগুলি ফর্মগুলি গ্রহণ করে এবং সেগুলি প্রক্রিয়া করে তাদের অবশ্যই অনুরোধ করা ফর্ম-প্রসেসিং সাইটে ডেটা সরবরাহ না করার জন্য অবশ্যই সতর্ক থাকতে হবে যা প্রেরণের উদ্দেশ্যে নয়।
কনটেন্ট-
ডিসপজিশন শিরোনাম ক্ষেত্রের ফাইলের নাম ব্যাখ্যা করার সময় এটি গুরুত্বপূর্ণ, প্রযোজকের
ফাইল স্পেসে অজান্তে ফাইল ওভাররাইট না করা।
এটি আপনাকে উদ্বেগ দেয় যদি আপনি বিকাশকারী হন এবং আপনার সার্ভার ব্যবহারকারীদের দ্বারা জমা দেওয়া ফর্মগুলি প্রক্রিয়া করবে যা সংবেদনশীল তথ্য ধারণ করে।
enctype
। আমি জানি এটা থেকে আক্ষরিক এর multipart/form-data
জন্য RFC কিন্তু তা সত্ত্বেও এটা ফরম যে সম্পূর্ণরূপে তথ্য হিসাবে পাঠানো হয় কিনা লম্ব হয় জমা দেওয়ার সম্পর্কে নিরাপত্তা কারণগুলো একটি অবাধ ডাম্প এর application/x-www-form-urlencoded
বা multipart/form-data
।
POST এ পদ্ধতিটির বৈশিষ্ট্যটি সেট করুন কারণ ফর্মটি ব্যবহার করে কোনও ফাইলের URL প্যারামিটারের মধ্যে ফাইল সামগ্রী রাখা যায় না।
এনটাইটাইপের মানটি মাল্টিপার্ট / ফর্ম-ডেটাতে সেট করুন কারণ ডেটা একাধিক অংশে বিভক্ত হবে, প্রতিটি ফাইলের জন্য একটি এবং ফর্ম বডিটির পাঠ্য যা তাদের সাথে প্রেরণ করা যেতে পারে।
POST
কোনও ফর্মের মাধ্যমে ফাইল জমা দেওয়ার পক্ষে যথেষ্ট এবং সম্ভবত multipart/form-data
কিছু অস্পষ্ট উপায়ে যোগ করা বোনাস। বিষয়টি তেমন নয়। বেশিরভাগ ফাইলের একেবারে ব্যবহারের প্রয়োজন হবে multipart/form-data
।
<head>
এবং <body>
অপ্রাসঙ্গিক এবং বিভ্রান্তিকর।
সাধারণত এটি যখন আপনার কোনও পোষ্ট ফর্ম থাকে যা ডেটা হিসাবে কোনও ফাইল আপলোড নিতে হয় ... এটি সার্ভারকে জানায় যে এটি কীভাবে স্থানান্তরিত ডেটা এনকোড করবে, সেক্ষেত্রে এটি এনকোড হবে না কারণ এটি কেবল স্থানান্তর এবং আপলোড হবে সার্ভারে ফাইলগুলি, উদাহরণস্বরূপ কোনও চিত্র বা পিডিএফ আপলোড করার সময়
এনকটাইপ বৈশিষ্ট্যটি সার্ভারে জমা দেওয়ার সময় ফর্ম-ডেটা কীভাবে এনকোড করা উচিত তা নির্দিষ্ট করে।
এনটাইপ বৈশিষ্ট্যটি শুধুমাত্র পদ্ধতি = "পোস্ট" ব্যবহার করা যেতে পারে।
কোনও অক্ষর এনকোড করা হয়নি। আপনি যখন ফাইল আপলোড নিয়ন্ত্রণ করে এমন ফর্মগুলি ব্যবহার করছেন তখন এই মানটির প্রয়োজন হয়
ডাব্লু 3 স্কুল থেকে
multipart/form-data
। এটিও বেশ অস্পষ্ট; "কোনও অক্ষর এনকোড করা হয়নি" এই বাক্যটির অর্থ কী? -1।