উত্তর:
অনুরোধডিসপাচার - ফরোয়ার্ড () পদ্ধতি
আমরা যখন
forward
পদ্ধতিটি ব্যবহার করি , অনুরোধটি আরও প্রক্রিয়াকরণের জন্য একই সার্ভারের মধ্যে অন্য উত্সে স্থানান্তরিত হয়।এর ক্ষেত্রে
forward
, ওয়েব ধারক অভ্যন্তরীণভাবে সমস্ত প্রক্রিয়াজাতকরণ পরিচালনা করে এবং ক্লায়েন্ট বা ব্রাউজার জড়িত নয়।যখন বস্তুটিতে
forward
ডাকা হয়requestDispatcher
, আমরা অনুরোধ এবং প্রতিক্রিয়া অবজেক্টগুলি পাস করি, সুতরাং আমাদের পুরানো অনুরোধ অবজেক্টটি নতুন সংস্থানটিতে উপস্থিত রয়েছে যা আমাদের অনুরোধটি প্রক্রিয়া করতে চলেছে।দৃশ্যত, আমরা ফরোয়ার্ড করা ঠিকানা দেখতে পারছি না, এটি স্বচ্ছ।
forward()
পদ্ধতিটি ব্যবহার করার চেয়ে দ্রুতsendRedirect
।আমরা যখন ফরোয়ার্ড ব্যবহার করে পুনর্নির্দেশ করি এবং আমরা একই তথ্যটি নতুন সংস্থানে ব্যবহার করতে চাই, তখন
request.setAttribute()
আমাদের কাছে অনুরোধের অবজেক্ট উপলব্ধ থাকায় আমরা ব্যবহার করতে পারি।SendRedirect
ক্ষেত্রে
sendRedirect
, অনুরোধটি অন্য উত্সে, অন্য কোনও ডোমেনে, বা আরও প্রক্রিয়াজাতকরণের জন্য একটি ভিন্ন সার্ভারে স্থানান্তরিত হয়।আপনি যখন ব্যবহার
sendRedirect
করবেন তখন ধারকটি ক্লায়েন্ট বা ব্রাউজারে অনুরোধটি স্থানান্তর করে, সুতরাংsendRedirect
পদ্ধতির অভ্যন্তরে প্রদত্ত URL টি ক্লায়েন্টের কাছে একটি নতুন অনুরোধ হিসাবে দৃশ্যমান।
sendRedirect
কল করার ক্ষেত্রে , পুরানো অনুরোধ এবং প্রতিক্রিয়া অবজেক্টগুলি হারিয়ে যায় কারণ এটি ব্রাউজারের দ্বারা নতুন অনুরোধ হিসাবে বিবেচিত হয়।ঠিকানা বারে, আমরা নতুন পুনঃনির্দেশিত ঠিকানা দেখতে সক্ষম হয়েছি। এটা স্বচ্ছ নয়।
sendRedirect
ধীর কারণ একটি অতিরিক্ত রাউন্ড ট্রিপ প্রয়োজন, কারণ সম্পূর্ণ নতুন অনুরোধ তৈরি হয় এবং পুরানো অনুরোধের বস্তুটি হারিয়ে যায়। দুটি ব্রাউজার অনুরোধ প্রয়োজন।তবে ইন
sendRedirect
, যদি আমরা কোনও নতুন সংস্থার জন্য একই ডেটা ব্যবহার করতে চাই তবে আমাদের ডেটাটি সেশনে সঞ্চয় করতে হবে বা URL সহ পাস করতে হবে।কোনটি ভাল?
এটি দৃশ্যপটের উপর নির্ভর করে যার জন্য পদ্ধতিটি আরও কার্যকর।
আপনি যদি নিয়ন্ত্রণটি নতুন সার্ভার বা প্রসঙ্গে স্থানান্তর করতে চান এবং এটি সম্পূর্ণ নতুন কাজ হিসাবে বিবেচিত হয়, তবে আমরা এর জন্য যাব
sendRedirect
। সাধারণত, ওয়েব পৃষ্ঠার ব্রাউজার পুনরায় লোড করার সময় অপারেশনটি নিরাপদে পুনরাবৃত্তি করা যেতে পারে এবং ফলাফলকে প্রভাবিত করবে না এমন একটি ফরোয়ার্ড ব্যবহার করা উচিত।
ওয়েব ডেভলপমেন্ট ওয়ার্ল্ডে, "পুনর্নির্দেশ" শব্দটি ক্লায়েন্টকে একটি Location
নতুন ইউআরএল সম্বলিত একটি শিরোনাম দিয়ে খালি এইচটিটিপি প্রতিক্রিয়া পাঠানোর কাজ যা ক্লায়েন্টকে ব্র্যান্ডের নতুন জিইটি অনুরোধ প্রেরণ করতে হবে। সুতরাং মূলত:
some.jsp
।Location: other.jsp
শিরোনাম সহ একটি HTTP প্রতিক্রিয়া প্রেরণ করেother.jsp
(এটি ব্রাউজারের অ্যাড্রেস বারে প্রতিফলিত হয়!)other.jsp
।আপনি ওয়েব ব্রাউজারের বিল্টিন / অ্যাডন বিকাশকারী সরঞ্জামসেট দিয়ে এটি ট্র্যাক করতে পারেন। Chrome / IE9 / ফায়ারব্যাগে F12 টিপুন এবং এটি দেখতে "নেটওয়ার্ক" বিভাগটি দেখুন।
ঠিক উপরের দ্বারা অর্জন করা হয় sendRedirect("other.jsp")
। RequestDispatcher#forward()
একটি পুনঃচালনা পাঠায় না। পরিবর্তে, এটি লক্ষ্য পৃষ্ঠার সামগ্রীটি HTTP প্রতিক্রিয়া হিসাবে ব্যবহার করে।
some.jsp
।other.jsp
।যাইহোক, মূল HTTP অনুরোধটি ছিল some.jsp
, ব্রাউজারের ঠিকানা বারের URL টি অপরিবর্তিত রয়েছে। এছাড়াও, পিছনে নিয়ামকটিতে নির্ধারিত কোনও অনুরোধের বৈশিষ্ট্যগুলি some.jsp
উপলব্ধ থাকবে other.jsp
। এটি কোনও পুনর্নির্দেশের সময় ঘটে না কারণ আপনি ক্লায়েন্টকে মূলত একটি নতুন এইচটিটিপি অনুরোধ তৈরি করতে বাধ্য করছেন other.jsp
, এর মাধ্যমে মূল some.jsp
বৈশিষ্ট্যটির সমস্ত বৈশিষ্ট্যগুলি অন্তর্ভুক্ত করে ফেলে দিন।
RequestDispatcher
MVC দৃষ্টান্ত মধ্যে অত্যন্ত দরকারী এবং / অথবা আপনি JSP এর আড়াল থেকে সরাসরি প্রবেশাধিকার কাছ থেকে কি চান না। আপনি জেএসপি'র /WEB-INF
ফোল্ডারে রাখতে পারেন Servlet
এবং অনুরোধগুলি নিয়ন্ত্রণ, প্রাক প্রসেস এবং পোস্টপ্রসেসগুলি ব্যবহার করতে পারেন । /WEB-INF
ফোল্ডারে থাকা জেএসপিগুলি ইউআরএল দ্বারা সরাসরি অ্যাক্সেসযোগ্য নয় তবে Servlet
ব্যবহার করে এগুলি অ্যাক্সেস করতে পারে RequestDispatcher#forward()
।
আপনি উদাহরণস্বরূপ মধ্যে একটা JSP ফাইল থাকতে পারে /WEB-INF/login.jsp
এবং LoginServlet
যা একটি অন ম্যাপ করা হয় url-pattern
এর /login
। আপনি যখন অনুরোধ করবেন http://example.com/context/login
, তারপরে সার্লেটের অনুরোধ করা doGet()
হবে। আপনি সেখানে যে কোনও প্রাক প্রসেসিং স্টাফ করতে পারেন এবং শেষ পর্যন্ত অনুরোধটি ফরোয়ার্ড করতে পারেন:
request.getRequestDispatcher("/WEB-INF/login.jsp").forward(request, response);
আপনি যখন একটি ফর্ম জমা দিন, আপনি সাধারণত ব্যবহার করতে চান POST
:
<form action="login" method="post">
এইভাবে সার্লেটের অনুরোধ করা doPost()
হবে এবং আপনি সেখানে যে কোনও পোস্ট প্রসেসিং স্টাফ করতে পারেন (যেমন বৈধতা, ব্যবসায়িক যুক্তি, ব্যবহারকারীকে লগইন করুন ইত্যাদি)।
যদি কোনও ত্রুটি থাকে তবে আপনি সাধারণত অনুরোধটি একই পৃষ্ঠায় ফরোয়ার্ড করতে চান এবং ত্রুটিগুলি ইনপুট ক্ষেত্রগুলির পাশে প্রদর্শন করতে চান ইত্যাদি। আপনি এটির RequestDispatcher
জন্য ব্যবহার করতে পারেন ।
যদি কোনও POST
সফল হয়, আপনি সাধারণত অনুরোধটি পুনর্নির্দেশ করতে চান , যাতে ব্যবহারকারী যখন অনুরোধটি রিফ্রেশ করে (যেমন F5 টিপে বা ইতিহাসে ফিরে নেভিগেশন করা হয়) তখন অনুরোধটি পুনরায় জমা দেওয়া হবে না।
User user = userDAO.find(username, password);
if (user != null) {
request.getSession().setAttribute("user", user); // Login user.
response.sendRedirect("home"); // Redirects to http://example.com/context/home after succesful login.
} else {
request.setAttribute("error", "Unknown login, please try again."); // Set error.
request.getRequestDispatcher("/WEB-INF/login.jsp").forward(request, response); // Forward to same page so that you can display error.
}
একটি পুনর্নির্দেশ এইভাবে একটি নতুন ফায়ার ক্লায়েন্ট নির্দেশ GET
দেওয়া URL এ অনুরোধ। অনুরোধটি রিফ্রেশ করলে কেবল পুনঃনির্দেশিত অনুরোধটি রিফ্রেশ হবে কেবল প্রাথমিক অনুরোধ নয়। এটি "ডাবল জমা দেওয়া" এবং বিভ্রান্তি এবং খারাপ ব্যবহারকারীর অভিজ্ঞতা এড়াতে পারবে। একে POST-Redirect-GET
প্যাটার্নও বলা হয় ।
RequestDispatcher
ইন্টারফেস আপনাকে একটি সার্ভার সাইড এগিয়ে করার অনুমতি দিয়েছে / যেহেতু অন্তর্ভুক্ত sendRedirect()
একটি ক্লায়েন্ট সাইড পুনর্নির্দেশ আছে। কোনও ক্লায়েন্টের দিকনির্দেশে সার্ভারটি একটি HTTP স্থিতি কোডটি 302
(অস্থায়ী পুনঃনির্দেশ) ফেরত পাঠাবে যার ফলে ওয়েব ব্রাউজারটি GET
পুনঃনির্দেশিত স্থানে সামগ্রীর জন্য একটি নতুন HTTP অনুরোধ জারি করে । বিপরীতে, RequestDispatcher
ইন্টারফেসটি ব্যবহার করার সময়, নতুন সংস্থানটিতে অন্তর্ভুক্ত / ফরোয়ার্ডগুলি পুরোপুরি সার্ভারের দিকে পরিচালিত হয়।
forward
, পুনর্নির্দেশ নয়।
ফরোয়ার্ড () এবং সেন্ডরেডাইরেক্ট () পদ্ধতির মধ্যে প্রধান গুরুত্বপূর্ণ পার্থক্যটি হ'ল ফরোয়ার্ডের ক্ষেত্রে (), সার্ভারের শেষে পুনর্নির্দেশ ঘটে এবং ক্লায়েন্টের কাছে দৃশ্যমান হয় না, তবে সেন্ডরাইডারেক্ট () এর ক্ষেত্রে ক্লায়েন্টের শেষে পুনর্নির্দেশ ঘটে এবং এটি দৃশ্যমান ক্লায়েন্ট।
আপনি যা করতে চান তার উপর নির্ভর করে এই পদ্ধতির যে কোনও একটি হতে পারে "আরও ভাল", অর্থাত্ আরও উপযুক্ত।
ব্রাউজারে কোনও গোল ভ্রমণ না করেই কোনও ভিন্ন পৃষ্ঠা থেকে ডেটা পাওয়ার সাথে সাথে একটি সার্ভার-সাইড পুনর্নির্দেশ দ্রুততর হয় ar তবে ব্রাউজারে দেখা URL টি এখনও মূল ঠিকানা, তাই আপনি সেখানে কিছুটা অসঙ্গতি তৈরি করছেন।
কোনও ক্লায়েন্ট-সাইড পুনর্নির্দেশ হ'ল আরও বহুমুখী ইনসোফার কারণ এটি আপনাকে সম্পূর্ণ আলাদা সার্ভারে প্রেরণ করতে পারে বা প্রোটোকল পরিবর্তন করতে পারে (যেমন HTTP থেকে HTTPS এ), বা উভয়ই। এবং ব্রাউজারটি নতুন ইউআরএল সম্পর্কে সচেতন। তবে এটি সার্ভার এবং ক্লায়েন্টের মধ্যে একটি অতিরিক্ত পিছনে।
SendRedirect()
সার্ভারগুলির মধ্যে সামগ্রীটি অনুসন্ধান করবে। এটি ধীর কারণ এটি সামগ্রীর URL টি প্রেরণ করে ব্রাউজারকে অন্তরঙ্গ করতে হয়। তারপরে ব্রাউজার একই সার্ভারের মধ্যে বা অন্য একটিতে সামগ্রীর জন্য একটি নতুন অনুরোধ তৈরি করবে।
RquestDispatcher
আমি মনে করি যে সার্ভারের মধ্যে থাকা সামগ্রীটি অনুসন্ধান করার জন্য। এটি সার্ভার সাইড প্রক্রিয়া এবং এটি দ্রুত SendRedirect()
পদ্ধতির সাথে তুলনা করে । তবে বিষয়টি হ'ল এটি ব্রাউজারকে অন্তর্নিহিত করবে না যে সার্ভারে এটি প্রয়োজনীয় তারিখ বা বিষয়বস্তু অনুসন্ধান করছে, না ব্রাউজারকে ইউআরএল ট্যাবে URL টি পরিবর্তন করতে বলবে না। সুতরাং এটি ব্যবহারকারীর সামান্য অসুবিধার কারণ হয়।
আমাদের যদি অন্য ডোমেনে নিয়ন্ত্রণ স্থানান্তর করতে হয় বা টাস্কের বিচ্ছেদ অর্জন করতে হয় তবে প্রযুক্তিগতভাবে পুনঃনির্দেশ ব্যবহার করা উচিত।
উদাহরণস্বরূপ অর্থ প্রদানের অ্যাপ্লিকেশনটিতে আমরা প্রথমে পেমেন্টপ্রসেস করি এবং তারপরে ডিসপ্লেপেইমেন্টআইএনফোতে পুনঃনির্দেশ করি। যদি ক্লায়েন্ট ব্রাউজারটি রিফ্রেশ করে তবে কেবল ডিসপ্লে পেমেন্টইনফো হয়ে যাবে এবং পেমেন্টপ্রসেসের পুনরাবৃত্তি হবে না। তবে আমরা যদি এই দৃশ্যে এগিয়ে ব্যবহার করি, পেমেন্টপ্রসেস এবং ডিসপ্লে পেমেন্টআইএনফো উভয়ই ধারাবাহিকভাবে পুনরায় সম্পাদন করা হবে যার ফলস্বরূপ অসংলগ্ন ডেটা হতে পারে।
অন্যান্য দৃশ্যের জন্য, ফরোয়ার্ডটি ব্যবহারে দক্ষ কারণ এটি প্রেরণ-নির্দেশিকার চেয়ে দ্রুত
অনুরোধ প্রেরণকারী একটি ইন্টারফেস যা ওয়েব উত্স থেকে অন্য ওয়েব উত্স থেকে অনুরোধ বা প্রতিক্রিয়া প্রেরণের জন্য ব্যবহৃত হয়। এটিতে মূলত দুটি পদ্ধতি রয়েছে।
request.forward(req,res)
: এই পদ্ধতিটি একটি ওয়েব উত্স থেকে অন্য উত্সে অনুরোধটি ফরোয়ার্ড করা হয়। যেমন একটি সার্লেট থেকে অন্য সার্লেট বা একটি ওয়েব অ্যাপ্লিকেশন থেকে অন্য ওয়েব অ্যাপ্লিকেশন।
response.include(req,res)
: এই পদ্ধতিটি ব্যবহৃত হয় অন্য সার্লেলে একটি সার্লেটের প্রতিক্রিয়া অন্তর্ভুক্ত
দ্রষ্টব্য: অনুরোধ প্রেরণকারী ব্যবহার করে আমরা অনুরোধ বা প্রতিক্রিয়াগুলি একই সার্ভারে ফরোয়ার্ড করতে বা অন্তর্ভুক্ত করতে পারি।
request.sendRedirect()
: এটি ব্যবহার করে আমরা বিভিন্ন সার্ভার জুড়ে অনুরোধ বা প্রতিক্রিয়াগুলি ফরোয়ার্ড করতে বা অন্তর্ভুক্ত করতে পারি। এতে ক্লায়েন্ট পৃষ্ঠাটি পুনর্নির্দেশের সময় একটি তদন্ত করে তবে উপরের প্রক্রিয়াতে ক্লায়েন্টটি অন্তরঙ্গতা পাবেন না
কেবলমাত্র মধ্যে পার্থক্য Forward(ServletRequest request, ServletResponse response)
এবং sendRedirect(String url)
হয়
ফরোয়ার্ড ():
forward()
পদ্ধতি সার্ভার প্রান্তের মধ্যে মৃত্যুদন্ড কার্যকর করা হয়।forward ()
সার্ভলেট ধারক দ্বারা পদ্ধতিটি সরবরাহ করা হওয়ায় এটি ক্লায়েন্টের অনুরোধ প্রোটোকলের উপর নির্ভর করে না ।forward()
পদ্ধতি দ্রুত চেয়ে sendRedirect()
পদ্ধতি।RequestDispatcher
ইন্টারফেসে ঘোষণা করা হয় ।sendRedirect ():
response.sendRedirect("..")
ওয়েবসাইটের index.jsp পৃষ্ঠায় একটি করি । তবে এটি CSS ফাইল এবং jsp পৃষ্ঠা থেকে কিছু পাঠ্য মিস করে যা পৃষ্ঠার আংশিক লোডের দিকে নিয়ে যায়। তবে যখন আমি ওয়েবসাইটটির স্বাগত পৃষ্ঠাটি index.jsp হিসাবে তৈরি করি তখন সমস্ত কিছুই সূক্ষ্মভাবে কাজ করে এবং পৃষ্ঠাগুলি সম্পূর্ণ হয়। পুনর্নির্দেশে কি ভুল?