Wenn für geschützte Inhalte eine Authentifizierung der Benutzerinformationen erforderlich ist, muss die AIR-Anwendung diese Informationen in der Regel über eine Benutzeroberfläche vom Benutzer einholen.
Im Folgenden wird ein Flex-Beispiel für eine einfache Benutzeroberfläche für das Einholen von Benutzerinformationen dargestellt. Es besteht aus einem Bedienfeldobjekt, das zwei TextInput-Objekte umfasst, eines für den Benutzernamen und eines für das Kennwort. Außerdem enthält das Bedienfeld eine Schaltfläche, mit der die Methode
credentials()
gestartet wird.
<mx:Panel x="236.5" y="113" width="325" height="204" layout="absolute" title="Login">
<mx:TextInput x="110" y="46" id="uName"/>
<mx:TextInput x="110" y="76" id="pWord" displayAsPassword="true"/>
<mx:Text x="35" y="48" text="Username:"/>
<mx:Text x="35" y="78" text="Password:"/>
<mx:Button x="120" y="115" label="Login" click="credentials()"/>
</mx:Panel>
credentials()
ist eine benutzerdefinierte Methode, die die Werte für den Benutzernamen und das Kennwort an die
setDRMAuthenticationCredentials()
-Methode übergibt. Sobald die Werte übergeben wurden, setzt die
credentials()
-Methode die Werte der TextInput-Objekte zurück.
<mx:Script>
<![CDATA[
public function credentials():void
{
videoStream.setDRMAuthenticationCredentials(uName, pWord, "drm");
uName.text = "";
pWord.text = "";
}
]]>
</mx:Script>
Ein Verfahren zur Implementierung einer solchen einfachen Benutzeroberfläche ist die Aufnahme des Bedienfelds als Teil eines neuen Zustands. Der neue Zustand löst den Grundzustand ab, wenn das DRMAuthenticateEvent-Objekt ausgelöst wird. Das folgende Beispiel enthält ein VideoDisplay-Objekt mit einem Quellattribut, das auf eine geschützte FLV-Datei verweist. In diesem Fall wird die
credentials()
-Methode so modifiziert, dass sie auch die Anwendung in den Grundzustand zurückversetzt, und zwar nach dem Übergeben der Benutzerinformationen und Zurücksetzen der Werte für das TextInput-Objekt.
<?xml version="1.0" encoding="utf-8"?>
<mx:WindowedApplication xmlns:mx="http://www.adobe.com/2006/mxml"
layout="absolute"
width="800"
height="500"
title="DRM FLV Player"
creationComplete="initApp()" >
<mx:states>
<mx:State name="LOGIN">
<mx:AddChild position="lastChild">
<mx:Panel x="236.5" y="113" width="325" height="204" layout="absolute"
title="Login">
<mx:TextInput x="110" y="46" id="uName"/>
<mx:TextInput x="110" y="76" id="pWord" displayAsPassword="true"/>
<mx:Text x="35" y="48" text="Username:"/>
<mx:Text x="35" y="78" text="Password:"/>
<mx:Button x="120" y="115" label="Login" click="credentials()"/>
<mx:Button x="193" y="115" label="Reset" click="uName.text='';
pWord.text='';"/>
</mx:Panel>
</mx:AddChild>
</mx:State>
</mx:states>
<mx:Script>
<![CDATA[
import flash.events.DRMAuthenticateEvent;
private function initApp():void
{
videoStream.addEventListener(DRMAuthenticateEvent.DRM_AUTHENTICATE,
drmAuthenticateEventHandler);
}
public function credentials():void
{
videoStream.setDRMAuthenticationCredentials(uName, pWord, "drm");
uName.text = "";
pWord.text = "";
currentState='';
}
private function drmAuthenticateEventHandler(event:DRMAuthenticateEvent):void
{
currentState='LOGIN';
}
]]>
</mx:Script>
<mx:VideoDisplay id="video" x="50" y="25" width="700" height="350"
autoPlay="true"
bufferTime="10.0"
source="http://www.example.com/flv/Video.flv" />
</mx:WindowedApplication>