Struts 2 - Interceptors

Interceptor secara konseptual sama dengan filter servlet atau kelas Proxy JDKs. Interceptors memungkinkan fungsionalitas lintas sektor untuk diimplementasikan secara terpisah dari aksi serta kerangka kerja. Anda dapat mencapai hal berikut menggunakan pencegat -

  • Memberikan logika preprocessing sebelum aksi dipanggil.

  • Memberikan logika postprocessing setelah aksi dipanggil.

  • Menangkap pengecualian sehingga pemrosesan alternatif dapat dilakukan.

Banyak fitur yang disediakan di Struts2 kerangka diimplementasikan menggunakan interseptor;

Examples termasuk penanganan pengecualian, pengunggahan file, callback siklus hidup, dll. Faktanya, karena Struts2 menekankan sebagian besar fungsinya pada interseptor, kemungkinan tidak ada 7 atau 8 interseptor yang ditetapkan per tindakan.

Struts2 Framework Interceptors

Framework Struts 2 menyediakan daftar interseptor out-of-the-box yang baik yang telah dikonfigurasi sebelumnya dan siap digunakan. Beberapa interseptor penting tercantum di bawah ini -

Sr Tidak Interceptor & Deskripsi
1

alias

Mengizinkan parameter memiliki alias nama yang berbeda di seluruh permintaan.

2

checkbox

Membantu dalam mengelola kotak centang dengan menambahkan nilai parameter salah untuk kotak centang yang tidak dicentang.

3

conversionError

Menempatkan informasi kesalahan dari mengonversi string menjadi jenis parameter ke dalam kesalahan bidang tindakan.

4

createSession

Secara otomatis membuat sesi HTTP jika belum ada.

5

debugging

Menyediakan beberapa layar debugging yang berbeda untuk pengembang.

6

execAndWait

Mengirim pengguna ke halaman tunggu perantara saat aksi dijalankan di latar belakang.

7

exception

Pengecualian peta yang dilemparkan dari suatu tindakan ke hasil, memungkinkan penanganan pengecualian otomatis melalui pengalihan.

8

fileUpload

Memfasilitasi pengunggahan file dengan mudah.

9

i18n

Melacak lokal yang dipilih selama sesi pengguna.

10

logger

Menyediakan logging sederhana dengan mengeluarkan nama tindakan yang sedang dieksekusi.

11

params

Menetapkan parameter permintaan pada tindakan.

12

prepare

Ini biasanya digunakan untuk melakukan pekerjaan pra-pemrosesan, seperti menyiapkan koneksi database.

13

profile

Mengizinkan informasi profil sederhana untuk dicatat untuk tindakan.

14

scope

Menyimpan dan mengambil status tindakan dalam sesi atau cakupan aplikasi.

15

ServletConfig

Menyediakan aksi dengan akses ke berbagai informasi berbasis servlet.

16

timer

Memberikan informasi pembuatan profil sederhana dalam bentuk berapa lama tindakan yang diperlukan untuk dijalankan.

17

token

Memeriksa tindakan untuk token yang valid untuk mencegah pengiriman formulir duplikat.

18

validation

Memberikan dukungan validasi untuk tindakan

Silakan lihat dokumentasi Struts 2 untuk detail lengkap tentang interseptor yang disebutkan di atas. Tetapi saya akan menunjukkan kepada Anda bagaimana menggunakan pencegat secara umum dalam aplikasi Struts Anda.

Bagaimana Cara Menggunakan Interceptors?

Mari kita lihat bagaimana menggunakan pencegat yang sudah ada ke program "Hello World" kita. Kami akan menggunakantimerinterceptor yang bertujuan untuk mengukur berapa lama waktu yang dibutuhkan untuk mengeksekusi suatu metode tindakan. Pada saat yang sama, saya menggunakanparamsinterceptor yang tujuannya adalah mengirim parameter permintaan ke tindakan. Anda dapat mencoba contoh Anda tanpa menggunakan pencegat ini dan Anda akan menemukannyaname properti tidak disetel karena parameter tidak dapat menjangkau tindakan.

Kami akan menyimpan file HelloWorldAction.java, web.xml, HelloWorld.jsp dan index.jsp seperti yang telah dibuat di Examples bab tapi mari kita memodifikasi struts.xml file untuk menambahkan pencegat sebagai berikut -

<?xml version = "1.0" Encoding = "UTF-8"?>
<!DOCTYPE struts PUBLIC
   "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
   "http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
   <constant name = "struts.devMode" value = "true" />
   
   <package name = "helloworld" extends = "struts-default">
      <action name = "hello" 
         class = "com.tutorialspoint.struts2.HelloWorldAction"
         method = "execute">
         <interceptor-ref name = "params"/>
         <interceptor-ref name = "timer" />
         <result name = "success">/HelloWorld.jsp</result>
      </action>
   </package>
</struts>

Klik kanan pada nama proyek dan klik Export > WAR Fileuntuk membuat file Perang. Kemudian terapkan WAR ini di direktori webapps Tomcat. Terakhir, jalankan server Tomcat dan coba akses URLhttp://localhost:8080/HelloWorldStruts2/index.jsp. Ini akan menghasilkan layar berikut -

Sekarang masukkan kata apa pun di kotak teks yang diberikan dan klik tombol Say Hello untuk menjalankan tindakan yang ditentukan. Sekarang jika Anda akan memeriksa log yang dihasilkan, Anda akan menemukan teks berikut -

INFO: Server startup in 3539 ms
27/08/2011 8:40:53 PM 
com.opensymphony.xwork2.util.logging.commons.CommonsLogger info
INFO: Executed action [//hello!execute] took 109 ms.

Di sini intinya dibuat karena timer interceptor yang mengatakan bahwa tindakan mengambil total 109ms untuk dieksekusi.

Buat Interceptors Kustom

Menggunakan interseptor khusus dalam aplikasi Anda adalah cara elegan untuk menyediakan fitur aplikasi lintas sektor. Membuat pencegat khusus itu mudah; antarmuka yang perlu diperluas adalah sebagai berikutInterceptor antarmuka -

public interface Interceptor extends Serializable {
   void destroy();
   void init();
   String intercept(ActionInvocation invocation)
   throws Exception;
}

Seperti namanya, metode init () menyediakan cara untuk menginisialisasi interseptor, dan metode destroy () menyediakan fasilitas untuk pembersihan interceptor. Tidak seperti tindakan, interseptor digunakan kembali di seluruh permintaan dan perlu threadsafe, terutama metode intercept ().

Itu ActionInvocationobjek menyediakan akses ke lingkungan runtime. Ini memungkinkan akses ke tindakan itu sendiri dan metode untuk memanggil tindakan dan menentukan apakah tindakan telah dipanggil.

Jika Anda tidak memerlukan inisialisasi atau kode pembersihan, file AbstractInterceptorkelas bisa diperpanjang. Ini menyediakan implementasi nooperation default dari metode init () dan destroy ().

Buat Kelas Interceptor

Mari kita buat MyInterceptor.java berikut di Java Resources > src folder -

package com.tutorialspoint.struts2;

import java.util.*;
import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.AbstractInterceptor;

public class MyInterceptor extends AbstractInterceptor {

   public String intercept(ActionInvocation invocation)throws Exception {

      /* let us do some pre-processing */
      String output = "Pre-Processing"; 
      System.out.println(output);

      /* let us call action or next interceptor */
      String result = invocation.invoke();

      /* let us do some post-processing */
      output = "Post-Processing"; 
      System.out.println(output);

      return result;
   }
}

Seperti yang Anda perhatikan, tindakan aktual akan dieksekusi menggunakan pencegat oleh invocation.invoke()panggilan. Jadi, Anda dapat melakukan beberapa pemrosesan awal dan beberapa pemrosesan pasca berdasarkan kebutuhan Anda.

Framework itu sendiri memulai proses dengan membuat panggilan pertama ke invoke () objek ActionInvocation. Setiap waktuinvoke()disebut, ActionInvocation berkonsultasi dengan statusnya dan mengeksekusi interseptor mana pun yang datang berikutnya. Ketika semua interseptor yang dikonfigurasi telah dipanggil, metode invoke () akan menyebabkan tindakan itu sendiri dijalankan.

Diagram berikut menunjukkan konsep yang sama melalui aliran permintaan -

Buat Kelas Aksi

Mari kita buat file java HelloWorldAction.java di bawah Java Resources > src dengan nama paket com.tutorialspoint.struts2 dengan konten yang diberikan di bawah ini.

package com.tutorialspoint.struts2;

import com.opensymphony.xwork2.ActionSupport;

public class HelloWorldAction extends ActionSupport {
   private String name;

   public String execute() throws Exception {
      System.out.println("Inside action....");
      return "success";
   }  

   public String getName() {
      return name;
   }

   public void setName(String name) {
      this.name = name;
   }
}

Ini adalah kelas yang sama yang telah kita lihat pada contoh sebelumnya. Kami memiliki metode pengambil dan penyetel standar untuk properti "nama" dan metode eksekusi yang mengembalikan string "berhasil".

Buat Tampilan

Mari kita buat file jsp di bawah ini HelloWorld.jsp di folder WebContent di proyek eclipse Anda.

<%@ page contentType = "text/html; charset = UTF-8" %>
<%@ taglib prefix = "s" uri = "/struts-tags" %>

<html>
   <head>
      <title>Hello World</title>
   </head>
   
   <body>
      Hello World, <s:property value = "name"/>
   </body>
</html>

Buat Halaman Utama

Kami juga perlu menciptakan index.jspdi folder WebContent. File ini akan berfungsi sebagai URL tindakan awal di mana pengguna dapat mengklik untuk memberi tahu kerangka kerja Struts 2 untuk memanggil metode yang ditentukan dari kelas HelloWorldAction dan membuat tampilan HelloWorld.jsp.

<%@ page language = "java" contentType = "text/html; charset = ISO-8859-1"
   pageEncoding = "ISO-8859-1"%>
<%@ taglib prefix = "s" uri = "/struts-tags"%>
   <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" 
   "http://www.w3.org/TR/html4/loose.dtd">

<html>
   <head>
      <title>Hello World</title>
   </head>
   
   <body>
      <h1>Hello World From Struts2</h1>
      <form action = "hello">
         <label for = "name">Please enter your name</label><br/>
         <input type = "text" name = "name"/>
         <input type = "submit" value = "Say Hello"/>
      </form>
   </body>
</html>

Itu hello tindakan yang ditentukan dalam file tampilan di atas akan dipetakan ke kelas HelloWorldAction dan metode eksekusi menggunakan file struts.xml.

File Konfigurasi

Sekarang, kita perlu mendaftarkan pencegat kita dan kemudian memanggilnya seperti yang kita panggil interseptor default pada contoh sebelumnya. Untuk mendaftarkan interseptor yang baru didefinisikan, tag <interceptors> ... </interceptors> ditempatkan langsung di bawah tag <package>struts.xmlmengajukan. Anda dapat melewati langkah ini untuk interseptor default seperti yang kita lakukan di contoh sebelumnya. Tapi di sini mari kita daftar dan gunakan sebagai berikut -

<?xml version = "1.0" Encoding = "UTF-8"?>
<!DOCTYPE struts PUBLIC
   "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
   "http://struts.apache.org/dtds/struts-2.0.dtd">

<struts>
   <constant name = "struts.devMode" value = "true" />
   <package name = "helloworld" extends = "struts-default">

      <interceptors>
         <interceptor name = "myinterceptor"
            class = "com.tutorialspoint.struts2.MyInterceptor" />
      </interceptors>

      <action name = "hello" 
         class = "com.tutorialspoint.struts2.HelloWorldAction" 
         method = "execute">
         <interceptor-ref name = "params"/>
         <interceptor-ref name = "myinterceptor" />
         <result name = "success">/HelloWorld.jsp</result>
      </action>

   </package>
</struts>

Perlu dicatat bahwa Anda dapat mendaftarkan lebih dari satu interseptor di dalamnya <package> tag dan waktu yang sama Anda dapat memanggil lebih dari satu interseptor di dalam <action>menandai. Anda dapat memanggil pencegat yang sama dengan tindakan yang berbeda.

File web.xml perlu dibuat di bawah folder WEB-INF di bawah Konten Web sebagai berikut -

<?xml version = "1.0" Encoding = "UTF-8"?>
<web-app xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xmlns = "http://java.sun.com/xml/ns/javaee" 
   xmlns:web = "http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
   xsi:schemaLocation = "http://java.sun.com/xml/ns/javaee 
   http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
   id = "WebApp_ID" version = "3.0">
   
   <display-name>Struts 2</display-name>
   
   <welcome-file-list>
      <welcome-file>index.jsp</welcome-file>
   </welcome-file-list>
   
   <filter>
      <filter-name>struts2</filter-name>
      <filter-class>
         org.apache.struts2.dispatcher.FilterDispatcher
      </filter-class>
   </filter>

   <filter-mapping>
      <filter-name>struts2</filter-name>
      <url-pattern>/*</url-pattern>
   </filter-mapping>
</web-app>

Klik kanan pada nama proyek dan klik Export > WAR Fileuntuk membuat file Perang. Kemudian terapkan WAR ini di direktori webapps Tomcat. Terakhir, jalankan server Tomcat dan coba akses URLhttp://localhost:8080/HelloWorldStruts2/index.jsp. Ini akan menghasilkan layar berikut -

Sekarang masukkan kata apa pun di kotak teks yang diberikan dan klik tombol Say Hello untuk menjalankan tindakan yang ditentukan. Sekarang jika Anda akan memeriksa log yang dihasilkan, Anda akan menemukan teks berikut di bagian bawah -

Pre-Processing
Inside action....
Post-Processing

Menumpuk Beberapa Interceptor

Seperti yang dapat Anda bayangkan, harus mengonfigurasi beberapa interseptor untuk setiap tindakan akan dengan cepat menjadi sangat tidak dapat dikelola. Untuk alasan ini, pencegat dikelola dengan tumpukan interseptor. Berikut ini contohnya, langsung dari file strutsdefault.xml -

<interceptor-stack name = "basicStack">
   <interceptor-ref name = "exception"/>
   <interceptor-ref name = "servlet-config"/>
   <interceptor-ref name = "prepare"/>
   <interceptor-ref name = "checkbox"/>
   <interceptor-ref name = "params"/>
   <interceptor-ref name = "conversionError"/>
</interceptor-stack>

Taruhan di atas disebut basicStackdan dapat digunakan dalam konfigurasi Anda seperti yang ditunjukkan di bawah ini. Node konfigurasi ini ditempatkan di bawah node <package ... />. Setiap tag <interceptor-ref ... /> merujuk pada interseptor atau tumpukan interseptor yang telah dikonfigurasi sebelum tumpukan interceptor saat ini. Oleh karena itu, sangat penting untuk memastikan bahwa nama tersebut unik di semua konfigurasi tumpukan pencegat dan pencegat saat mengkonfigurasi tumpukan pencegat dan pencegat awal.

Kami telah melihat bagaimana menerapkan interseptor ke aksi, menerapkan tumpukan interseptor tidak berbeda. Faktanya, kami menggunakan tag yang persis sama -

<action name = "hello" class = "com.tutorialspoint.struts2.MyAction">
   <interceptor-ref name = "basicStack"/>
   <result>view.jsp</result>
</action

Pendaftaran "basicStack" di atas akan mendaftarkan seluruh saham dari enam pencegat dengan tindakan hello. Ini harus dicatat bahwa interseptor dijalankan sesuai urutan, di mana mereka telah dikonfigurasi. Misalnya, dalam kasus di atas, eksepsi akan dijalankan pertama, kedua akan menjadi servlet-config, dan seterusnya.