Introduzione alle ASP:
primi passi negli script.
Frosini Andrea
e-mail: [email protected]
Università degli studi di Siena
Dipartimento di Scienze Matematiche ed Informatiche
Pagine Web statiche
Il Web nasce come una collezione di pagine HTML collegate tra
loro tramite links ipertestuali.
Quando nel Browser si indica un URL (Uniform Resource
Locator):
• il computer contatta il server HTTP basandosi sull’URL da noi
indicata (i nomi vengono tradotti in indirizzi IP dal servizio
distribuito DNS);
• il server HTTP cerca il file richiesto e, una volta trovato, invia il
file al richiedente;
• il computer, una volta ricevuto il file, lo esamina, lo elabora
(rendering) e lo mostra a video
Pagine Web dinamiche
Pagine il cui contenuto dipende dal contesto di esecuzione
• il browser invia al server Web, tramite URL, la richiesta di
attivazione di un programma seguita da una serie di parametri;
• il server Web riconosce che la richiesta deve essere indirizzata
all’applicazione e ne attiva una istanza con i parametri ricevuti;
• l’applicazione effettua l’elaborazione in base ai parametri e crea
sullo standard output, la risposta per il browser;
• il server Web cattura il flusso di dati generato dall’applicazione e
lo trasforma in pagina HTML.
Inizialmente le pagine dinamiche erano realizzate tramite lo standard
CGI (Common Gateway Interface), successivamente è stata data la
possibilità ai browsers di interpretare i linguaggi di scripting.
Linguaggi di scripting
Linguaggi come Jscript, VBscript, Perl che permettono al client di
effetture semplici elaborazioni.
Si avvicinano ai linguaggi di programmazione, pur caratterizzandosi
con una sintassi semplice e meno rigida.
Il codice di uno script si inserisce usualmente all’interno del codice
HTML, che riserva per questo i particolari tags <script> e </script>.
Script
• Uno script è composto da vari comandi di script.
• Un comando di script può assegnare un valore ad una variabile,
eseguire una operazione, avviare un processo di stampa …
• Affinchè uno script possa essere eseguito viene inviato ad uno
scripting engine che lo legge, riga per riga, e ne esegue i comandi.
• Ogni linguaggio di scripting ha bisogno del relativo scripting engine
installato sul server.
• Il client non necessita di uno scripting engine dato che tutto il carico
di lavoro è eseguito dal server.
Cosa è ASP
• ASP è l’acronimo per Active Server Pages;
• le pagine sono “attive” perché contengono istruzioni che ne
possono diversificare il contenuto finale;
• le pagine vengono scritte in HTML e salvate con estensione .asp;
• le pagine ASP hanno al loro interno un linguaggio di scripting;
• le pagine HTML di risposta alla richiesta di una ASP vengono
create sul momento
ASP non è un linguaggio di scripting
Come funziona ASP
• L’idea di base di ASP è quella di sfruttare la tecnologia COM
(Common Object Model), cioè sfruttare tutte le risorse che il
server Microsoft ha a disposizione, coinvolgendo i linguaggi di
scripting Vbscript e Jscript;
• il client richiede una pagina .asp al server. Il server invoca ASP
per elaborarla;
• vengono effettuati il parsing, il controllo sintattico e la
compilazione della pagina;
• il risultato è immerso nel codice HTML ed inviato al client.
Attenzione!
Per creare una pagina .asp è necessario:
• salvare il file in una directory visibile dalla rete;
• avere il permesso di esecuzione degli script.
N.B. una pagina ASP non può essere testata in locale a meno di non
aver installato un Personal Web Server (PWS)
Vantaggi e svantaggi di ASP
Vantaggi:
• Completa indipendenza dal particolare browser utilizzato
• Possibilità di usare più linguaggi di scripting all’interno di una
applicazione asp
• Comandi di script
Svantaggi:
• Notevole carico di lavoro per il server che deve generare
dinamicamente le pagine
• Tale soluzione contrasta con il modello CLIENT-SERVER
Sintassi ASP
Una pagina ASP è può essere composta da:
• testo;
• marcatori HTML;
• comandi di script.
E’ consentito utilizzare variabili, cicli ed istruzioni di controllo.
N.B. il creatore della pagina asp deve avere i permessi necessari
all’esecuzione degli script e delle query concessi dal server!
Dichiarare il linguaggio di scripting
ASP supporta in modo nativo due linguaggi: VBscript e Jscript.
Se non diversamente specificato, ASP interpreta quanto presente
all’interno dei tag <% e %> come VBscript.
Il linguaggio può essere dichiarato a livello di sito, di file o di
funzione (cioè la dichiarazione vale per tutte le applicazioni ASP
gestite dall’Internet Information Services (IIS), solo per quelle
legate ad un singolo file o solo per quelle legate ad una singola
funzione).
L’ulteriore attributo RUNAT permette di specificare il livello di
interpretazione dello script e assume i valori Server e Client.
Ricordiamoci che:
In VBScript sono disponibili i seguenti cicli:
• Do While … Loop: le istruzioni sono ripetute fino a quando una
condizione risulta True;
• While … Wend: le istruzioni sono ripetute fino a quando una
condizione risulta True;
• For … Next: le istruzioni sono ripetute un numero di volte
specificato da un contatore;
• For Each … Next: un insieme di istruzioni viene ripetuto per
ciascun elemento di un insieme. Tale numero puo’ non essere
noto a priori!
Esempi di semplici script (1)
<HEAD><TITLE>Evento associato ad un bottone</TITLE></HEAD>
<SCRIPT LANGUAGE="VBScript">
<!-Sub Bottone1_OnClick
MsgBox “Ciao Ciao.”
End Sub
--></SCRIPT>
<BODY>
<H3>Una semplice pagina di esempio</H3><HR>
<FORM>
<INPUT NAME="Bottone1" TYPE="BUTTON" VALUE="Fare clic qui">
</FORM></BODY>
Esempi di semplici script (2)
<SCRIPT><!-Sub Submit_OnClick
Dim TheForm
Set TheForm = Document.MioForm
If IsNumeric(TheForm.Testo1.Value) Then
If TheForm.Testo1.Value < 1 Or TheForm.Testo1.Value > 10 Then
MsgBox "Immettere un numero compreso tra 1 e 10."
Else MsgBox "Valore corretto."
End If
Else MsgBox "Immettere un valore numerico."
End If
End Sub
--></SCRIPT> …
Esempi di semplici script (3)
<FORM NAME=“MioForm”>
<INPUT TYPE=“Button” NAME =“Bottone1” VALUE="Click">
<SCRIPT FOR="Bottone1" EVENT = “onClick” LANGUAGE=“VBScript”>
MsgBox “Hai premuto il pulsante”
</SCRIPT>
</FORM>
<SCRIPT LANGUAGE="VBScript">
<!-Dim MyVar
MyVar = MsgBox ("Salve gente!", 65, "Esempio di MsgBox")
MsgBox ("Pulsante premuto "&MyVar)
</SCRIPT>
Esempi di semplici script (4)
<SCRIPT><!-Sub Esempio_ciclo()
Dim Contatore, Numero
Contatore = 0
Numero = 20
Do While Numero > 10
Numero = Numero - 1
Contatore = Contatore + 1
Loop
MsgBox “Il ciclo ha eseguito” & counter & “ ripetizioni.”
End Sub
--></SCRIPT> …
ASP: Esempio 1
<SCRIPT RUNAT=Server LANGUAGE=JSCRIPT>
function CiaoJS() {
Response.write(“Ciao da JScript")}
</SCRIPT>
<SCRIPT RUNAT=Server LANGUAGE=VBScript>
Sub CiaoVB
Response.write “Ciao da VBScript"
End Sub
</SCRIPT>
<html><HEAD><TITLE>Esempio Script lato server</TITLE></HEAD>
<body>
<% Call CiaoJS%><BR>
<% Call CiaoVB%>
</body>
</html>
Inclusione di file e commenti
Regole per l’inclusione di file:
• un file può includere altri file;
• un file non può includere sé stesso;
• un file può essere incluso più volte;
• non si possono creare dinamicamente nomi di file inclusi.
Sintassi
inclusione: <!--#include file
commento:
REM commento
‘ commento
= "file_da_includere"-->
Dichiarazione di variabili e cicli
Inizializzazione di una variabile:
pippo = 12
pluto = “Ciao mondo”
I cicli possono essere definiti usualmente:
for counter = 25 to 0 step -5
“Ciao mondo!<br>”
next
oppure
Do
"Ciao Mondo!<br>"
i = i + 1
Loop Until i > 5
La dichiarazione esplicita delle variabili nello script può essere
forzata utilizzando <% option explicit %>
Esempio 2
<HTML><HEAD><TITLE> Esempio variabili e cicli </TITLE></HEAD>
<BODY bgcolor="#FFFFFF">
<center> Calcolo dei quadrati e cubi dei primi 5 numeri <br><br>
<table border = 2>
<tr>
<td> Numero <td> Quadrato <td> Cubo ‘ intestazione tabella
</tr>
<% dim i
‘ dichiarazione variabile
i=5
for num = 1 to i %>
‘ variabile non dichiarata
<tr align=center>
<td><%=num%> <td><%=num*num%> <td><%=num*num*num%>
</tr>
<% next %>
</center>
</BODY></HTML>
Definire e richiamare procedure
Le procedure all’interno di una Active Server Page
• possono essere scritte con linguaggi di scripting diversi (seguendone,
ovviamente, la sintassi);
• possono essere definite su file esterni inclusi;
• sono richiamate con il comando Call Nome_procedura
• dopo il nome della procedura, tra parentesi, possono essere inseriti
gli eventuali parametri;
Esercizio
Piccolo esercizio:
• creare un file con estensione .inc che contenga una procedura
per stampare il carattere “ * ” ed una seconda procedura per
stampare il carattere “ ^ ” ;
• creare un file con estensione .asp che:
• includa il file .inc creato;
• visualizzi un triangolo rettangolo di altezza 9, formato
dalla sequenza di simboli “ *^* ” richiamati tramite le
procedure contenute nel file incluso.
Esempio 3
<% @LANGUAGE = VBScript %>
<% Option Explicit
Response.ContentType = "text/html"
Response.Expires = -1500 %>
… <%= date %> … <%= time %>
Informazioni dal browser
<%=Request.ServerVariables("SCRIPT_NAME")%>
<%=Request.ServerVariables("SERVER_PORT")%>
<%=Request.ServerVariables("REMOTE_HOST")%>
<%=Request.ServerVariables("HTTP_HOST")%>
<%=Request.ServerVariables("REMOTE_ADDR")%>
<%=Request.ServerVariables("HTTP_USER_AGENT")%>
<%=Request.ServerVariables("HTTP_ACCEPT_LANGUAGE")%>
Creare moduli
Lo scambio di dati tra client e server avviene essenzialmente tramite
i moduli (form) caratterizzati da:
•Campi: elementi da riempire con l’input che si desira spedire al
server;
•Bottoni: permettono l’invio (submit) o la cancellazione (reset) dei
dati inseriti nei campi;
•CGI (Common Gateway Interface): programmi lato server (Java,
C++, Perl …) che leggono ed elaborano i dati inviati,
fornendo al client la risposta tramite una pagina HTML di
formato standard.
Il tag <form>
Il tag per la creazione di moduli è <form> </form>
I suoi attributi di interesse sono
•Action: specifica l’azione che dovrà essere fatta al momento
dell’invio dei dati (caricamento di una pagina,
reindirizzamento verso una specifica URL, specifica della
risorsa che dovrà elaborare i dati inviati …)
•Method: specifica il modo di invio al server dei dati. I valori
ammessi sono get e post.
I metodi GET e POST
Inviando una form il client invia coppie del tipo nome=valore.
Il metodo GET è indicato per il passaggio di pochi valori che
vengono specificati al programma CGI sulla linea di comando.
Tali valori possono essere solo di tipo testuale, ad esempio
http://localhost/cgi-bin/script?nome=andrea&cognome=frosini
Il metodo POST è indicato per il passaggio di grandi quantità di dati
di qualsiasi tipo (testi, immagini, video). Viene eseguito solo in
risposta ad una form ed i parametri non passano in chiaro nella URL.
I dati vengono passati nel corpo del pacchetto HTTP.
Il tag <input />
Gli attributi del tag <input /> permettono le diverse modalità di
inserimento dati. Ad esempio:
•text, password, hidden permettono l’inserimento di righe di testo;
•textarea permette l’inserimento di aree di testo;
•select elemento di selezione multipla;
•radio e checkbox bottoni di invio dati;
•submit e reset bottoni di invio e cancellazione dati.
Esempio: <input type=“text” name=“saluto” value=“ciao” />
Ad ogni elemento è possibile associare un nome univoco ed un valore
di default
Cosa ci interessa?
La gestione dei form può risultare complessa, per questo noi ci
limiteremo quasi esclusivamente all’utilizzo
• del formato di invio POST;
• del tipo TEXT;
• dei bottoni di SUBMIT e RESET.
Esercizio:
Creare una pagina .html che includa un bottone per caricare una
seconda pagina .html per visualizzare la scritta “Ciao”.
Esempio 3: saluto.html
<HTML><HEAD><TITLE>Esempio saluto</TITLE></HEAD>
<BODY><center>Invio dati personali studente</center><br>
<FORM METHOD=POST ACTION="salve.asp">
<TABLE>
<TR>
<TD align=right>Nome:</TD>
<TD align=left><INPUT TYPE=TEXT NAME="nome"></TD>
</TR>
<TR>
<TD>
<TD align=left>
Maschio <INPUT type="RADIO" name="sesso" value="Maschio">
Femmina <INPUT type="RADIO" name="sesso" value="Femmina">
</TR>
</TABLE>
<INPUT TYPE=RESET> <INPUT TYPE=SUBMIT>
</FORM></BODY></HTML>
Esempio 3: salve.asp
<%@ Language=VBScript %>
<HTML><BODY>
<center><h3> Salve <br>
<%
strsesso=request.form("sesso")
pippo=request.form("nome")
%>
<% If (strsesso="Femmina") Then %>
Sig.ra
<%End If%>
<%If (strsesso="Maschio") Then %>
Sig.
<% End If %>
<%=pippo%>
</h3></center></BODY></HTML>
Esempio 4: esercizio
Esempio / esercizio:
• creare una pagina contenente un form per l’inserimento dei dati
di uno studente che contenga i campi testuali:
ID studente, Nome, Cognome, Citta’, Stato, CAP;
• inviare il form con il metodo post;
• l’invio del form deve caricare, in risposta, una pagina che
visualizzi i dati inseriti;
• eventualmente creare un controllo sui campi inseriti.
Scarica

End Sub - Dipartimento di Scienze Matematiche e Informatiche R