Struts 2 - File Konfigurasi

Bab ini akan memandu Anda melalui konfigurasi dasar yang diperlukan untuk a Struts 2aplikasi. Di sini kita akan melihat apa yang dapat dikonfigurasi dengan bantuan beberapa file konfigurasi penting sepertiweb.xml, struts.xml, strutsconfig.xml dan struts.properties

Sejujurnya, Anda bisa mulai bekerja hanya dengan menggunakan web.xml dan struts.xmlfile konfigurasi (seperti yang telah Anda saksikan di bab sebelumnya di mana contoh kami bekerja menggunakan dua file ini). Namun, untuk pengetahuan Anda, kami juga akan menjelaskan tentang file lain.

File web.xml

File konfigurasi web.xml adalah file konfigurasi J2EE yang menentukan bagaimana elemen permintaan HTTP diproses oleh wadah servlet. Ini bukan hanya file konfigurasi Struts2, tetapi ini adalah file yang perlu dikonfigurasi agar Struts2 berfungsi.

Seperti yang telah dibahas sebelumnya, file ini menyediakan titik masuk untuk aplikasi web apa pun. Titik masuk aplikasi Struts2 akan menjadi filter yang ditentukan dalam deskriptor penerapan (web.xml). Karenanya kita akan mendefinisikan entri kelas FilterDispatcher di web.xml. File web.xml perlu dibuat di bawah folderWebContent/WEB-INF.

Ini adalah file konfigurasi pertama yang perlu Anda konfigurasikan jika Anda memulai tanpa bantuan template atau alat yang menghasilkannya (seperti Eclipse atau Maven2).

Berikut adalah konten file web.xml yang kami gunakan dalam contoh terakhir kami.

<?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>

Perhatikan bahwa kami memetakan filter Struts 2 ke /*, dan tidak /*.actionyang berarti bahwa semua url akan diurai oleh filter struts. Kami akan membahas ini ketika kami akan melalui bab Anotasi.

File Struts.xml

Itu struts.xmlfile berisi informasi konfigurasi yang akan Anda modifikasi saat tindakan dikembangkan. File ini dapat digunakan untuk mengesampingkan pengaturan default untuk aplikasi, misalnya struts.devMode = false dan pengaturan lain yang ditentukan dalam file properti. File ini dapat dibuat di bawah folderWEB-INF/classes.

Mari kita lihat file struts.xml yang kita buat pada contoh Hello World yang dijelaskan di bab sebelumnya.

<?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">
         <result name = "success">/HelloWorld.jsp</result>
      </action>
      
      <-- more actions can be listed here -->

   </package>
   <-- more packages can be listed here -->

</struts>

Hal pertama yang perlu diperhatikan adalah DOCTYPE. Semua file konfigurasi struts harus memiliki doctype yang benar seperti yang ditunjukkan pada contoh kecil kami. <struts> adalah elemen tag root, di mana kami mendeklarasikan paket yang berbeda menggunakan tag <package>. Di sini <package> memungkinkan pemisahan dan modularisasi konfigurasi. Ini sangat berguna ketika Anda memiliki proyek besar dan proyek dibagi menjadi beberapa modul.

Misalnya, jika project Anda memiliki tiga domain - business_application, customer_application dan staff_application, Anda dapat membuat tiga paket dan menyimpan tindakan terkait dalam paket yang sesuai.

Tag paket memiliki atribut berikut -

Sr Tidak Atribut & Deskripsi
1

name (required)

Pengenal unik untuk paket tersebut

2

extends

Paket mana yang diperpanjang dari paket ini? Secara default, kami menggunakan struts-default sebagai paket dasar.

3

abstract

Jika ditandai benar, paket tersebut tidak tersedia untuk konsumsi pengguna akhir.

4

namespace

Namespace unik untuk tindakan

Itu constant tag bersama dengan nama dan atribut nilai harus digunakan untuk menimpa salah satu properti berikut yang ditentukan di default.properties, seperti yang baru saja kita atur struts.devModeProperti. Pengaturanstruts.devMode properti memungkinkan kita untuk melihat lebih banyak pesan debug di file log.

Kami mendefinisikan action tag sesuai dengan setiap URL yang ingin kita akses dan kita mendefinisikan kelas dengan metode execute () yang akan diakses setiap kali kita mengakses URL terkait.

Hasil menentukan apa yang dikembalikan ke browser setelah tindakan dijalankan. String yang dikembalikan dari tindakan harus menjadi nama hasil. Hasil dikonfigurasi per tindakan seperti di atas, atau sebagai hasil "global", tersedia untuk setiap tindakan dalam sebuah paket. Hasil memiliki opsionalname dan typeatribut. Nilai nama defaultnya adalah "sukses".

File Struts.xml dapat tumbuh besar dari waktu ke waktu dan karenanya memecahnya dengan paket adalah salah satu cara untuk memodularkannya, tetapi Strutsmenawarkan cara lain untuk memodularisasi file struts.xml. Anda dapat membagi file menjadi beberapa file xml dan mengimpornya dengan cara 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>
   <include file="my-struts1.xml"/>
   <include file="my-struts2.xml"/>
</struts>

File konfigurasi lain yang belum kami bahas adalah struts-default.xml. File ini berisi pengaturan konfigurasi standar untuk Struts dan Anda tidak perlu menyentuh pengaturan ini untuk 99,99% proyek Anda. Untuk alasan ini, kami tidak akan membahas terlalu banyak detail tentang file ini. Jika Anda tertarik, lihat didefault.properties file tersedia dalam file struts2-core-2.2.3.jar.

File Struts-config.xml

File konfigurasi struts-config.xml adalah tautan antara komponen Tampilan dan Model di Klien Web, tetapi Anda tidak perlu menyentuh pengaturan ini untuk 99,99% proyek Anda.

File konfigurasi pada dasarnya berisi elemen utama berikut -

Sr Tidak Interceptor & Deskripsi
1

struts-config

Ini adalah simpul akar dari file konfigurasi.

2

form-beans

Di sinilah Anda memetakan subkelas ActionForm Anda ke sebuah nama. Anda menggunakan nama ini sebagai alias untuk ActionForm Anda di seluruh file strutsconfig.xml, dan bahkan pada halaman JSP Anda.

3

global forwards

Bagian ini memetakan halaman di aplikasi web Anda ke sebuah nama. Anda dapat menggunakan nama ini untuk merujuk ke halaman yang sebenarnya. Ini untuk menghindari URL hardcode pada halaman web Anda.

4

action-mappings

Di sinilah Anda mendeklarasikan penangan formulir dan mereka juga dikenal sebagai pemetaan tindakan.

5

controller

Bagian ini mengkonfigurasi internal Struts dan jarang digunakan dalam situasi praktis.

6

plug-in

Bagian ini memberi tahu Struts di mana menemukan file properti Anda, yang berisi prompt dan pesan kesalahan

Berikut adalah contoh file struts-config.xml -

<?xml version = "1.0" Encoding = "ISO-8859-1" ?>
<!DOCTYPE struts-config PUBLIC
   "-//Apache Software Foundation//DTD Struts Configuration 1.0//EN"
   "http://jakarta.apache.org/struts/dtds/struts-config_1_0.dtd">

<struts-config>

   <!-- ========== Form Bean Definitions ============ -->
   <form-beans>
      <form-bean name = "login" type = "test.struts.LoginForm" />
   </form-beans>

   <!-- ========== Global Forward Definitions ========= -->
   <global-forwards>
   </global-forwards>

   <!-- ========== Action Mapping Definitions ======== -->
   <action-mappings>
      <action
         path = "/login"
         type = "test.struts.LoginAction" >

         <forward name = "valid" path = "/jsp/MainMenu.jsp" />
         <forward name = "invalid" path = "/jsp/LoginView.jsp" />
      </action>
   </action-mappings>

   <!-- ========== Controller Definitions ======== -->
   <controller contentType = "text/html;charset = UTF-8"
      debug = "3" maxFileSize = "1.618M" locale = "true" nocache = "true"/>

</struts-config>

Untuk detail lebih lanjut tentang file struts-config.xml, silakan periksa dokumentasi struts Anda.

File Struts.properties

File konfigurasi ini menyediakan mekanisme untuk mengubah perilaku default kerangka kerja. Sebenarnya, semua properti yang terkandung di dalamstruts.properties file konfigurasi juga dapat dikonfigurasi di web.xml menggunakan init-param, serta menggunakan tag konstan di struts.xmlfile konfigurasi. Tetapi, jika Anda ingin memisahkan semuanya dan lebih spesifik, Anda dapat membuat file ini di bawah folderWEB-INF/classes.

Nilai yang dikonfigurasi dalam file ini akan menggantikan nilai default yang dikonfigurasi di default.propertiesyang terkandung dalam distribusi struts2-core-xyzjar. Ada beberapa properti yang mungkin Anda pertimbangkan untuk diubah menggunakanstruts.properties file -

### When set to true, Struts will act much more friendly for developers
struts.devMode = true

### Enables reloading of internationalization files
struts.i18n.reload = true

### Enables reloading of XML configuration files
struts.configuration.xml.reload = true

### Sets the port that the server is run on
struts.url.http.port = 8080

Di sini setiap baris dimulai dengan hash (#) akan dianggap sebagai komentar dan akan diabaikan oleh Struts 2.