Programrendszerek Fejlesztése 14/11 1. Az előző előadás tartalma: 2  Alkalmazásszerverek, alkalmazásszerverek felépítése  Java EE alkalmazások és modulok.

Slides:



Advertisements
Hasonló előadás
Tamás Kincső, OSZK, Analitikus Feldolgozó Osztály, osztályvezető A részdokumentumok szolgáltatása az ELDORADO-ban ELDORADO konferencia a partnerkönyvtárakkal.
Advertisements

Windows Communication Foundation (WCF)

Kamarai prezentáció sablon
RESTful Web Service tesztelése
Hálózati és Internet ismeretek
Tempus S_JEP Számítógép hálózatok Összefoglalás Összefoglalás Összeállította: Broczkó Péter (BMF)
1. Előadás WCF- bemutatás
Client Access Server. Autodiscovery service Availability service (EWS) Offline Address Book (OAB) service Activesync service Outlook Web Access Public.
Erőállóképesség mérése Találjanak teszteket az irodalomban
OE-NIK HP Haladó Programozás Windows Communication Foundation A szolgáltatás, a hoszt és az ügyfél elkészítése.
4. Web Szolgáltatások Dr. Bilicki Vilmos Szegedi Tudományegyetem
Webszolgáltatások PHP-ben
Humánkineziológia szak
Mellár János 5. óra Március 12. v
2010/2011.Huszár István1. dia Weboldalak tervezése II. (X)HTML.
A tételek eljuttatása az iskolákba
.NET web szolgáltatások
UNIVERSITY OF SZEGED D epartment of Software Engineering UNIVERSITAS SCIENTIARUM SZEGEDIENSIS 11. Szolgáltatás Integráció Dr. Bilicki Vilmos Szegedi Tudományegyetem.
Ember László XUBUNTU Linux (ami majdnem UBUNTU) Ötödik nekifutás 192 MB RAM és 3 GB HDD erőforrásokkal.
Hernyák Zoltán XML validálás.
Védőgázas hegesztések
Osztott alkalmazások kezelése. VIR elosztott architektúra indítékai: - meglévő komponensek integrációja - WEB / Internet elterjedése (nemzetköziség) -
WEB Technológiák Dr. Pance Miklós – Kolcza Gábor Miskolci Egyetem.
WSDL alapismeretek A WSDL (Web Services Description Language – Web szolgáltatások leíró nyelv) egy XML-alapú nyelv a Web szolgáltatások leírására és azok.
OE-NIK HP Haladó Programozás WCF kivételkezelés. OE-NIK HP Haladó Programozás Windows Communication Foundation A szolgáltatás, a hoszt és az ügyfél elkészítése.
Haladó Programozás A webszolgáltatás fogalma
6. előadás Parametrikus polimorfizmus. Generikus programozás. Az Ada sablonok.
Önleíró adatok: XML INFO ÉRA, Békéscsaba
Szerkezeti elemek teherbírásvizsgálata összetett terhelés esetén:
Hálószolgáltatások (Web Services)
UDDI_1 UDDI alapok Forrás: 128.ibm.com/developerworks/webservices/library/ws-featuddi/ 128.ibm.com/developerworks/webservices/library/ws-featuddi/
Bevezetés az ebXML-be Forrás: An Introduction to ebXML ebXML and Web Services Practical Considerations In Implementing Web Services Romin IraniRomin Irani.
SOAP alapismeretek A SOAP egy egyszerű XML alapú protokoll, ami lehetővé teszi, hogy az alkalmazások információt cseréljenek a HTTP-én keresztül. Forrás:
WEB MES (webes gyártásirányító rendszer)
DRAGON BALL GT dbzgtlink féle változat! Illesztett, ráégetett, sárga felirattal! Japan és Angol Navigáláshoz használd a bal oldali léptető elemeket ! Verzio.
XML támogatás adatbázis-kezelő rendszerekben
Exchange Server 2007 Client Access Role
szakmérnök hallgatók számára
Budapest, június 28. Ontológia kezelő modul tervezése szöveges információt kezelő informatikai rendszer számára Förhécz András BME Méréstechnika.
LOGO Webszolgáltatások Készítette: Kovács Zoltán IV. PTM.
Sapientia - Erdélyi Magyar TudományEgyetem (EMTE) Csíkszereda IRT
2007. május 22. Debrecen Digitalizálás és elektronikus hozzáférés 1 DEA: a Debreceni Egyetem elektronikus Archívuma Karácsony Gyöngyi DE Egyetemi és Nemzeti.
Topológia felderítés hibrid hálózatokban
Weboldalak tervezése (X)HTML.
1 Hernyák Zoltán Programozási Nyelvek II. Eszterházy Károly Főiskola Számítástudományi tsz.
1 Hernyák Zoltán Web: Magasszintű Programozási Nyelvek I. Eszterházy.
Csurik Magda Országos Tisztifőorvosi Hivatal
A klinikai transzfúziós tevékenység Ápolás szakmai ellenőrzése
2006. május 15P2P hálózatok 1 Fóliák a vizsgára: 1. előadás  Bevezető: 11-16, 21,  Usenet: előadás:  Bevezető: 3-8  Napster: 
2006. Peer-to-Peer (P2P) hálózatok Távközlési és Médiainformatikai Tanszék.
QualcoDuna interkalibráció Talaj- és levegövizsgálati körmérések évi értékelése (2007.) Dr. Biliczkiné Gaál Piroska VITUKI Kht. Minőségbiztosítási és Ellenőrzési.
HTML5 alapú fejlesztő és futtató környezet megvalósítása
Komponens-absztrakció. Objektum-orientált paradigma korlátai Feltételezés az interfészekről: 1. öröklés és aggregáció alkalmazható, 2. közös programozási.
Java web programozás 11..
Webszolgáltatások Simon Balázs
1. Melyik jármű haladhat tovább elsőként az ábrán látható forgalmi helyzetben? a) A "V" jelű villamos. b) Az "M" jelű munkagép. c) Az "R" jelű rendőrségi.
Mérés és adatgyűjtés laboratóriumi gyakorlat - levelező Sub-VI és grafikonok 1 Mingesz Róbert V
Webszolgáltatás szabványok Simon Balázs
Adamkó Attila UML2 Adamkó Attila
Illés Zoltán ELTE Informatikai Kar
> aspnet_regiis -i 8 9 TIPP: Az „Alap” telepítés gyors, nem kérdez, de később korlátozhat.
A KÖVETKEZŐKBEN SZÁMOZOTT KÉRDÉSEKET VAGY KÉPEKET LÁT SZÁMOZOTT KÉPLETEKKEL. ÍRJA A SZÁMOZOTT KÉRDÉSRE ADOTT VÁLASZT, VAGY A SZÁMOZOTT KÉPLET NEVÉT A VÁLASZÍV.
Az XML nyelv (Extensible Markup Language). XML  XML: leíró nyelv (metanyelv)  XML alkalmazás: egy megalkotott nyelv  XML dokumentum: egy új nyelv egy.
.NET FRAMEWORK Röviden Krizsán Zoltán 1.0. Tulajdonságok I Rövidebb fejlesztés 20 támogatott nyelv (nyílt specifikáció) 20 támogatott nyelv (nyílt specifikáció)
Programozás III JPA.
Haladó Programozás A webszolgáltatás fogalma Szabványok és protokollok
Hálózatos programok készítése
Alkalmazott Informatikai Tanszék
JBoss Wildfly Kalla Mór
Előadás másolata:

Programrendszerek Fejlesztése 14/11 1

Az előző előadás tartalma: 2  Alkalmazásszerverek, alkalmazásszerverek felépítése  Java EE alkalmazások és modulok és kezelésük  Alkalmazásszerverek kezelése (monitoring, menedzsment)  Clustering, Jgroups  Alkalmazásszerverek biztonsága  Java Connector Architecture

Irodalom 3  IBM: Web Services Handbook for WebSphere Application Server Version 6.1

A mai előadás tartalma 4  Bevezető  Web Szolgáltatás szabványok  SOAP  WSDL  JAX-RPC  JEE – WS  UDDI  WS profilok  WS-Security  WS-Interoperability  Web Szolgáltatás architektúrák

Bevezető  Trendek  Integráció  Üzleti folyamatok teljes automatizálása (EDI)  Szolgáltatás Orientált Architektúra  Szolgáltatás gyártó  Szolgáltatás közvetítő  Szolgáltatás fogyasztó  Jellemzői  A kliens nem a szerverhez, hanem a szolgáltatáshoz kötődik  Az új és a régi komponensek blokkokba vannak csomagolva ezek web szolgáltatáson csatlakoznak  A komplex alkalmazásokon belül az üzleti logika el van különítve  Szolgáltatásokat futásidőben lehet cserélgetni  A csatolások konfigurációs fájlokban vannak definiálva 5

A SOA fő elemei  XML  SOAP  WSDL  WSIL  UDDI 6

A web szolgáltatások jellemzői  Önhordó  Önleíró  A weben keresztül van publikálva, fellelve és használva  Moduláris  Nyelv független  Nyílt szabvány  Lazán csatoltak  Dinamikusak  Programozható hozzáférést biztosítanak 7

Története  Web sikersztori  H2A működik  A2A nem igazán  1999: Microsoft XML alapú protokol: SOAP  IBM, Microsoft, Ariba: WSDL  Ma több mint 40 ajánlás/specifikáció 8

Web szolgáltatás szabványok 9

Alapvető szabványok  SOAP: Simpe Object Access Protocol  Struktúrált és típusos XML dokumentumok cseréjét írja le elosztott környezetben  Önhordó, önleíró  Alapesetben állapotmentes, egyirányú kommunikáció  WSDL: Web Service Description Language  A web szolgáltatást mind absztrakt végpontot definiálja  A műveletek és az üzenetek is megfelelő absztrakcióval vannak leírva  Az aktuális üzentekre építő protokoll pedig konkrét szolgáltatásokat specifikál  UDDI: Universal Description, Discovery, and Integration  Web szolgáltatások felderítése és publikálása 10

Leírás és felderítés  WS-Inspection: Web Services Inspection Language (WSIL)  UDDI nélküli felderítés  WS-Discovery  Többesküldés alapú web szolgáltatás felderítés  WS-MetadataExchange  Üzenetváltás a kezdeti infócseréhez (XSD,WSDL, WS-Policy)  WS-Policy  Szíbályok leírása (azonosítás, QoS, …)  WS-PolicyAssertions  Általános követelmény gyűjtemény (szöveg kódolás, …)  WS-PolicyAttachment  Kapcsolatok leírása  DNS Endpoint Discovery (DNS-EPD)  DNS alapú felderítés 11

Üzenetküldés  ASAP: Asynchronous Services Access Protocol  SOAP Messages with Attachments (SwA)  MIME kezelés  SOAP Message Transmission Optimization Mechanism  Szelektív kódolás  WS-Addressing  WS-Notification  Publish/Subscirbe  WS-Eventing  WS-Enumeration  WS-MessageDelivery  WS-ReliableMessaging  WS-Resources  WS-Transfer 12

Menedzsment  WSDM: Web Services Distributed Management  WS-Manageability  SPML: Service Provisioning Markup Language  WS-Provisioning 13

Üzleti folyamatok  BPEL: Business Process Execution Language  WS-CDL  WS-CAF 14

Tranzakciók  WS-Coordination (WS-COOR)  WS-Transaction  WS-AtomicTransaction (WS-AT)  WS-BusinessActivity (WS-BA) 15

Biztonság  XML-Encryption  XML-Signature  WS-Security  WS-SecureConversation  WS-SecurityPolicy  WS-Trust  WS-Federation  SAML: Security Assertion Markup Language 16

SOAP  XML alapú protokol  Envelope  Header  Body  Független az átviteli protokolltól (HTTP, JMS, FTP, …)  Jelenleg HTTP (WS-I Basic Profile 1.0)  Üzenetváltás minta (Message Exchange Pattern - MEP)  Egyirányú/Kétirányú 17

SOAP elemei  Boríték (Envelope)  Ez tárolja a többit  Vezérlő információk  Cím, …  Egy vagy több fejléc (Header)  Vezérlő információk (QoS)  Ki és hogyan kezelje az üzenetet?  Egy törzs (Body)  Üzenet azonosítás  Paraméterek  Mit csináljunk?  Kódolási szabályok  Megadja, hogy az adatot hogyan sorosítsuk  Programozási nyelv független adat séma (XSD) 18

Fejlécek  Általános és flexibilis mechanizmus a SOAP üzenetek kiterjesztésére  Nem szükséges a felek között előzetes egyeztetés  Előre definiált fejléc attribútum:  SOAP köztes entitás  A fejlécek egy része ezekhez az entitásokhoz szól  SOAP-ENV:actor  A hibák kezelése a MEP-től függ (mustUnderstand fault WS-I BP 1.0)  A fejlécek viszik át a biztonság, tranzakció, titkosítás,.. infókat is  Hordozhatnak kliens vagy projekt specifikus információkat is 19

WS-I konformancia fejléc 20

Törzs (Body)  A végső címzettnek szóló információcserére szolgáll  A Body elemen belül található XML elemek a test bejegyzések (body entries)  A bejegyzések egymástól függetlenül vannak kódolva  A legtöbb esetben a body tartalma:  Üzenet neve  Egy referencia a szolgáltatás példányra  Egy vagy több paraméter 21

Hibakezelés  A SOAP definiál egy body elemet erre a célra  Fault element (nulla vagy egy lehet belőle)  faultcode  soapenv:Client  soapenv:Server  sopaenv:VersionMismatch  soapenv:MustUnderstand  faultstring  Ember által értelmezhető szöveges leíárs  faultactor  Opcionális, a hiba forrását adja meg (URI)  A köztes elemeknek ezt kötelező kitöltenie  detail  Alkalmazás specifikus mező, opcionális 22

Adatmodell  Nyelvfüggetlen absztrakció  Egyszerű XSD típusok  Összetett típusok  Struktúrák  Tömbök (benne lehet struktúra vagy tömb, …)  A SOAP-ENC névtérben specifikálják az elemeket  A SOAP csak azt mondja meg, hogy hogyan lehet az adattípusokat megadni, azt nem hogy ezek milyenek 23

Tömbök 24

Kommunikációs stílusok  Dokumentum  Üzenet orientált stílus  Alacsonyabb absztrakciós megoldás  Az in paraméter egy XML dokumentum  A válasz bármi (vagy semmi)  RPC  Szinkron kommunikáció  Részei  A távoli objektum címe (URI)  A metódus neve  Paraméterek  Opcionális fejléc adatok 25

Kódolás/Üzenetváltás módok  A sorosítás, visszaállítás módját adja meg  Programozás nyelv független!  Típusai:  SOAP encoding (SOAP adat modell elemek)  Literal (XSD) – ezt támogatja a WS-I basic profile  Literal XML (nem használják)  Üzenetváltás módok  Document/Literal – a legjobb megoldás Java és nem Java alkalmazások együttműködésére  RPC/Literal – Java – Java  RPC/Encoded – régi java implementációk  Document/Encoded – Nem használt 26

SOAP megvalósítások 27

WSDL  XML alapú  Megadja, hogy  Mit csinál a web szolgáltatás  Hol tudjuk elérni  Hogyan lehet meghívni  A web szolgáltatás biztosítója megadhatja:  A nevét  A protokollt és a kódolást  Tipus információkat (műveletek, paraméterek, adattípusok) 28

A WSDL szerkezete  Types – adattípus definiciók tárolója. Pl.: XSD  Message – Az átküldött adat absztrakt típusos megadása  Port type – egy vagy több prot által támogatott absztrakt műveletek megadása  Operation – a szolgáltatás által támogatott akció leírása (kimenő/bejövő üzenet esetleg hiba)  Binding – Konkrét protkol és adatformátum egy adott prot típushoz. (protokol név, meghívási mód, szolgáltatás id, kódolás)  Service – összetratozó portok listája  Port – egy végpont kötés – hálózati cím összekapcsolása 29

types 30

message  Egy vagy több logikai részt tartalmaz  Egy interakciót ír le 31

Port type  Absztrakt műveletek és a felhasznált absztrakt üzenetek halmaza  Műveletek  Egyirányú  Kérés-Válasz  Megszólítás-Válasz  Értesítés 32

Bindings  Protokol specifikus általános csatoló adatok (pl.: SOAP kommunikációs stílus) 33

Service definition/port definition  Szolgáltatás  Összefog több portot egy név alatt  Port  Egy konkrét végpont egy konkrét címmel 34

WSDL csatolás típusok  Kiegészítő fejlécek  SOAP – binding, operation, body, fault, address, header, headerfault  HTTP – get/post (address, binding)  MIME – több részből állhat, … (content, multipartRelated, body, mimeXml)  EJB  JMS  … 35

JAX-RPC  Java API for XML based RPC  Programozás model a SOAP alapú alkalmazásokhoz  Leképezést biztosít a Java és a WSDL között  Java alkalmazás könnyedén kommunikálhat nem Java alkalmazással RPC alapon 36

JAX-RPC 37

WS kliensek  Statikus csonk  WSDL-ből generált csonkokat használ  Szolgáltatás végpont interfész (SEI)  Szolgáltatás interfész (hogyan kapjuk meg a SEI-t)  Szolgáltatás kereső osztály (hozzáférés a SEI-hez)  Kapcsolódó csonk (az aktuális hívásokat kezeli) 38

WS kliensek  Dinamikus proxy  A web szolgáltatás cím változhat 39

WS kliensek  Dinamikus hívó interfész  A WSDL változhat  Nem használ proxy fájlokat hanem a WSDL-t használja futás időben 40

Adat típus csatolás  Java-XML, XML-Java  Egyszerű típusok automatikusan  Egyes adatstruktúrákra is adott 41

Web Szolgáltatások JEE környezetben  WSEE  Hogyan valósítsuk meg a web szolgáltatásokat J2EE környezetben?  Kliens  Szerver  Web konténer  EJB konténer  Kezelők  Egy feldolgozási láncban kezelhetik a SOAP fejléceket  Tranzakció (a helyi tranzakciókat felfüggesztik)/Biztonság nincs (HTTPS, …) (?) 42

UDDI  Univerzális Leírás, Felderítés és Integráció  Segítségével egyszerűbbek a B2B tranzakciók  UDDI felépítés  Üzleti entitás  Üzleti szolgáltatás  Kötő minta  tModel  Takszonómia  Publákációs megjegyzések 43

Web Szolgáltatás biztonság  Tipikus problémák  Megoldások  TLS-SSL  WS-Security  Üzenet szintű biztonsági beállítások  Vég-Vég megoldás 44

WS-Security 45

Példa 46

WS-I Web Szolgáltatások együttműködése  A web szolgáltatás elvileg azért jó mert platform független, …  Sok SOAP megvalósítása  Sok szabványosítási testület (OASIS, IETF, W3C, …)  WS-I együttműködési minimum specifikálása  WS-I profilok  Implementációs javaslatok  Basic Profile v1.1 (pl.: document/literal vagy RPC/literal kötelező, SOAP/HTTP kötés, HTTP POST metódus, …)  Attachements Profile v1.0  Simple SOAP binding Profile v1.0  Basic Security Profile  Minta alkalmazások  Teszt eszközök 47

WS architektúra 48

MEP 49

SOAP modell 50

Összefoglaló  Bevezető  Web Szolgáltatás szabványok  SOAP  WSDL  JAX-RPC  JEE – WS  UDDI  WS profilok  WS-Security  WS-Interoperability  Web Szolgáltatás architektúrák 51

A következő előadás tartalma  Tervezési minták 52