JSP - Pemrosesan Formulir
Pada bab ini, kita akan membahas Pemrosesan Formulir di JSP. Anda pasti pernah menjumpai banyak situasi ketika Anda perlu meneruskan beberapa informasi dari browser Anda ke server web dan akhirnya ke program backend Anda. Browser menggunakan dua metode untuk meneruskan informasi ini ke server web. Metode-metode ini adalah Metode GET dan Metode POST.
Metode dalam Pengolahan Formulir
Sekarang mari kita bahas metode dalam Pemrosesan Formulir.
GET metode
Metode GET mengirimkan informasi pengguna yang dikodekan yang ditambahkan ke permintaan halaman. Halaman dan informasi yang dikodekan dipisahkan oleh? karakter sebagai berikut -
http://www.test.com/hello?key1=value1&key2=value2
Metode GET adalah metode default untuk meneruskan informasi dari browser ke server web dan menghasilkan string panjang yang muncul di browser Anda. Location:box. Direkomendasikan bahwa metode GET lebih baik tidak digunakan. jika Anda memiliki kata sandi atau informasi sensitif lainnya untuk diteruskan ke server.
Metode GET memiliki batasan ukuran: only 1024 characters can be in a request string.
Informasi ini diteruskan menggunakan QUERY_STRING header dan akan dapat diakses melalui variabel lingkungan QUERY_STRING yang dapat ditangani menggunakan getQueryString() dan getParameter() metode objek permintaan.
Metode POST
Metode yang umumnya lebih andal untuk meneruskan informasi ke program backend adalah metode POST.
Metode ini mengemas informasi dengan cara yang persis sama seperti metode GET, tetapi alih-alih mengirimkannya sebagai string teks setelah? di URL itu mengirimkannya sebagai pesan terpisah. Pesan ini masuk ke program backend dalam bentuk input standar yang dapat Anda parse dan gunakan untuk pemrosesan Anda.
JSP menangani jenis permintaan ini menggunakan getParameter() metode untuk membaca parameter sederhana dan getInputStream() metode untuk membaca aliran data biner yang berasal dari klien.
Membaca Data Formulir menggunakan JSP
JSP menangani penguraian data formulir secara otomatis menggunakan metode berikut tergantung pada situasinya -
getParameter() - Anda menelepon request.getParameter() metode untuk mendapatkan nilai parameter formulir.
getParameterValues() - Panggil metode ini jika parameter muncul lebih dari sekali dan mengembalikan beberapa nilai, misalnya kotak centang.
getParameterNames() - Panggil metode ini jika Anda ingin daftar lengkap semua parameter dalam permintaan saat ini.
getInputStream() - Panggil metode ini untuk membaca aliran data biner yang berasal dari klien.
GET Contoh Metode Menggunakan URL
URL berikut akan mengirimkan dua nilai ke program HelloForm menggunakan metode GET.
http://localhost:8080/main.jsp?first_name=ZARA&last_name=ALI
Di bawah ini adalah main.jspProgram JSP untuk menangani input yang diberikan oleh web browser. Kami akan menggunakangetParameter() metode yang membuatnya sangat mudah untuk mengakses informasi yang diteruskan -
<html>
<head>
<title>Using GET Method to Read Form Data</title>
</head>
<body>
<h1>Using GET Method to Read Form Data</h1>
<ul>
<li><p><b>First Name:</b>
<%= request.getParameter("first_name")%>
</p></li>
<li><p><b>Last Name:</b>
<%= request.getParameter("last_name")%>
</p></li>
</ul>
</body>
</html>
Sekarang ketik http://localhost:8080/main.jsp?first_name=ZARA&last_name=ALI di browser Anda Location:box. Ini akan menghasilkan hasil sebagai berikut -
Menggunakan Metode GET untuk Membaca Data Formulir
|
GET Contoh Metode Menggunakan Formulir
Berikut adalah contoh yang meneruskan dua nilai menggunakan HTML FORM dan tombol kirim. Kami akan menggunakan main.jsp JSP yang sama untuk menangani input ini.
<html>
<body>
<form action = "main.jsp" method = "GET">
First Name: <input type = "text" name = "first_name">
<br />
Last Name: <input type = "text" name = "last_name" />
<input type = "submit" value = "Submit" />
</form>
</body>
</html>
Simpan HTML ini di file Hello.htm dan masukkan <Tomcat-installation-directory>/webapps/ROOT directory. Kapan Anda akan mengakseshttp://localhost:8080/Hello.htm, Anda akan menerima keluaran berikut.
<p> Cobalah untuk memasukkan Nama Depan dan Nama Belakang dan kemudian klik tombol kirim untuk melihat hasil di mesin lokal Anda di mana tomcat sedang berjalan. Berdasarkan masukan yang diberikan, akan menghasilkan hasil yang serupa seperti yang disebutkan pada contoh di atas.Contoh Metode POST Menggunakan Formulir
Mari kita lakukan sedikit modifikasi pada JSP di atas untuk menangani metode GET dan POST. Di bawah ini adalahmain.jsp Program JSP untuk menangani input yang diberikan oleh web browser menggunakan metode GET atau POST.
Sebenarnya tidak ada perubahan dalam JSP di atas karena satu-satunya cara untuk melewatkan parameter diubah dan tidak ada data biner yang diteruskan ke program JSP. Konsep terkait penanganan file akan dijelaskan dalam bab terpisah di mana kita perlu membaca aliran data biner.
<html>
<head>
<title>Using GET and POST Method to Read Form Data</title>
</head>
<body>
<center>
<h1>Using POST Method to Read Form Data</h1>
<ul>
<li><p><b>First Name:</b>
<%= request.getParameter("first_name")%>
</p></li>
<li><p><b>Last Name:</b>
<%= request.getParameter("last_name")%>
</p></li>
</ul>
</body>
</html>
Berikut ini adalah konten dari Hello.htm file -
<html>
<body>
<form action = "main.jsp" method = "POST">
First Name: <input type = "text" name = "first_name">
<br />
Last Name: <input type = "text" name = "last_name" />
<input type = "submit" value = "Submit" />
</form>
</body>
</html>
Mari kita simpan sekarang main.jsp dan hello.htm masuk <Tomcat-installationdirectory>/webapps/ROOT directory. Saat Anda mengakseshttp://localhost:8080/Hello.htm, Anda akan menerima keluaran berikut.
Cobalah untuk memasukkan Nama Depan dan Nama Belakang dan kemudian klik tombol kirim untuk melihat hasilnya di mesin lokal Anda tempat tomcat berjalan.
Berdasarkan masukan yang diberikan, Anda akan menerima hasil yang serupa seperti pada contoh di atas.
Meneruskan Data Kotak Centang ke Program JSP
Kotak centang digunakan ketika lebih dari satu opsi diperlukan untuk dipilih.
Berikut ini contohnya HTML code, CheckBox.htm, untuk formulir dengan dua kotak centang.
<html>
<body>
<form action = "main.jsp" method = "POST" target = "_blank">
<input type = "checkbox" name = "maths" checked = "checked" /> Maths
<input type = "checkbox" name = "physics" /> Physics
<input type = "checkbox" name = "chemistry" checked = "checked" /> Chemistry
<input type = "submit" value = "Select Subject" />
</form>
</body>
</html>
Kode di atas akan menghasilkan hasil sebagai berikut -
Berikut adalah program JSP main.jsp untuk menangani masukan yang diberikan oleh web browser untuk tombol kotak centang.
<html>
<head>
<title>Reading Checkbox Data</title>
</head>
<body>
<h1>Reading Checkbox Data</h1>
<ul>
<li><p><b>Maths Flag:</b>
<%= request.getParameter("maths")%>
</p></li>
<li><p><b>Physics Flag:</b>
<%= request.getParameter("physics")%>
</p></li>
<li><p><b>Chemistry Flag:</b>
<%= request.getParameter("chemistry")%>
</p></li>
</ul>
</body>
</html>
Program di atas akan menghasilkan hasil sebagai berikut -
Reading Checkbox Data
Maths Flag :: on
Physics Flag:: null
Chemistry Flag:: on
Membaca Semua Parameter Formulir
Berikut ini adalah contoh umum yang menggunakan getParameterNames()metode HttpServletRequest untuk membaca semua parameter formulir yang tersedia. Metode ini mengembalikan Enumerasi yang berisi nama parameter dalam urutan yang tidak ditentukan.
Setelah kita memiliki Pencacahan, kita dapat mengulang Pencacahan dengan cara standar, menggunakan hasMoreElements() metode untuk menentukan kapan harus berhenti dan menggunakan nextElement() metode untuk mendapatkan setiap nama parameter.
<%@ page import = "java.io.*,java.util.*" %>
<html>
<head>
<title>HTTP Header Request Example</title>
</head>
<body>
<center>
<h2>HTTP Header Request Example</h2>
<table width = "100%" border = "1" align = "center">
<tr bgcolor = "#949494">
<th>Param Name</th>
<th>Param Value(s)</th>
</tr>
<%
Enumeration paramNames = request.getParameterNames();
while(paramNames.hasMoreElements()) {
String paramName = (String)paramNames.nextElement();
out.print("<tr><td>" + paramName + "</td>\n");
String paramValue = request.getHeader(paramName);
out.println("<td> " + paramValue + "</td></tr>\n");
}
%>
</table>
</center>
</body>
</html>
Berikut ini adalah konten dari Hello.htm -
<html>
<body>
<form action = "main.jsp" method = "POST" target = "_blank">
<input type = "checkbox" name = "maths" checked = "checked" /> Maths
<input type = "checkbox" name = "physics" /> Physics
<input type = "checkbox" name = "chemistry" checked = "checked" /> Chem
<input type = "submit" value = "Select Subject" />
</form>
</body>
</html>
Sekarang coba panggil JSP menggunakan Hello.htm di atas; ini akan menghasilkan hasil seperti di bawah ini berdasarkan masukan yang diberikan -
Membaca Semua Parameter Formulir
Nama Param | Nilai Param |
---|---|
matematika | di |
kimia | di |
Anda dapat mencoba JSP di atas untuk membaca data formulir lain yang memiliki objek lain seperti kotak teks, tombol radio atau dropdown, dll.