JSP - Kode Status Http
Pada bab ini, kita akan membahas Kode Status Http di JSP. Format permintaan HTTP dan pesan tanggapan HTTP serupa dan akan memiliki struktur berikut -
Baris status awal + CRLF (Carriage Return + Line Feed, yaitu Jalur Baru)
Nol atau lebih baris header + CRLF
Sebuah baris kosong yaitu. sebuah CRLF
Badan pesan opsional seperti file, data kueri, atau keluaran kueri.
Misalnya, header respons server terlihat seperti berikut -
HTTP/1.1 200 OK
Content-Type: text/html
Header2: ...
...
HeaderN: ...
(Blank Line)
<!doctype ...>
<html>
<head>...</head>
<body>
...
</body>
</html>
Baris status terdiri dari HTTP version (HTTP/1.1 in the example), kode status (200 dalam contoh), dan pesan yang sangat singkat terkait dengan kode status (OK in the example).
Tabel berikut mencantumkan kode status HTTP dan pesan terkait yang mungkin dikembalikan dari Server Web -
Kode | Pesan | Deskripsi |
---|---|---|
100 | Terus | Hanya sebagian dari permintaan telah diterima oleh server, tetapi selama itu belum ditolak, klien harus melanjutkan permintaan |
101 | Switching Protocols | Server beralih protokol. |
200 | baik | Permintaannya oke |
201 | Dibuat | Permintaan selesai, dan sumber daya baru dibuat |
202 | Diterima | Permintaan diterima untuk diproses, tetapi pemrosesan tidak selesai. |
203 | Informasi Non-otoritatif | |
204 | Tidak ada isi | |
205 | Setel Ulang Konten | |
206 | Konten Parsial | |
300 | Pilihan ganda | Daftar tautan; pengguna dapat memilih link dan pergi ke lokasi tersebut. Maksimal lima alamat. |
301 | Pindah Secara Permanen | Halaman yang diminta telah dipindahkan ke url baru. |
302 | Ditemukan | Halaman yang diminta telah dipindahkan sementara ke url baru. |
303 | Lihat Lainnya | Halaman yang diminta dapat ditemukan di bawah url yang berbeda. |
304 | Tidak dimodifikasi | |
305 | Gunakan proxy | |
306 | Tidak terpakai | Kode ini digunakan di versi sebelumnya. Ini tidak lagi digunakan, tetapi kodenya sudah dipesan. |
307 | Pengalihan Sementara | Halaman yang diminta telah dipindahkan sementara ke url baru. |
400 | Permintaan yang buruk | Server tidak memahami permintaan tersebut. |
401 | Tidak resmi | Halaman yang diminta membutuhkan nama pengguna dan kata sandi. |
402 | Pembayaran Diperlukan | Anda belum dapat menggunakan kode ini. |
403 | Terlarang | Akses dilarang ke halaman yang diminta |
404 | Tidak ditemukan | Server tidak dapat menemukan halaman yang diminta. |
405 | Metode Tidak Diizinkan | Metode yang ditentukan dalam permintaan tidak diperbolehkan. |
406 | Tidak dapat diterima | Server hanya dapat menghasilkan respon yang tidak diterima oleh klien. |
407 | Diperlukan Otentikasi Proksi | Anda harus mengautentikasi dengan server proxy sebelum permintaan ini dapat dilayani. |
408 | Request Timeout | Permintaan membutuhkan waktu lebih lama daripada yang disiapkan server untuk menunggu. |
409 | Konflik | Permintaan tidak dapat diselesaikan karena ada konflik. |
410 | Hilang | Halaman yang diminta tidak lagi tersedia. |
411 | Panjang Diperlukan | "Panjang-Konten" tidak ditentukan. Server tidak akan menerima permintaan tanpa itu. |
412 | Prekondisi Gagal | Prasyarat yang diberikan dalam permintaan dievaluasi sebagai salah oleh server. |
413 | Entitas Permintaan Terlalu Besar | Server tidak akan menerima permintaan, karena entitas permintaan terlalu besar. |
414 | Request-url Terlalu Panjang | Server tidak akan menerima permintaan, karena urlnya terlalu panjang. Ini terjadi ketika Anda mengubah permintaan "posting" menjadi permintaan "dapatkan" dengan informasi kueri yang panjang. |
415 | Jenis Media Tidak Didukung | Server tidak akan menerima permintaan, karena jenis media tidak didukung. |
417 | Harapan Gagal | |
500 | Kesalahan server dari dalam | Permintaan itu belum selesai. Server menemui kondisi yang tidak terduga. |
501 | Tidak Diterapkan | Permintaan itu belum selesai. Server tidak mendukung fungsionalitas yang diperlukan. |
502 | Gateway Buruk | Permintaan itu belum selesai. Server menerima tanggapan yang tidak valid dari server hulu. |
503 | Layanan tidak tersedia | Permintaan itu belum selesai. Server kelebihan beban atau down untuk sementara. |
504 | Gateway Timeout | Gerbang telah habis waktunya. |
505 | Versi HTTP Tidak Didukung | Server tidak mendukung "http protocol" Versi: kapan. |
Metode untuk Mengatur Kode Status HTTP
Metode berikut dapat digunakan untuk mengatur Kode Status HTTP dalam program servlet Anda. Metode ini tersedia dengan objek HttpServletResponse .
S.No. | Metode & Deskripsi |
---|---|
1 | public void setStatus ( int statusCode ) Metode ini menetapkan kode status arbitrer. Metode setStatus menggunakan int (kode status) sebagai argumen. Jika tanggapan Anda menyertakan kode status khusus dan dokumen, pastikan untuk meneleponsetStatussebelum benar-benar mengembalikan konten apa pun dengan PrintWriter . |
2 | public void sendRedirect(String url) Metode ini menghasilkan respons 302 bersama dengan header Lokasi yang memberikan URL dokumen baru. |
3 | public void sendError(int code, String message) Metode ini mengirimkan kode status (biasanya 404) bersama dengan pesan singkat yang secara otomatis diformat di dalam dokumen HTML dan dikirim ke klien. |
Contoh Kode Status HTTP
Contoh berikut menunjukkan bagaimana kode kesalahan 407 dikirim ke browser klien. Setelah ini, browser akan menampilkan "Need authentication!!!"pesan.
<html>
<head>
<title>Setting HTTP Status Code</title>
</head>
<body>
<%
// Set error code and reason.
response.sendError(407, "Need authentication!!!" );
%>
</body>
</html>
Anda akan menerima output berikut -
HTTP Status 407 - Need authentication!!!
type Status report
message Need authentication!!!
description The client must first authenticate itself with the proxy (Need authentication!!!).
Apache Tomcat/5.5.29
Agar lebih nyaman dengan kode status HTTP, cobalah untuk mengatur kode status yang berbeda dan deskripsinya.