Servlet - Penjelasan
Sejauh ini, Anda telah mempelajari bagaimana Servlet menggunakan deskriptor penerapan (file web.xml) untuk menerapkan aplikasi Anda ke server web. Servlet API 3.0 telah memperkenalkan paket baru yang disebut javax.servlet.annotation. Ini menyediakan tipe anotasi yang dapat digunakan untuk membuat anotasi kelas servlet. Jika Anda menggunakan anotasi, deskriptor penerapan (web.xml) tidak diperlukan. Tetapi Anda harus menggunakan tomcat7 atau versi tomcat yang lebih baru.
Anotasi dapat menggantikan konfigurasi XML yang setara dalam file deskriptor penerapan web (web.xml) seperti deklarasi servlet dan pemetaan servlet. Kontainer servlet akan memproses kelas beranotasi pada waktu penerapan.
Jenis anotasi yang diperkenalkan di Servlet 3.0 adalah -
Sr.No. | Anotasi & Deskripsi |
---|---|
1 | @WebServlet Untuk mendeklarasikan servlet. |
2 | @WebInitParam Untuk menentukan parameter inisialisasi. |
3 | @WebFilter Untuk mendeklarasikan filter servlet. |
4 | @WebListener Untuk mendeklarasikan WebListener |
5 | @HandlesTypes Untuk mendeklarasikan tipe kelas yang dapat ditangani oleh ServletContainerInitializer. |
6 | @HttpConstraint Penjelasan ini digunakan dalam penjelasan ServletSecurity untuk mewakili batasan keamanan yang akan diterapkan ke semua metode protokol HTTP yang elemen HttpMethodConstraint yang sesuai TIDAK terjadi dalam penjelasan ServletSecurity. |
7 | @HttpMethodConstraint Anotasi ini digunakan dalam anotasi ServletSecurity untuk mewakili batasan keamanan pada pesan protokol HTTP tertentu. |
8 | @MultipartConfig Anotasi yang mungkin ditentukan pada kelas Servlet, yang menunjukkan bahwa contoh Servlet mengharapkan permintaan yang sesuai dengan tipe MIME multipart / form-data. |
9 | @ServletSecurity Anotasi ini digunakan pada kelas implementasi Servlet untuk menentukan batasan keamanan yang akan diberlakukan oleh wadah Servlet pada pesan protokol HTTP. |
Di sini kita telah membahas beberapa Anotasi secara mendetail.
@Web
@WebServlet digunakan untuk mendeklarasikan konfigurasi Servlet dengan wadah. Tabel berikut berisi daftar atribut yang digunakan untuk penjelasan WebServlet.
Sr.No. | Atribut & Deskripsi |
---|---|
1 | String name Nama Servlet |
2 | String[] value Array pola URL |
3 | String[] urlPatterns Susunan pola URL tempat Filter ini diterapkan |
4 | Int loadOnStartup Nilai integer memberi Anda petunjuk pengurutan mulai |
5 | WebInitParam[] initParams Array parameter inisialisasi untuk Servlet ini |
6 | Boolean asyncSupported Operasi asinkron yang didukung oleh Servlet ini |
7 | String smallIcon Ikon kecil untuk Servlet ini, jika ada |
8 | String largeIcon Ikon besar untuk Servlet ini, jika ada |
9 | String description Deskripsi Servlet ini, jika ada |
10 | String displayName Nama tampilan Servlet ini, jika ada |
Setidaknya satu pola URL HARUS dideklarasikan di value atau urlPattern atribut anotasi, tetapi tidak keduanya.
Itu value atribut direkomendasikan untuk digunakan ketika pola URL adalah satu-satunya atribut yang disetel, jika tidak, urlPattern atribut harus digunakan.
Contoh
Contoh berikut menjelaskan cara menggunakan anotasi @WebServlet. Ini adalah servlet sederhana yang menampilkan teksHello Servlet.
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebInitParam;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
@WebServlet(value = "/Simple")
public class Simple extends HttpServlet {
private static final long serialVersionUID = 1L;
protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setContentType("text/html");
PrintWriter out = response.getWriter();
out.print("<html><body>");
out.print("<h3>Hello Servlet</h3>");
out.print("</body></html>");
}
}
Menyusun Simple.java dengan cara biasa dan letakkan file kelas Anda di <Tomcat-installationdirectory> / webapps / ROOT / WEB-INF / kelas.
Sekarang coba panggil servlet dengan hanya menjalankan http: // localhost: 8080 / Simple . Anda akan melihat output berikut di halaman web.
Hello servlet
@Bayu_joo
Anotasi @WebInitParam digunakan untuk menentukan parameter inisialisasi untuk Servlet atau Filter. Ini digunakan dalam anotasi WebFilter atau WebSevlet. Tabel berikut berisi daftar atribut yang digunakan untuk anotasi WebInitParam.
Sr.No. | Atribut & Deskripsi |
---|---|
1 | String name Nama parameter inisialisasi |
2 | String value Nilai parameter inisialisasi |
3 | String description Deskripsi parameter inisialisasi |
Contoh
Contoh berikut menjelaskan cara menggunakan anotasi @WeInitParam bersama dengan anotasi @WebServlet. Ini adalah servlet sederhana yang menampilkan teksHello Servlet dan nilai string Hello World! yang diambil dari init parameter.
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebInitParam;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
@WebServlet(value = "/Simple", initParams = {
@WebInitParam(name = "foo", value = "Hello "),
@WebInitParam(name = "bar", value = " World!")
})
public class Simple extends HttpServlet {
private static final long serialVersionUID = 1L;
protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setContentType("text/html");
PrintWriter out = response.getWriter();
out.print("<html><body>");
out.print("<h3>Hello Servlet</h3>");
out.println(getInitParameter("foo"));
out.println(getInitParameter("bar"));
out.print("</body></html>");
}
}
Menyusun Simple.java dengan cara biasa dan letakkan file kelas Anda di <Tomcat-installationdirectory>; / webapps / ROOT / WEB-INF / kelas.
Sekarang coba panggil servlet dengan hanya menjalankan http: // localhost: 8080 / Simple . Anda akan melihat output berikut di halaman web.
Hello Servlet
Hello World!
@Filter_kecil
Ini adalah anotasi yang digunakan untuk mendeklarasikan filter servlet. Ini diproses oleh penampung pada waktu penerapan, dan filter terkait diterapkan ke pola URL, servlet, dan jenis petugas operator yang ditentukan.
Itu @WebFilteranotasi mendefinisikan filter dalam aplikasi web. Anotasi ini ditentukan di kelas dan berisi metadata tentang filter yang dideklarasikan. Filter beranotasi harus menentukan setidaknya satu pola URL. Tabel berikut mencantumkan atribut yang digunakan untuk anotasi WebFilter.
Sr.No. | Atribut & Deskripsi |
---|---|
1 | String filterName Nama filter |
2 | String[] urlPatterns Menyediakan larik nilai atau urlPatterns yang diterapkan filter |
3 | DispatcherType[] dispatcherTypes Menentukan jenis petugas operator (Permintaan / Respons) tempat filter diterapkan |
4 | String[] servletNames Menyediakan larik nama servlet |
5 | String displayName Nama filter |
6 | String description Deskripsi filter |
7 | WebInitParam[] initParams Larik parameter inisialisasi untuk filter ini |
8 | Boolean asyncSupported Operasi asinkron didukung oleh filter ini |
9 | String smallIcon Ikon kecil untuk filter ini, jika ada |
10 | String largeIcon Ikon besar untuk filter ini, jika ada |
Contoh
Contoh berikut menjelaskan cara menggunakan anotasi @WebFilter. Ini adalah LogFilter sederhana yang menampilkan nilai Init-paramtest-paramdan stempel waktu waktu saat ini di konsol. Artinya, filter berfungsi seperti lapisan antarmuka antara permintaan dan respons. Di sini kami menggunakan "/ *" untuk urlPattern. Artinya, filter ini berlaku untuk semua servlet.
import java.io.IOException;
import javax.servlet.annotation.WebFilter;
import javax.servlet.annotation.WebInitParam;
import javax.servlet.*;
import java.util.*;
// Implements Filter class
@WebFilter(urlPatterns = {"/*"}, initParams = {
@WebInitParam(name = "test-param", value = "Initialization Paramter")})
public class LogFilter implements Filter {
public void init(FilterConfig config) throws ServletException {
// Get init parameter
String testParam = config.getInitParameter("test-param");
//Print the init parameter
System.out.println("Test Param: " + testParam);
}
public void doFilter(ServletRequest request, ServletResponse response,
FilterChain chain) throws IOException, ServletException {
// Log the current timestamp.
System.out.println("Time " + new Date().toString());
// Pass request back down the filter chain
chain.doFilter(request,response);
}
public void destroy( ) {
/* Called before the Filter instance is removed
from service by the web container*/
}
}
Menyusun Simple.java dengan cara biasa dan letakkan file kelas Anda di <Tomcat-installationdirectory> / webapps / ROOT / WEB-INF / kelas.
Sekarang coba panggil servlet dengan hanya menjalankan http: // localhost: 8080 / Simple . Anda akan melihat output berikut di halaman web.
Hello Servlet
Hello World!
Sekarang, buka konsol servlet. Di sana, Anda akan menemukan nilai fileinit parameter testparam dan current timestamp bersama dengan pesan notifikasi servlet.