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.