Hva er JSP-direktiver?
- JSP-direktiver er meldingene til JSP container. De gir global informasjon om en hel JSP-side.
- JSP-direktiver brukes til å gi spesiell instruksjon til en container for oversettelse av JSP til servletkode.
- I JSP livssyklusfase må JSP konverteres til en servlet som er oversettelsesfasen.
- De gir instruksjoner til containeren om hvordan du håndterer visse aspekter av JSP-behandling
- Direktiver kan ha mange attributter med komma atskilt som nøkkelverdipar.
- I JSP er direktiv beskrevet i <% @%> koder.
Syntaks for direktivet:
<%@ directive attribute %>
Det er tre typer direktiver:
- Side-direktivet
- Inkluder direktiv
- Taglib-direktivet
Hver av dem er beskrevet i detalj nedenfor med eksempler:
I denne opplæringen lærer du -
- JSP-sidedirektivet
- JSP Inkluder direktiv
- JSP Taglib-direktivet
JSP-sidedirektivet
Syntaks for sidedirektivet:
<%@ page… %>
- Det gir attributter som blir brukt på hele JSP-siden.
- Den definerer sideavhengige attributter, for eksempel skriptspråk, feilside og bufferkrav.
- Den brukes til å gi instruksjoner til en container som gjelder gjeldende JSP-side.
Følgende er listen over attributter knyttet til sidedirektivet:
- Språk
- Strekker
- Import
- innholdstype
- info
- økt
- isThreadSafe
- autoflush
- buffer
- IsErrorPage
- pageEncoding
- errorPage
- isELgonored
Mer informasjon om hvert attributt
- språk : Den definerer programmeringsspråket (underliggende språk) som brukes på siden.
Språksyntaks:
<%@ page language="value" %>
Her er verdien programmeringsspråket (underliggende språk)
Eksempel:
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"pageEncoding="ISO-8859-1"%>
Forklaring av kode: I eksemplet ovenfor er attributt språkverdi Java som er det underliggende språket i dette tilfellet. Derfor vil koden i uttrykkskoder bli kompilert ved hjelp av Java-kompilator.
- Utvider : Denne attributtet brukes til å utvide (arve) klassen slik JAVA gjør
Syntaks for utvidelser:
<%@ page extends="value" %>
Her representerer verdien klassen den må arves fra.
Eksempel:
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"pageEncoding="ISO-8859-1"%><%@ page extends="demotest.DemoClass" %>
Forklaring av koden: I den ovennevnte koden utvider JSP DemoClass som er innenfor demotest-pakken, og den vil utvide alle klassefunksjonene.
- Import : Dette attributtet er det mest brukte attributtet i attributter for sidedirektiv. Det brukes til å fortelle containeren å importere andre java-klasser, grensesnitt, enums, etc. mens genererer servletkode. Det ligner på importuttalelser i java-klasser, grensesnitt.
Import av syntaks :
<%@ page import="value" %>
Her indikerer verdien klassene som må importeres.
Eksempel:
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"import="java.util.Date" pageEncoding="ISO-8859-1"%>
Forklaring av koden:
I koden ovenfor importerer vi dataklasse fra java.util-pakken (alle verktøyklasser), og den kan bruke alle metodene i følgende klasse.
- contentType :
- Den definerer tegnskodeskjemaet, dvs. det brukes til å stille inn innholdstype og tegnsett for svaret
- Standard type contentType er "text / html; charset = ISO-8859-1".
Innholdssyntaks Type:
<%@ page contentType="value" %>
Eksempel:
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"pageEncoding="ISO-8859-1"%>
Forklaring av koden:
I ovennevnte kode er innholdstypen angitt som tekst / html, den setter tegnkoding for JSP og for generert responsside.
- info
- Den definerer en streng som er tilgjengelig med getServletInfo () -metoden.
- Dette attributtet brukes til å angi servletbeskrivelsen.
Syntaks for info:
<%@ page info="value" %>
Her representerer verdien servletinformasjonen.
Eksempel:
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"info="Guru Directive JSP" pageEncoding="ISO-8859-1"%>
Forklaring av koden:
I ovennevnte kode kan strengen "Guru Directive JSP" hentes av servletgrensesnittet ved hjelp av getServletInfo ()
- Økt
- JSP-siden oppretter økt som standard.
- Noen ganger trenger vi ikke å opprette en økt i JSP, og derfor kan vi i dette tilfellet sette dette attributtet til falsk. Standardverdien til øktattributtet er sann, og økten opprettes.
Når den er satt til falsk, kan vi indikere at kompilatoren ikke oppretter økten som standard.
Øktens syntaks:
<%@ page session="true/false"%>
Her i dette tilfellet kan sesjonsattributt settes til sant eller usant
Eksempel:
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"session="false"%>
Forklaring av kode:
I eksemplet ovenfor er øktattributtet satt til "falsk", og vi indikerer derfor at vi ikke vil lage noen økt i denne JSP
- isThreadSafe:
- Den definerer trådmodellen for den genererte servletten.
- Det indikerer nivået på trådsikkerhet implementert på siden.
- Standardverdien er sant så samtidig
- Vi kan bruke dette attributtet til å implementere SingleThreadModel-grensesnitt i generert servlet.
- Hvis vi setter den til false, vil den implementere SingleThreadModel og kan få tilgang til delte objekter og kan gi inkonsekvens.
Syntaks for isThreadSafe:
<% @ page isThreadSafe="true/false" %>
Her representerer true eller false hvis synkronisering er der, og sett det som true og sett det som false.
Eksempel:
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"isThreadSafe="true"%>
Forklaring av koden:
I koden ovenfor er isThreadSafe satt til "true", og derfor vil synkronisering gjøres, og flere tråder kan brukes.
- AutoFlush:
Dette attributtet spesifiserer at den bufrede utgangen skal skylles automatisk eller ikke, og standardverdien for det attributtet er sant.
Hvis verdien er satt til falsk, blir ikke bufferen spylt automatisk, og hvis den er full, får vi et unntak.
Når bufferen er ingen, er falsken uekte, og det er ingen buffering, så den skylles automatisk.
Syntaks for autoFlush:
<% @ page autoFlush="true/false" %>
Her representerer sant / usant om buffering må gjøres eller ikke
Eksempel:
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"autoFlush="false"%>
Forklaring av koden:
I den ovennevnte koden er autoflush satt til falsk, og buffering vil derfor ikke gjøres, og den har spylt utgangen manuelt.
- Buffer:
- Ved å bruke dette attributtet kan utgangssvarobjektet være bufret.
- Vi kan definere størrelsen på buffering som skal gjøres ved hjelp av dette attributtet, og standardstørrelsen er 8 KB.
- Den leder servletten til å skrive bufferen før den skrives til responsobjektet.
Syntaks for buffer:
<%@ page buffer="value" %>
Her representerer verdien størrelsen på bufferen som må defineres. Hvis det ikke er noen buffer, kan vi skrive som ingen, og hvis vi ikke nevner noen verdi, er standard 8KB
Eksempel:
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"buffer="16KB"%>
Forklaring av koden:
I den ovennevnte koden er bufferstørrelse nevnt som 16KB hvor bufferen vil være av den størrelsen
- isErrorPage:
- Det indikerer at JSP-side som har en feilside vil bli sjekket på en annen JSP-side
- Enhver JSP-fil som er erklært med "isErrorPage" -attributtet, kan da motta unntak fra andre JSP-sider som har feilsider.
- Unntak er bare tilgjengelig på disse sidene.
- Standardverdien er falsk.
Syntaks for isErrorPage:
<%@ page isErrorPage="true/false"%>
Eksempel:
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"isErrorPage="true"%>
Forklaring av koden:
I koden ovenfor er isErrorPage satt som sant. Derfor vil den sjekke at alle andre JSPer har errorPage (beskrevet i neste attributt) attributt sett, og det kan håndtere unntak.
- PageEncoding:
Standard er angitt som "ISO-8859-1" hvis andre ikke er spesifisert.
Syntaks for side Koding:
<%@ page pageEncoding="vaue" %>
Her spesifiserer verdien tegnsettverdien for JSP
Eksempel:
<%@ page language="java" contentType="text/html;" pageEncoding="ISO-8859-1"isErrorPage="true"%>
Forklaring av koden:
I ovennevnte kode er "pageEncoding" satt til standard tegnsett ISO-8859-1
- errorPage:
Feilsyntaks Side:
<%@ page errorPage="value" %>
Her representerer verdien feilen JSP-sideverdi
Eksempel:
<%@ page language="java" contentType="text/html;" pageEncoding="ISO-8859-1"errorPage="errorHandler.jsp"%>
Forklaring av koden:
I koden ovenfor har vi errroHandler.jsp for å håndtere unntak
- isELIgnorert:
- IsELIgnored er et flaggattributt der vi må bestemme om vi skal ignorere EL-koder eller ikke.
- Dens datatype er java enum, og standardverdien er falsk, derfor er EL aktivert som standard.
Syntaks for isEL ignorert:
<%@ page isELIgnored="true/false" %>
Her representerer true / false verdien av EL om den skal ignoreres eller ikke.
Eksempel:
<%@ page language="java" contentType="text/html;" pageEncoding="ISO-8859-1"isELIgnored="true"%>
Forklaring av koden:
I koden ovenfor er isELIgnored sant, og ekspresjonsspråk (EL) blir derfor ignorert her.
I eksemplet nedenfor bruker vi fire attributter (kodelinje 1-2)
Eksempel med fire attributter
<% @ sidespråk = "java" contentType = "text / html;" pageEncoding = "ISO-8859-1"isELIgnored = "false"%><% @ side import = "java.util.Date"%>Direktiv Guru JSP1 Dato er: <% = ny java.util.Date ()%>