LUIZ WAGNER ARAÚJO NUNES IMPLEMENTAÇÃO DE UM WEB SERVICE PARA UMA LOCADORA DE VEÍCULOS - RELAÇÃO B2B Palmas 2006.1 LUIZ WAGNER ARAÚJO NUNES IMPLEMENTAÇÃO DE UM WEB SERVICE PARA UMA LOCADORA DE VEÍCULOS - RELAÇÃO B2B “Trabalho apresentado ao curso de Sistemas de Informação do Centro Universitário Luterano de Palmas como requisito parcial da disciplina de Trabalho de Conclusão de Curso em Sistemas de Informação, orientado pela professora Madianita Bogo” Palmas 2006.1 LUIZ WAGNER ARAÚJO NUNES IMPLEMENTAÇÃO DE UM WEB SERVICE PARA UMA LOCADORA DE VEÍCULOS - RELAÇÃO B2B “Trabalho apresentado ao curso de Sistemas de Informação do Centro Universitário Luterano de Palmas como requisito parcial da disciplina de Trabalho de Conclusão de Curso em Sistemas de Informação, orientado pela professora Madianita Bogo” BANCA EXAMINADORA _______________________________________ Profª. M.Sc. Madianita Bogo Centro Universitário Luterano de Palmas _______________________________________ Fabiana Ferreira Cardoso Centro Universitário Luterano de Palmas _______________________________________ Prof. M.Sc. Ricardo Marx Costa Soares de Jesus Centro Universitário Luterano de Palmas 4 SUMÁRIO 1. INTRODUÇÃO.......................................................................................................... 10 2. REVISÃO DE LITERATURA ................................................................................. 12 2.1. Sistemas Distribuídos .......................................................................................... 12 2.1.1. Modelo Cliente/Servidor ................................................................................. 13 2.2. RMI...................................................................................................................... 14 2.3. CORBA ............................................................................................................... 15 2.4. Web Service ......................................................................................................... 17 2.4.1. WSDL.............................................................................................................. 18 2.4.2. UDDI ............................................................................................................... 22 2.4.3. JWSDP ............................................................................................................ 25 2.4.3.1. JAX-RPC..................................................................................................... 25 2.4.3.1.1. Desenvolvimento do Servidor ..................................................................... 26 2.4.3.1.2. Desenvolvimento do Cliente ....................................................................... 31 2.5. B2B...................................................................................................................... 33 2.6. Web Services em B2B.......................................................................................... 34 3. MATERIAL E MÉTODOS ...................................................................................... 36 3.1. Material................................................................................................................ 36 3.1.1. Hardware......................................................................................................... 36 3.1.2. Software........................................................................................................... 37 3.2. Métodos ............................................................................................................... 38 4. RESULTADOS E DISCUSSÃO............................................................................... 39 4.1. Domínio ............................................................................................................... 39 4.2. Comunicação das Aplicações .............................................................................. 40 4.3. Modelagem do Web Service ................................................................................ 42 4.3.1. Funcionalidades do Web Service ..................................................................... 42 4.3.2. Diagrama de Classes........................................................................................ 43 4.4. Considerações sobre o serviço............................................................................. 45 4.4.1. Questão Legal do Serviço ................................................................................ 46 4.5. Implementação do Serviço .................................................................................. 47 4.6. Implementação do Cliente ................................................................................... 49 5. CONSIDERAÇÕES FINAIS .................................................................................... 53 6. REFERÊNCIAS BIBLIOGRÁFICAS..................................................................... 55 ANEXOS ......................................................................................................................... 57 ANEXO I: MODELAGEM DO WEB SERVICE ............................................................ 58 ANEXO II: IMPLEMENTAÇÃO DO WEB SERVICE .................................................. 77 ANEXO III: IMPLEMENTAÇÃO DA APLICAÇÃO CLIENTE................................ 100 5 LISTA DE FIGURAS Figura 1 - Estrutura do modelo Cliente/Servidor – adaptada de Horstmann (2003). .......... 13 Figura 2 - Estrutura de comunicação do padrão CORBA, modificada de Riccioni (2000). 15 Figura 3 – Exemplo de um documento WSDL. .................................................................. 20 Figura 4 – Exemplo de Interface de um Web Service com JAX-RPC. ............................... 27 Figura 5 – Exemplo de Classe de Implementação de um Web Service com JAX-RPC. .... 28 Figura 6 – Documento XML utilizado pelo aplicativo wscompile. .................................... 29 Figura 7 – Documento XML utilizado pelo aplicativo jar. ................................................. 30 Figura 8 – Documento XML utilizado pelo aplicativo wsdeploy. ...................................... 30 Figura 9 – Exemplo de Classe de Implementação de um Cliente JAX-RPC. ..................... 32 Figura 10 - Arquitetura de Comunicação da Aplicação Cliente com o Web Service .......... 41 Figura 11 – Diagrama de Casos de Uso............................................................................... 43 Figura 12 – Diagrama de Classes do Web Service............................................................... 44 Figura 13 – Implementação da Interface do Web Service.................................................... 48 Figura 14 – Fragmento de Código do Arquivo veiculos.php. ............................................. 50 6 LISTA DE TABELAS Tabela 1: Pilha Básica de Web Services – disponível em Hendricks (2002)....................... 17 7 LISTA DE ABREVIATURAS API Application Programming Interface B2B Business-to-business CORBA Common Object Request Broker Architecture ebXML Eletronic Business Extensible Markup Language FTP File Transfer Protocol HTTP HyperText Transfer Protocol HTTPS HyperText Transfer Protocol Secure IDL Interface Definition Language ISO International Organization for Standardization JWSDP Java Web Service Developer Pack NAICS North American Industry Classification System 8 ORB Object Request Broker RPC Remote Procedure Call SMTP Simple Mail Transfer Protocol SOAP Simple Object Access Protocol TCP/IP Transfer Control Protocol/Internet Protocol UDDI Universal Description, Discovery and Integration W3C World Wide Web Consortium WSDL Web Service Description Language XML Extensible Markup Language 9 RESUMO A crescente demanda na utilização da Internet para a comunicação entre empresas fez surgir uma nova modalidade de comércio eletrônico, denominada Business-to-business (B2B), na qual as empresas integram suas aplicações com o intuito de intercambiar as informações, possibilitando a realização dos processos de negócio. A tecnologia de Web Services surgiu com a promessa de permitir que aplicações desenvolvidas em plataformas e linguagens de programação distintas possam se integrar, garantindo a interoperabilidade entre as aplicações, o que é interessante quando se fala em comunicação entre aplicações de empresas distintas. O objetivo deste trabalho é realizar um estudo da tecnologia de Web Services analisando a sua utilização na modalidade de comércio eletrônico Business-tobusiness, realizando um estudo teórico dos conceitos relacionados ao tema e testes práticos da integração de aplicações desenvolvidas em linguagens distintas. 10 1. INTRODUÇÃO A Internet tem sido utilizada principalmente para o relacionamento entre pessoas e para o comércio eletrônico, em que as pessoas passaram a se relacionar com as empresas surgindo esta nova modalidade de comércio. Nos últimos anos, é notável também uma crescente utilização da Internet para a troca de informações entre empresas, as quais são tidas como parceiras comerciais, buscando a integração de suas aplicações para a manutenção desta forma de comunicação. Da parceria entre empresas surgiu a modalidade de comércio eletrônico denominada Business-to-business (B2B), definindo o comércio entre empresas realizado através da troca de informações pela Internet. Várias tecnologias surgiram para aprimorar e permitir mais facilidade na comunicação entre as aplicações das empresas, dentre elas o padrão RMI, o CORBA e a tecnologia de Web Services. A tecnologia de Web Services traz a promessa de permitir e facilitar a comunicação entre aplicações desenvolvidas em linguagens de programação e plataformas distintas, prometendo também possibilitar interoperabilidade entre tais aplicações, o que é interessante quando se fala em comunicação entre aplicações de empresas distintas. Com base neste cenário, em que é crescente a demanda pela integração de aplicações dado o surgimento desta nova modalidade de comércio eletrônico, pensou-se em desenvolver um estudo da tecnologia de Web Services e sua relação com o Business-to-business, uma vez que foi notado que é um assunto pouco discutido. O objetivo deste trabalho é estudar a tecnologia de Web Services, buscando levantar suas características, fazendo um breve estudo das demais tecnologias a fim de possibilitar um 11 melhor entendimento. É parte também deste trabalho o estudo das características da modalidade comércio eletrônico Business-to-business, buscando principalmente relacionála com a tecnologia de Web Services, fazendo um levantamento teórico e a implementação de um exemplo prático nesta avaliação. Este trabalho está estruturado da seguinte forma: a seção 2 apresenta um levantamento das características das aplicações distribuídas, mencionando os modelos e as tecnologias existentes, buscando maior destaque das características da tecnologia de Web Services, sobretudo da API JAX-RPC, que integra o JWSDP, descrevendo os passos básicos para a criação de uma aplicação Servidora e uma aplicação Cliente. Exibe também um levantamento a respeito do Business-to-business, buscando relacioná-lo com a tecnologia de Web Services. A seção 3 contém a relação do material empregado e descreve os métodos utilizados no desenvolvimento do trabalho. A seção 4 mostra os resultados e uma discussão a respeito do que foi encontrado na literatura e dos testes práticos realizados, quando possível, fazendo uma relação entre os mesmos. A seção 5 expõe as considerações finais, descrevendo as conclusões a respeito do estudo realizado, apontando a utilização em trabalhos futuros. 12 2. REVISÃO DE LITERATURA 2.1. Sistemas Distribuídos Um sistema distribuído pode ser definido como um conjunto de computadores interconectados em rede com o objetivo principal de compartilhar recursos de hardware e software. Para Casetti (1993) “um sistema distribuído constitui-se de processadores autônomos conectados através de um subsistema de comunicação, que cooperam-se através de troca de mensagens.” Uma das vantagens advindas da utilização de um sistema distribuído é o compartilhamento de recursos. Assim, os recursos mantidos por uma estação servidora poderão ser utilizados por estações clientes, que solicitam os recursos através de uma rede de comunicação. Como proteção à ocorrência de falhas, sistemas distribuídos podem ser implantados com grande vantagem sobre os sistemas centralizados. A redundância de recursos de hardware e de software pode imprimir mais confiabilidade ao sistema como um todo: caso partes do sistema venham a falhar, o restante do sistema é capaz de continuar o processamento, ao contrário de um sistema centralizado em que uma falha comprometeria todo o sistema. Por fim, como um sistema distribuído está disseminado em uma rede, sua abrangência é uma grande vantagem sobre um sistema centralizado, uma vez que pode atingir grandes distâncias geográficas. Tanenbaum (1992) menciona a capacidade de crescimento incremental dos sistemas distribuídos. A escalabilidade permite que novas unidades processadoras possam ser adicionadas, visando aumentar o poder de processamento do conjunto, sem que sejam 13 necessárias alterações na configuração do sistema e interrupções no funcionamento no momento das alterações. Um dos modelos de sistemas distribuídos mais difundidos e citados na literatura é o modelo Cliente/Servidor. A seção 2.1.1 apresenta o conceito e descreve o funcionamento deste modelo. 2.1.1. Modelo Cliente/Servidor Segundo Riccioni (2000), o modelo Cliente/Servidor de computação distribuída é um modelo de gerenciamento de informação que divide o processamento entre um computador que requer um serviço e outro que devolve o serviço. Como em sistemas distribuídos não existe região de memória compartilhada, os processos se comunicam através de mecanismos de troca de mensagens. A programação de socket e a chamada de procedimento remoto (RPC – Remote Procedure Call) são mecanismos utilizados nas trocas de mensagens. A Figura 1 ilustra a transmissão de mensagens no modelo Cliente/Servidor. Cliente Servidor solicitação resposta Figura 1 - Estrutura do modelo Cliente/Servidor – adaptada de Horstmann (2003). Na estrutura apresentada na Figura 1, os retângulos identificados como Cliente e Servidor representam as aplicações Cliente e Servidor, respectivamente, dentro do modelo 14 Cliente/Servidor. De uma maneira simplificada, o Cliente envia uma mensagem de solicitação para o Servidor, que realiza o processamento e retorna uma mensagem de resposta para o Cliente. Com o advento do paradigma de orientação a objetos, foram idealizados objetos colaborativos localizados em ambientes remotos, capazes de interagir através de mecanismos de troca de mensagens. Com isso, surgiram os padrões RMI (Remote Method Invocation – Invocação de Método Remoto) e CORBA (Common Object Request Broker Architecture – Arquitetura de Agentes de Requisição de Objetos Comum). Esses padrões serão discutidos nas seções 2.2 e 2.3. 2.2. RMI O padrão RMI foi uma iniciativa da empresa Sun Microsystems. Escrito na linguagem de programação Java, esse padrão possibilita a comunicação entre objetos residentes em máquinas virtuais java (JVM – Java Virtual Machine), que podem estar localizadas em computadores distintos ou não. Com o RMI, a invocação de métodos de um objeto remoto parece simples para o desenvolvedor. Os detalhes de comunicação ficam ocultos. Assim, o desenvolvedor tem a impressão de que está realizando a chamada de métodos de um objeto local. “Ao invocar um método sobre um objeto remoto, o cliente RMI atua, na realidade, sobre um objeto local que se faz passar pelo objeto remoto. Esse objeto local é chamado stub. O stub age como um proxy do objeto remoto e esconde do cliente o uso dos serviços providos pelos protocolos de transporte. Por serem gerados por um compilador chamado rmic, os desenvolvedores de um programa RMI não têm que se preocupar em codificar os stubs” (ALBUQUERQUE, 2001). Os serviços oferecidos pelo Servidor são descritos através de um arquivo Java que implementa uma interface. A interface contém a assinatura dos métodos disponibilizados pelo Servidor. Desta forma, o Cliente descobre os métodos analizando a interface do Serviço. 15 Apesar de escrito em Java, uma linguagem prometida para ser “quase perfeita” em termos de portabilidade, como leciona Riccioni (2000), o RMI é limitado exatamente em sistemas heterogêneos no tocante à interação com objetos desenvolvidos em outras linguagens. Ao contrário disto, o padrão CORBA promete possibilitar a integração entre aplicações heterogêneas. O padrão CORBA será discutido na seção seguinte. 2.3. CORBA Conforme citado por Horstmann (2003), “o padrão CORBA permite a comunicação entre objetos escritos em diferentes linguagens de programação. (...) Ele define um mecanismo comum para troca de dados e descoberta de serviços”. A especificação CORBA tem sido implementada por diversas linguagens de programação. Os programas Cliente e Servidor podem ser desenvolvidos em linguagens de programação distintas, como Java e C++, por exemplo. A especificação CORBA define um Agente de Requisição de Objetos (ORB – Object Request Broker) que é responsável por intermediar a comunicação entre objetos remotos. “O ORB é responsável pela localização do objeto ao qual se destina a requisição, assim como o envio dos parâmetros da requisição no formato aceito por este objeto. (...) Também é função do ORB, o retorno de parâmetros de saída da requisição para o cliente, se assim houver” (RICCIONI, 2000). A Figura 2 apresenta a estrutura da comunicação do padrão CORBA. Cliente Servidor ORB Rede ORB Figura 2 - Estrutura de comunicação do padrão CORBA, modificada de Riccioni (2000). A estrutura de comunicação apresentada na Figura 2 pode ser entendida da seguinte forma: primeiramente o Cliente obtém uma referência ao objeto remoto, através do ORB, e então 16 faz a invocação de um método do objeto remoto. Em seguida, O ORB converte os parâmetros do método em um formato independente de plataforma, e envia-os através da rede ao ORB do Servidor. O ORB do Servidor recebe os parâmetros e decodifica-os, repassando a chamada do método ao Servidor. Após o processamento da chamada, o Servidor envia a resposta com os parâmetros ao ORB, que faz a codificação e envia ao ORB do Cliente. Por fim, o ORB do Cliente decodifica os parâmetros de saída e repassa-os ao Cliente. A padronização do protocolo de comunicação e do formato das mensagens em um sistema distribuído é um ponto importante para a interação entre objetos distribuídos, principalmente na interação entre objetos heterogêneos. O formato e o modo de transmissão das mensagens devem possibilitar que o objeto do Cliente possa enviar as mensagens de forma que o objeto do Servidor possa recebê-las e processá-las. A definição do formato das mensagens e dados para a comunicação entre ORB’s é papel do Protocolo Inter-ORB Geral (GIOP). A forma de transmissão das mensagens numa rede TCP/IP é papel do Protocolo Inter-ORB Internet (IIOP). A descrição do objeto Servidor, que atenderá às requisições dos objetos Clientes, está contida em um documento que apresenta a assinatura dos métodos disponibilizados pelo objeto Servidor e os tipos de dados que podem ser enviados e recebidos através das mensagens. A linguagem utilizada para desenvolvimento deste documento é a linguagem de definição de interface (IDL – Interface Definition Language). Um documento IDL é bem semelhante a uma interface definida na linguagem de programação Java, e possui a extensão .idl. No tocante à interação entre aplicações comerciais na Internet, visando a integração de parceiros comerciais, uma nova tecnologia surgiu buscando proporcionar maior interoperabilidade entre as aplicações. A tecnologia de Web Services têm recebido muitos incentivos por parte de grandes empresas como Microsoft e IBM. Na seção 2.4 será apresentada a tecnologia de Web Services. 17 2.4. Web Service Um Web Service representa uma aplicação auto-descritiva que é capaz de responder a solicitações de outras aplicações, independentemente da linguagem e da plataforma em que estas foram desenvolvidas, fazendo uso de tecnologias padrão, tais como os protocolos da Internet, como HTTP, e a linguagem XML. Além da capacidade de responder a solicitações, um Web Service também pode fazer solicitações a outros Web Services, exercendo assim o papel de aplicação cliente ou consumidora. Conceitualmente, a estrutura de um Web Service pode ser representada na forma de uma pilha. De acorco com Hendricks (2002), a pilha é formada por 4 camadas. A tabela 1 apresenta as camadas associando-as às respectivas tecnologias. Tabela 1: Pilha Básica de Web Services – disponível em Hendricks (2002). Publicação e Descoberta do Serviço UDDI (Service Publication/Discovery) Descrição do Serviço (Service WSDL Description) Troca de Mensagens XML – SOAP (XML SOAP Messaging) Rede de Transporte (Transport Network) HTTP, SMTP, FTP, HTTPS over TCP/IP Um Web Service pode ter seus dados publicados em um registro de negócios, tais como o registro UDDI (Universal Description, Discovery and Integration – Descrição, Descoberta e Integração Universais). A especificação UDDI padroniza um modelo de repositório de registro de Web Services públicos e dos negócios que os representam. Através do registro clientes e parceiros de negócios podem integrar suas aplicações buscando as descrições dos Web Services registrados. Além da especificação UDDI, mencionada por Hendricks (2002), a especificação ebXML também padroniza um modelo de repositório. Mais abrangente do que a especificação UDDI, ela é dirigida a registros de negócios, cujas empresas podem possuir Web Services implementados. A especificação UDDI será apresentada com maior profundidade na seção 2.4.2. 18 Um diferencial importante dos Web Services sobre as demais tecnologias de sistemas distribuídos é a forma de descrição. A descrição de um Web Service apresenta os métodos disponibilizados, os parâmetros de entrada e saída e a localização e o nome do serviço. Para a descrição é utilizado um documento escrito na Linguagem de Descrição de Web Services (WSDL – Web Services Description Language). Este documento é um documento XML cujo esquema segue as regras da WSDL. A WSDL será discutida com mais detalhes na seção 2.4.1. As mensagens trocadas entre o Web Service e os Clientes são convertidas nos formatos definidos pelo protocolo escolhido para a comunicação. Dentre os protocolos está o protocolo SOAP (Simple Object Access Protocol – Protocolo Simples de Acesso ao Objeto), o qual acondiciona a mensagem em um documento XML. O protocolo SOAP pode ser utilizado no mecanismo de troca de mensagens baseado em RPC ou baseado em troca de documentos. Por fim, as mensagens são transportadas fazendo uso de um dos protocolos de Internet, como por exemplo, HTTP, SMTP etc. Segundo Hendricks (2002), o mais utilizado é o protocolo HTTP (Hypertext Transfer Protocol – Protocolo de Transferência de Hipertexto). O uso destes protocolos, e principalmente do HTTP, é devido ao fato de que os mesmos geralmente são utilizados por várias aplicações e, além disso, comumente estão habilitados nos firewalls, o que facilita a utilização da tecnologia de Web Services. Neste trabalho, o Web Service desenvolvido utiliza a API JAX-RPC, integrante do JWSDP, a qual utiliza o protocolo SOAP para troca de mensagens e o protocolo HTTP para o transporte. 2.4.1. WSDL A sigla WSDL é utilizada para referenciar o documento que descreve um Web Service. Este documento, que é um documento XML, tem por finalidade apresentar os detalhes do Web Service. Ao contrário do que é utilizado nos padrões RMI e CORBA, o documento WSDL é mais complexo devido aos detalhes que especifica, como endereço real do serviço, definição da estrutura das mensagens de solicitação e resposta de cada uma das operações 19 disponibilizadas pelo Web Service etc. A sua estrutura é constituída de 5 elementos básicos: types, message, portType, binding e service (TODD, 2003). A escrita de um documento WSDL pode ser uma tarefa bastante complexa, a depender da quantidade de operações disponibilizadas pelo Web Service, dos parâmetros de entrada e saída, e dos tipos de dados utilizados nas mensagens. Normalmente, os aplicativos que possibilitam o desenvolvimento de Web Services disponibilizam ferramentas capazes de gerar este documento com base na interface desenvolvida e na localização e no nome que referencia o serviço. A Figura 3 apresenta um exemplo de um documento WSDL. 20 1. <?xml version="1.0" encoding="UTF-8" ?> 2. <definitions xmlns="http://schemas.xmlsoap.org/wsdl/" xmlns:tns="urn:Foo" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:soap="http://schemas.xmlsoap.org/wsdl/soap/" name="Hello" targetNamespace="urn:Foo"> 3. <types /> 4. <message name="HelloIF_sayHello"> 5. <part name="String_1" type="xsd:string" /> 6. </message> 7. <message name="HelloIF_sayHelloResponse"> 8. <part name="result" type="xsd:string" /> 9. </message> 10. <portType name="HelloIF"> 11. <operation name="sayHello" parameterOrder="String_1"> 12. <input message="tns:HelloIF_sayHello" /> 13. <output message="tns:HelloIF_sayHelloResponse" /> 14. </operation> 15. </portType> 16. <binding name="HelloIFBinding" type="tns:HelloIF"> 17. <soap:binding transport="http://schemas.xmlsoap.org/soap/http" style="rpc" /> 18. <operation name="sayHello"> 19. <soap:operation soapAction="" /> 20. <input> 21. <soap:body encodingStyle="http://schemas.xmlsoap.org/soap/encoding/" use="encoded" namespace="urn:Foo" /> 22. </input> 23. <output> 24. <soap:body encodingStyle="http://schemas.xmlsoap.org/soap/encoding/" use="encoded" namespace="urn:Foo" /> 25. </output> 26. </operation> 27. </binding> 28. <service name="Hello"> 29. <port name="HelloIFPort" binding="tns:HelloIFBinding"> 30. <soap:address location="http://localhost:8080/Hello/hello" xmlns:wsdl="http://schemas.xmlsoap.org/wsdl/" /> 31. </port> 32. </service> 33. </definitions> Figura 3 – Exemplo de um documento WSDL. O documento apresentado na Figura 3 foi gerado com o aplicativo wscompile, o qual integra a API JAX-RPC. Para isso, foram utilizados como base um arquivo XML de configuração e o arquivo de interface do serviço compilado. O documento representa a descrição do Web Service denominado Hello, o qual possui apenas uma operação denominada sayHello, que recebe um parâmetro do tipo String e retorna uma String como resposta. 21 De acordo com W3C (2001), o elemento raiz do documento WSDL é o elemento definitions. O elemento types contém as definições dos tipos de dados que serão enviados e recebidos através das mensagens processadas pelo Web Service. Este elemento é especificado quando é preciso utilizar tipos de dados complexos, definidos pelo desenvolvedor. Quando são utilizados somente tipos de dados padronizados pelo W3C, este elemento não precisa ser especificado. No exemplo apresentado na Figura 4, o elemento types não contém valor declarado, o que indica que os dados contidos nas mensagens de solicitação e de resposta conterão somente valores padrão definidos. O elemento message define, para cada mensagem, qual o tipo de dado de cada parâmetro ou retorno. Para cada operação disponibilizada pelo Web Service, devem ser criados dois elementos message, um para a mensagem de requisição e outro para a respectiva mensagem de resposta. O tipo de dado pode ser um valor padrão ou qualquer tipo definido no elemento types. No exemplo da Figura 3, o elemento message cujo atributo name contém o valor “HelloIF_sayHello” representa a mensagem de solicitação do método “sayHello(String nome)”. O sub-elemento part define o tipo de dado do parâmetro e a ordem em que aparecerá, que neste caso é o primeiro parâmetro de entrada, e é do tipo String. O valor “String_1” do atributo name do elemento part denota o tipo de dado e a ordem do parâmetro. O valor “xsd:string” do atributo type do elemento part define que o tipo de dado do parâmetro é o tipo “string” definido no namespace “http://www.w3.org/2001/XMLSchema”. O elemento message cujo atributo name contém o valor “HelloIF_sayHelloResponse” define a mensagem de resposta do método “sayHello(String nome)”. O valor do atributo name do sub-elemento part agora contém o valor “result”, o que completa o sentido de que a mensagem é de resposta, conduzindo o resultado da operação processada pelo método do Web Service. O valor “xsd:string” do atributo type do elemento part define que o tipo de dado da resposta é o tipo “http://www.w3.org/2001/XMLSchema”. “string” definido no namespace 22 O elemento portType descreve os métodos que serão disponibilizados pelo Web Service. A finalidade básica deste elemento é indicar, para cada método do Web Service, qual elemento message definirá o formato da mensagem de solicitação e qual definirá o formato da mensagem de resposta. O sub-elemento operation indica a operação que está sendo definida. O sub-elemento input, do elemento operation, referencia o elemento message que descreverá o formato da mensagem de solicitação, e o sub-elemento output referencia o elemento message que descreverá o formato da mensagem de resposta. O elemento binding apresenta a informação do protocolo que será utilizado no transporte das mensagens. Pelo menos um elemento binding é requerido. De acordo com WSDL (2001), a linguagem WSDL é extensível a ponto de permitir a adoção de outros formatos de mensagem e protocolos de rede, além de SOAP 1.1, HTTP GET/POST e MIME, por exemplo. O protocolo SOAP é mais utilizado com o protocolo HTTP. No entanto, podem ser utilizados vários outros protocolos, como SMTP, FTP etc. A API JAX-RPC adota o protocolo SOAP como padrão para definição do formato das mensagens e HTTP para o transporte. No documento da Figura 4, o protocolo de transporte é indicado pelo atributo transport do sub-elemento soap:binding, que contém o valor “http://schemas.xmlsoap.org/soap/http”. De acordo com W3c (2002), o SOAP pode utilizar mensagens orientadas a documento ou orientadas a procedimentos (RPC), o que é definido através do atributo style do elemento soap:binding, sendo que o valores podem ser “rpc” ou “document”. O valor é opcional, mas, quando não indicado, será considerado o valor “document”. De acordo com Todd (2003), o elemento service contém o endereço real do Web Service. Assim, para cada elemento binding haverá a indicação de um endereço real através do elemento service. 2.4.2. UDDI W3C (2002) afirma que a tarefa de publicação e descrição de Web Services é essencial dentro da arquitetura básica de Web Services. Neste contexto, o padrão UDDI merece destaque por ser o mais utilizado. Oasis (2004) declara que o objetivo da especificação é 23 definir um conjunto de serviços com suporte à descrição e descoberta de negócios, organizações, e outros fornecedores de Web Services, dos Web Services que eles disponibilizam e das interfaces técnicas que podem ser utilizadas para acessar estes Serviços. A estrutura de armazenamento objetiva facilitar a localização das informações. De acordo com Todd (2003), UDDI permite realizar buscas por negócios e serviços de diferentes maneiras, tais como: localização de negócios por tipo de negócio (Yellow Pages – Páginas Amarelas); localização de negócios por nomes, endereços, entre outras informações (White Pages – Páginas Brancas); e localização de informações sobre os serviços que um negócio oferece (Green Pages – Páginas Verdes). Ainda segundo Todd (2003), UDDI define não somente uma estrutura para organização de informações, mas também um XML Schema para definição da estrutura de armazenamento, uma API com métodos que permitem publicar serviços e métodos para acessar serviços, uma especificação para replicação de informações entre registros e uma especificação para operadores de registro definindo, dentre outras, questões como segurança. As informações que são submetidas a um registro UDDI são armazenadas na forma de um documento XML, o qual segue o XML Schema descrito pela especificação. De acordo com Chappell (2002), o XML Schema define os seguintes elementos básicos: • businessEntity: é o elemento que contém as informações que definem um determinado negócio. Dentre estas, estão informações de contato e nome do negócio. Este elemento contém também sub-elementos que armazenam informações referentes aos serviços oferecidos pelo negócio. • businessService: é o elemento que contém a definição de um determinado serviço, contendo informações como nome, descrição e mais informações, como ponto de acesso, por exemplo, armazenadas em seus sub-elementos. • bindingTemplate: este elemento contém a informação do endereço real do serviço, a qual está armazenada no sub-elemento accessPoint. 24 • tModel: este elemento é um dos sub-elementos do elemento bindingTemplate, que representa uma especificação técnica dentro do contexto de um registro UDDI. A informação contida neste elemento poderia auxiliar companhias a determinar se um Web Service é compatível com seus requisitos de negócio. • categoryBag: este elemento contém informações de categorização para o serviço. Dentre as várias categorizações citadas estão a NAICS – North American Industry Classification System – Sistema de Classificação da Indústria Norte Americana e ISO 3166, que é um sistema de classificação geográfica padronizado pela International Organization for Standardization – Organização de Padronização Internacional. • publisherAssertion: este elemento contém informação sobre relacionamento de elementos businessEntity. As APIs para publicação e descoberta de serviços, definidas pela especificação UDDI, permitem que empresas possam publicar informações sobre seus negócios e serviços, e que clientes e parceiros possam localizar estas informações. A API de consulta referencia um URL de um determinado registro de negócios e não necessita de acesso autenticado para sua utilização. Ao contrário, a API de publicação utiliza o protocolo HTTPS e requer que o negócio utilize um nome de usuário e uma senha para as operações de inserção, alteração e remoção de informações. No pacote de APIs Java para desenvolvimento de Web Services – JWSDP (Java Web Service Developer Pack), a API JAX-R permite a manipulação de registros XML, permitindo a realização de operações de gerenciamento e consulta. A API JAX-RPC permite a construção de Web Services e clientes que usam chamadas de procedimento remoto (RPC) e XML. A versão mais recente do JWSDP é a versão 2.0, a qual apresenta a API JAX-WS em substituição à API JAX-RPC. O JWSDP será apresentado em mais detalhes na seção 2.4.3. 25 2.4.3. JWSDP O JWSDP é formado por um conjunto de APIs de código fonte aberto, desenvolvidas na linguagem Java, permitindo a construção, teste e publicação de Web Services e aplicações, utilizando a pilha de protocolos apresentada na Seção 2.4. No desenvolvimento deste trabalho foi utilizada a versão 1.6 do JWSDP. Nele estão contidas APIs para desenvolvimento de Web Services, aplicações Web, dentre outras aplicações. Destacam-se neste pacote as APIs JAXB (Java Architecture for XML Binding – Arquitetura Java para Mapeamento XML), JAXP (Java API for XML Processing – API Java para Processamento de XML), JAX-RPC (Java API for XML-based RPC – API Java para RPC baseado em XML) e JAXR (Java API for XML Registries – API Java para Registros XML). O JWSDP é mantido em contínua evolução, e recentemente, no decorrer deste trabalho, foi publicada a versão 2.0. Nesta nova versão, a API JAX-RPC foi renomeada para API JAXWS (Java API for XML Web Services – API Java para Web Services em XML). A API JAX-RPC será apresentada em mais detalhes na Seção 2.4.3.1. 2.4.3.1. JAX-RPC JAX-RPC é uma API para construção de Web Services e clientes usando mecanismos de RPC baseados em XML. Sun (2003) destaca que a API é independente do protocolo usado na representação das mensagens de requisição e de resposta às chamadas de procedimento remoto, suportando protocolos baseados em XML. No entanto, apesar de especificar a independência quanto ao protocolo de representação das mensagens, o projeto da API foi direcionado para o protocolo SOAP, implementando o suporte ao mesmo no pacote javax.xml.rpc.soap. O protocolo SOAP é um protocolo para intercâmbio de informação em ambiente descentralizado e distribuído, baseado em XML. Como mecanismo de transporte, JAX-RPC utiliza o protocolo HTTP. Para a descrição das informações do Serviço, a API utiliza a linguagem WSDL. Simplicidade e Interoperabilidade são características destacadas na especificação da API. A simplicidade está relacionada à maneira de como o desenvolvedor realiza a codificação do 26 Cliente ou do Servidor para a realização da comunicação. Os detalhes de como as mensagens são codificadas, transmitidas e recebidas não são motivo de preocupação, já que isto fica transparente ao desenvolvedor. A interoperabilidade relaciona-se com a capacidade atribuída ao Cliente e ao Servidor de realizar comunicação independentemente da linguagem ou plataforma que utilizem. A restrição a esta característica é que as partes envolvidas na comunicação devem utilizar mecanismos de RPC baseados em XML. O Serviço em JAX-RPC é desenvolvido e publicado em container de servlet. O JWSDP 1.6 dá suporte aos produtos Sun Java System Application Server Platform Edition 8.1 e Tomcat 5.0 para Java WSDP. A especificação da API declara somente este modelo de desenvolvimento do Serviço. Na seção 2.4.3.1.1 serão apresentados os passos básicos para o desenvolvimento do Servidor. Será apresentado nas Seções 2.4.3.1.1 e 2.4.3.1.2 a implementação de um Web Service denominado “Ola” e de um Cliente, utilizando a API JAX-RPC, com a finalidade de demonstrar os passos básicos para a utilização da API e demonstrar a forma de comunicação realizada entre as aplicações. 2.4.3.1.1. Desenvolvimento do Servidor JAX-RPC possibilita o desenvolvimento do Servidor de duas formas. Na primeira forma, pode-se desenvolver o Servidor partindo-se de um documento WSDL existente e utilizando uma ferramenta para realizar o mapeamento da WSDL para Java. O aplicativo wscompile, que integra a API JAX-RPC, possibilita a realização da tarefa de mapeamento e geração das classes do Servidor a partir da WSDL. É a forma mais complexa, já que a codificação da WSDL não é uma ação simples, como foi descrito na Seção 2.4.1. A segunda forma, que será descrita nessa seção, é codificando a interface e a classe que implementa a interface. JAX-RPC é bastante semelhante ao RMI no tocante à implementação do Servidor. Além disso, as chamadas aos métodos do Serviço pelo cliente são realizadas como se o Cliente estivesse executando métodos de um objeto local, facilitando o desenvolvimento. 27 Nessa aplicação o Serviço resume-se a um método que retorna ao cliente a mensagem “Olá <nome >”, sendo que o nome é o parâmetro passado pelo cliente na chamada do método. O primeiro passo para o desenvolvimento do servidor é criar a interface com a assinatura do método. A Figura 4 apresenta a interface de um Web Service, desenvolvido a partir dos exemplos contidos em Sun (2005). 1. 2. 3. 4. 5. 6. 7. 8. package ola; import java.rmi.*; java.util.*; public interface OlaIF extends Remote{ public String dizerOla(String nome) throws RemoteException; } Figura 4 – Exemplo de Interface de um Web Service com JAX-RPC. A interface apresentada na Figura 4 contém a assinatura do método denominado dizerOla, o qual recebe um parâmetro do tipo String e retorna uma String como resultado. A interface deve estender a interface Remote do pacote java.rmi e os métodos precisam declarar que podem lançar uma exceção remota do tipo RemoteException, quando a chamada a um método falhar. Os parâmetros dos métodos e o tipos de dados de retorno devem respeitar os tipos de dados suportados pela API, conforme apresentados em Sun (2003). A implementação do Servidor é realizada como uma classe comum, implementando a interface do Serviço. A classe deve implementar os métodos declarados na interface e deve possuir um construtor padrão, como mostra o trecho em negrito, na figura 5 . Além disso, atributos e métodos de acesso local podem ser adicionados ao código da classe, a critério do desenvolvedor. O Servidor pode implementar ainda a interface ServiceLifecycle, que possibilita a realização de operações de gerenciamento de sessão. A Figura 5 contém um exemplo de uma classe que implementa a interface apresentada na Figura 4. 28 1. package ola; 2. import java.rmi.*; 3. import java.util.*; 4. import javax.xml.rpc.*; 5. 6. public class OlaImpl implements OlaIF{ 7. public OlaImpl(){} 8. public String dizerOla(String nome){ 9. return “Olá “+nome; 10. } 11. } Figura 5 – Exemplo de Classe de Implementação de um Web Service com JAX-RPC. A classe OlaImpl, apresentada na Figura 5, implementa o método remoto dizerOla declarado na interface OlaIF, mostrado na figura 4, e um construtor padrão. Além do pacote java.rmi a classe deve importar o pacote javax.xml.rpc que contém as classes necessárias para a implementação do Servidor. Como pode ser notado, esta classe não implementa a interface ServiceLifecycle. Um ponto importante a ser analisado no momento da criação do Servidor é quanto aos tipos de dados dos parâmetros e dos dados de retorno dos métodos remotos. Como já mencionado, os tipos de dados devem ser os tipos declarados pela especificação da API. No entanto, podem ser utilizados tipos definidos pelo desenvolvedor, que são implementados em classes cujos atributos, parâmetros e retorno de métodos devem ser declarados com tipos dentre os definidos na especificação. A API, através do aplicativo wscompile, realiza o mapeamento dos tipos de dados do Servidor para os tipos definidos pela especificação da linguagem WSDL, criando o arquivo WSDL referente ao Serviço, visando a padronização e assim permitindo a interoperabilidade entre as aplicações Clientes e o Servidor. Para que o Serviço seja publicado e assim disponibilizado aos Clientes, é necessário criar a WSDL e os arquivos WAR. Estas tarefas são utilizadas através dos aplicativos wscompile, jar e wsdeploy, sendo que estes aplicativos necessitam de documentos XML que devem 29 conter uma estrutura específica para cada aplicativo. A Figura 6 apresenta um documento XML utilizado pelo aplicativo wscompile. 1. 2. 3. 4. 5. 6. 7. <?xml version="1.0" encoding="UTF-8"?> <configuration xmlns="http://java.sun.com/xml/ns/jax-rpc/ri/config"> <service name="Teste" targetNamespace="urn:Foo" typeNamespace="urn:Foo" packageName="ola"> <interface name="ola.OlaIF"/> </service> </configuration> Figura 6 – Documento XML utilizado pelo aplicativo wscompile. No documento XML apresentado na Figura 6, o atributo packageName do elemento service contém o nome do pacote onde estão as classes compiladas do Servidor. O atributo name do elemento interface contém o nome da interface. Além de criar a WSDL para o Serviço, o aplicativo também gera um arquivo modelo que contém o mapeamento dos tipos de dados do Serviço para os tipos de dados suportados pela API. Este arquivo modelo será utilizado pelo aplicativo jar. Para a geração do arquivo com a extensão .war, é necessário inicialmente executar o aplicativo jar, o qual utiliza um documento XML denominado jaxrpc-ri. A Figura 7 apresenta um documento XML utilizado pelo aplicativo jar. 30 1. <?xml version="1.0" encoding="UTF-8"?> 2. <webServices xmlns="http://java.sun.com/xml/ns/jax-rpc/ri/dd" version="1.0" 3. targetNamespaceBase="urn:Foo" typeNamespaceBase="urn:Foo" 4. urlPatternBase="/ws"> 5. <endpoint name="Ola" display-name="Servico Web Ola" 6. description="Web Service usando JAX-RPC." 7. interface="ola.OlaIF" model="/WEB-INF/model.gz" 8. implementation="ola.OlaImpl"/> 9. <endpointMapping endpointName="Ola" urlPattern="/ola"/> 10. </webServices> Figura 7 – Documento XML utilizado pelo aplicativo jar. No documento XML apresentado na Figura 7, o atributo name do elemento endpoint contém o nome do Serviço, o qual é referenciado pelo atributo endpointName do elemento endpointMapping. O atributo interface do elemento endpoint contém o nome do pacote e da interface, e o atributo implementation contém o nome do pacote e da classe que implementa o Servidor. O atributo urlPattern do elemento endpointMapping especifica a String que será incorporada ao url gerado pelo container Web. Para a tarefa final de criação do arquivo .war para publicação no container Web, é utilizado o aplicativo wsdeploy, o qual necessita de um documento XML denominado web que contenha os dados que serão publicados. A Figura 8 apresenta um documento XML utilizado pelo aplicativo. <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN" "http://java.sun.com/j2ee/dtds/web-app_2_3.dtd"> <web-app> <display-name>Servico Web Ola</display-name> <description>Web Service usando JAX-RPC.</description> <session-config> <session-timeout>60</session-timeout> </session-config> </web-app> Figura 8 – Documento XML utilizado pelo aplicativo wsdeploy. 31 No documento XML apresentado na Figura 8, o elemento display-name contém o nome que será apresentado na tela de visualização das aplicações do container Web. O elemento description contém a descrição. Os aplicativos devem ser executados seqüencialmente, começando pelo wscompile, e em seguida o aplicativo jar e depois wsdeploy. Mais detalhes da execução destes aplicativos e dos comandos podem ser encontrados em Nunes (2005). Uma vez que o Serviço esteja publicado, é possível criar aplicações Clientes. Na seção seguinte serão apresentados os passos básicos para a criação de um programa Cliente. 2.4.3.1.2. Desenvolvimento do Cliente Segundo Sun (2005), existem várias formas de se desenvolver um Cliente JAX-RPC. Dentre elas podemos citar o Cliente de Stub Estático, o Cliente de Proxy Dinâmico, o Cliente de Interface de Invocação Dinâmica e o Cliente de Aplicação. A diferença básica entre cada um dos métodos de desenvolvimento consiste no momento em que são obtidos os objetos que referenciam o Serviço. Sun (2005) apresenta detalhes da criação destes modelos, sendo que nesse trabalho é abordado o modelo mais simples, o Cliente de Stub Estático, o qual será apresentado nesta Seção. Neste modelo a referência ao Serviço é uma classe Stub que é obtida em tempo de desenvolvimento através do aplicativo wscompile, o qual constrói também arquivos serializadores e tipos de valores. Para criar as classes utilizadas na aplicação cliente é necessário, apenas, que se tenha a localização da WSDL do servidor. O objeto Stub que contém a referência age como um proxy para o Serviço remoto. Assim, as chamadas ao Serviço são realizadas através do objeto local, utilizando o objeto Stub. A Figura 9 apresenta um exemplo de Cliente de Stub Estático para o Servidor definido na Seção 2.4.3.1.1. 32 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15. 16. 17. 18. 19. 20. 21. 22. 23. import javax.xml.rpc.Stub; import ola.*; public class ClienteOla{ public ClienteOla(String endereco){ try{ Stub stub = (Stub) (new Ola_Impl().getOlaIFPort()); String prop = javax.xml.rpc.Stub.ENDPOINT_ADDRESS_PROPERTY; stub.setProperty(prop,endereco); OlaIF ola = (OlaIF) stub; System.out.println(ola.dizerOla(“Luiz”)); }catch(Exception ex){ ex.printStackTrace(); } } public static void main(String args[]){ if (args[0] != null){ ClienteOla clienteOla = new ClienteOla(args[0]); } System.exit(0); } } Figura 9 – Exemplo de Classe de Implementação de um Cliente JAX-RPC. A classe ClienteOla, apresentada na Figura 9, implementa um Cliente JAX-RPC do Serviço apresentado na Figura 5. Os trechos relacionados à comunicação com o servidor estão em negrito no código. A classe deve importar o pacote javax.xml.rpc.Stub, a fim de poder instanciar um objeto Stub, definido no pacote. Como se trata de um Cliente de Stub Estático, ele deve importar também o pacote que contém as classes compiladas com base na especificação do Servidor. Dentre as classes que o aplicativo wscompile gera está a classe Ola que é uma interface que estende a interface Service do pacote javax.xml.rpc. A classe Ola_Impl implementa a interface Ola, que contém o método getOlaIFPort, que retorna um objeto Stub que referencia o Serviço. Após a obtenção do Stub, é necessário configurar a propriedade ENDPOINT_ADDRESS_PROPERTY, a qual armazenará o endereço do Serviço, através do método _setProperty do objeto Stub. Por fim, é necessário converter o objeto Stub para 33 um objeto do tipo da interface do Servidor, através de uma operação de casting, permitindo a chamada de métodos remotos. A linha 10 do exemplo apresentado na Figura 5 demonstra esta operação. Como é possível notar, o aplicativo wscompile adota uma nomenclatura na geração das classes. Para interface que extende a interface Service é atribuído um nome com a nomenclatura <nome_do_serviço>. Para a classe que a implementa é atribuído um nome na forma <nome_do_serviço>_Impl, e para o método que retorna um objeto Stub a forma é get<nome_do_serviço>IFPort. Como já foi comentado, as tarefas de desenvolvimento do Serviço e do Cliente não correspondem apenas às tarefas descritas nesta Seção. A API JAX-RPC faz uso dos aplicativos wscompile, wsdeploy e jar para concluir as tarefas mencionadas, os quais fazem uso de arquivos XML para obter os dados de configuração necessários à execução dos aplicativos. Além dos arquivos XML apresentados nas Figuras 6, 7 e 8, para compilação do cliente é utilizado também o arquivo apresentado na Figura 9. Mais detalhes sobre a utilização dos aplicativos podem ser encontrados em Nunes (2005) e na Seção 4.5. 2.5. B2B A sigla B2B, derivada da expressão Business-to-Business (Negócio-a-Negócio), representa a modalidade de negócio eletrônico realizado entre empresas, tidas como parceiras comerciais umas das outras. Uma definição para o termo é apresentada por Silvestre (2004): “nesse modelo as partes são duas organizações que interligam-se, geralmente em uma relação de fornecedor ou usuário de produtos, serviços ou informação.” A interligação de empresas, nessa modalidade negócio eletrônico, permite a troca de informações, muitas vezes confidenciais, onde apenas o suficiente para a realização de negócios é disponibilizado. Amor (2000) enumera várias justificativas para a adoção do negócio eletrônico, tais como: a busca pela expansão do alcance de mercado; tornar-se mais visível ao mercado alvo; entregar resposta mais rapidamente aos clientes e parceiros; disponibilizar novos serviços; 34 fortalecer o relacionamento entre parceiros comerciais; e reduzir custos nas operações e, conseqüentemente em produtos e serviços. O surgimento da tecnologia de Web Services proporcionou que empresas com diferentes sistemas informatizados pudessem interligá-los, obtendo mais agilidade na realização de processos de negócios e reduzindo custos das operações, antes realizadas de forma manual, envolvendo métodos de comunicação muitas vezes ultrapassados e consumindo os valiosos recursos humanos. Na seção 2.6 serão apresentados mais detalhes relativos à tecnologia de Web Services e o B2B. 2.6. Web Services em B2B A adoção de padrões da Internet pela tecnologia de Web Services possibilita a integração de aplicações heterogêneas permitindo que empresas possam ampliar seus serviços. Sistemas que anteriormente não poderiam ser integrados devido a questões tecnológicas ou de custos agora, interligados, permitem que empresas possam intercambiar informações formando um modelo de negócio eletrônico vantajoso para ambos. Com isso fica fortalecida a parceria entre as empresas, que antes tinham que realizar suas interações de outras formas. Os processos de negócios agora podem (e até devem) ser repensados com o intuito de avaliar as vantagens da informatização. Processos de negócios que antes eram realizados da forma tradicional, consumindo recursos humanos e meios de comunicação dispendiosos, agora podem ser conduzidos de forma ágil, com menor probabilidade de erros e com baixo custo. Pode-se citar como exemplo o serviço de reserva de veículos oferecido por uma locadora de veículos, o qual seria realizado através da integração do sistema informatizado da locadora com o de um hotel. No ato da realização de uma reserva junto ao hotel, um hóspede poderia solicitar a reserva de um veículo, o que seria realizado automaticamente pelo funcionário na interface do sistema do hotel, facilitando a manipulação pelo funcionário, agilizando o processo de reserva, prestando um serviço de maior qualidade ao hóspede, e economizando recursos e tempo na realização da transação. 35 Nesta negociação, a integração dos sistemas e a parceria entre as empresas ficariam transparentes para o hóspede, que conduziria as negociações com o hotel. Posteriormente, de acordo com as questões contratuais mantidas pelas empresas parceiras, os acertos seriam realizados, quando o hotel repassaria os valores referentes à locação do veículo à locadora. Nota-se, nesta rápida exposição, que a integração dos sistemas proporciona a expansão dos serviços prestados pelo hotel aos seus clientes, sem significar aumento nos preços. Quanto à locadora, a parceria representa uma expansão de mercado. No tocante ao aspecto tecnológico, outros padrões como RMI e CORBA também poderiam ser empregados, observando-se as limitações de cada um, a depender das características dos sistemas a serem interligados, tais como plataformas, linguagens em que foram desenvolvidos e custos envolvidos na operação de integração, como contratação de uma equipe de desenvolvimento e treinamento de pessoal. Neste contexto, a tecnologia de Web Services não parece ter surgido para substituir as tecnologias existentes, mas sim proporcionar um maior poder de escolha por parte das empresas no momento da integração dos sistemas. Observando o que foi citado logo acima, o que vai determinar que uma tecnologia seja utilizada em contrapartida a outra são as características de cada um dos sistemas. 36 3. MATERIAL E MÉTODOS 3.1. Material O material utilizado compreende equipamentos de hardware e softwares, além do material bibliográfico discriminado no capítulo referente às referências bibliográficas. Os equipamentos de hardware serão apresentados na Seção 3.1.1. Os softwares utilizados serão discriminados na Seção 3.1.2. 3.1.1. Hardware O trabalho não necessitou de equipamentos de hardware especiais para o desenvolvimento. Os equipamentos compreendem dois microcomputadores, cujas configurações serão a seguir discriminadas: • Microcomputador tipo desktop, com processador Pentiun III com freqüência de 1.0 Gigahertz, com 256 MB de memória RAM, com disco rígido de 20 GB, com unidade leitora/gravadora de CD/DVD, com unidade leitora/gravadora de disquetes de 1.44 MB. O acesso à internet foi realizado através de conexão banda larga, utilizando um modem D-Link 500G. Este conjunto de hardware foi utilizado na fase de desenvolvimento e testes das aplicações e, principalmente, no desenvolvimento desta Revisão de Literatura, apresentando desempenho satisfatório na execução das atividades, sem a necessidade de quaisquer adaptações ou substituições de peças e equipamentos. 37 • Microcomputador tipo desktop, com processador Pentiun III com freqüência de 1.0 Gigahertz, com 256 MB de memória RAM, com disco rígido de 20 GB, com unidade leitora de CD, com unidade leitora/gravadora de disquetes de 1.44 MB, nas dependências do complexo de informática do CEULP/ULBRA. Este conjunto de hardware foi utilizado principalmente para a realização de pesquisas na Internet, auxiliando no desenvolvimento desta Revisão de Literatura, e apresentou também desempenho satisfatório na execução das atividades, sem a necessidade de quaisquer adaptações ou substituições de peças e equipamentos. 3.1.2. Software Os equipamentos de hardware discriminados na Seção 3.1.1 utilizaram a plataforma Windows, o primeiro com o Sistema Operacional Windows XP Professional Service Pack 2, e o segundo com o Sistema Operacional Windows 2000 Professional. Para o desenvolvimento desta Revisão de Literatura, foi utilizado o aplicativo Microsoft Word 2003 como editor de texto, e o Adobe Acrobat Reader 7.0 para leitura de documentos diversos. O navegador Web Microsoft Internet Explorer Versão 6.0 foi utilizado para a realização de buscas na Internet, leitura de documentos e tutoriais, e no desenvolvimento e testes das aplicações. O desenvolvimento da modelagem do Web Service foi realizado com o auxílio do aplicativo Rational Rose versão 2003. Na edição das classes Java e dos arquivos XML foram utilizados o Jcreator LE versão 3.5.013, cuja versão é freeware, e o Bloco de Notas versão 5.1. Para as tarefas de compilação e execução foi utilizado o JDK 5.0 (Java 2 Platform Standard Edition Development Kit 5.0 Update 5), associado ao JWSDP versão 1.6. O container Web utilizado foi o Tomcat 5.0 para JWSDP para a publicação do Serviço. Na edição da aplicação Cliente foi utilizada a Linguagem PHP, cuja instalação foi realizada com pacote da versão 5.1.4. Como editor das páginas PHP foi utilizado o Macromedia Dreamweaver 8. Como servidor Web foi utilizado o Internet Information Services versão 5. 38 Como sistema gerenciador de banco de dados foi utilizado o MySQL versão 4, auxiliado pelo aplicativo de consulta MySQL Query Browser versão 1.1.20 para Windows, utilizados tanto no desenvolvimento do Servidor quanto na aplicação Cliente. 3.2. Métodos A fase inicial do trabalho constituiu-se de buscas e leituras de textos, tutoriais e documentos na Internet e consultando livros diversos, os quais são citados no capítulo de referências bibliográficas, buscando o entendimento dos conceitos da tecnologia de Web Services, da API JAX-RPC e dos aplicativos necessários para o desenvolvimento das aplicações. O estudo da especificação técnica da API JAX-RPC foi de extrema importância para o desenvolvimento do trabalho, destacando-se como o principal documento de referência. Passada a fase inicial, passou-se a definição do domínio e à modelagem do Web Service. Posteriormente, iniciou-se a codificação das classes Java, acompanhando rigorosamente a modelagem desenvolvida. Para a definição da aplicação Cliente, buscou-se levantar as linguagens que oferecessem suporte à tecnologia de Web Services, destacando-se a linguagem PHP devido à quantidade de material de referência e tutoriais encontrados com extrema facilidade na Internet. Foi escolhida uma linguagem distinta da implementação do servidor para mostrar a interoperabilidade. Terminadas as etapas de desenvolvimento das aplicações, passou-se à fase de testes, na qual foi possível constatar o funcionamento das aplicações. Questionamentos surgiram a respeito do real destaque da tecnologia de Web Services na integração de aplicações. Por fim, passou-se à conclusão deste relatório, já com as devidas conclusões a respeito do tema proposto, anotando-se as dificuldades encontradas e os pontos positivos e negativos da utilização da tecnologia empregada. 39 4. RESULTADOS E DISCUSSÃO 4.1. Domínio Na definição do domínio buscou-se colocar em discussão um tema que refletisse mais adequadamente o assunto proposto neste estudo, que é a relação entre B2B e Web Services, e não apenas um exemplo comum como os encontrados nos diversos tutoriais e documentos sobre a tecnologia de Web Services, que, na maioria das vezes, não reflete as situações do mundo real. Também se buscou um tema de acordo com as características da modalidade de negócio eletrônico B2B, tentando levantar e discutir questões a respeito das vantagens e desvantagens da integração de aplicações entre parceiros comerciais. Neste trabalho foi desenvolvido um Web Service de uma locadora de veículos, onde é possível receber solicitação de reservas de veículos, além de operações como alteração e cancelamento de reserva, busca de veículos disponíveis para reserva e busca das reservas realizadas pelos Clientes, neste caso, empresas parceiras. A definição de um Web Service disponibilizado por uma locadora de veículos foi devido ao fato deste ramo comercial oferecer um tipo de serviço que é utilizado por vários segmentos, sendo viável buscar parcerias através da utilização da tecnologia de Web Services. As operações relativas à reserva de veículos foram tidas como as mais relevantes, por isso foram disponibilizadas pelo Web Service implementado aos seus parceiros comerciais. Não foram desenvolvidas funcionalidades de gerenciamento de usuários e tampouco de veículos, sendo que os dados necessários às operações de reserva foram inseridos 40 manualmente no banco de dados. Isso se deve ao fato do trabalho enfocar a comunicação entre aplicações de empresas distintas. Os clientes do serviço podem ser aplicações Web, aplicativos Desktop, ou outro Web Service. Neste trabalho, para a aplicação Cliente foi idealizada uma aplicação Web de um hotel que realizaria o papel de parceiro comercial, porém, vários outros segmentos poderiam usar esse serviço, como, por exemplo, uma empresa de turismo. A aplicação Web do hotel é integrada ao Web Service da locadora, buscando disponibilizar aos seus hóspedes um serviço diferenciado, facilitando a realização do processo de negócio entre as empresas parceiras, proporcionando aos funcionários mais facilidade na realização de suas atividades. As reservas de veículos seriam integradas à aplicação Web do hotel. Para a implementação do Servidor foi utilizada a API JAX-RPC, que integra o JWSDP. A utilização da linguagem Java deve-se ao fato de ser uma linguagem portável e devido ao fato de existirem estudos anteriores sobre o desenvolvimento de Web Services em Java. A linguagem utilizada para a implementação do cliente foi a PHP e não o Java, que é a linguagem do servidor, visando demonstrar a interoperabilidade dos Web Services, sendo que foi comprovado que existe independência de plataforma e de linguagem de programação. A linguagem PHP gratuita foi escolhida por ser simples, no tocante à instalação e configuração, e por oferecer uma vasta bibliografia em português, não tendo sido realizados testes comparativos com outras linguagens para essa escolha. Neste trabalho não foram levadas em consideração questões relacionadas à segurança na comunicação das aplicações, haja vista que se notou que o trabalho se estenderia a um nível bastante elevado, e que o tempo disponível não proporcionaria a obtenção de resultados satisfatórios. Porém, é importante mencionar que para colocar o serviço em uso, seria interessante acrescentar a segurança na comunicação. 4.2. Comunicação das Aplicações A comunicação da aplicação cliente com o Web Service é realizada de forma transparante para o usuário da aplicação do hotel. A Figura 10 apresenta os detalhes da comunicação. 41 Figura 10 - Arquitetura de Comunicação da Aplicação Cliente com o Web Service Como pode ser visto na Figura 10, o usuário interage com a aplicação do hotel através do navegador, que realiza uma requisição HTTP para o servidor Web, no caso o IIS. Quando a página solicitada necessita realizar uma chamada ao Web Service, o Cliente PHP solicita o documento WSDL, que é devolvido pelo Servidor. De posse do documento WSDL, o Cliente PHP realiza um chamada a um método do Web Service, que processa a chamada e envia o retorno. A comunicação nas chamadas e retorno de métodos do Web Service são realizadas através do protocolo SOAP sobre HTTP. Ao final da realização das operações solicitadas pelo usuário, uma resposta HTTP é enviada ao navegador e o resultado é exibido ao usuário. 42 4.3. Modelagem do Web Service A modelagem apresentada neste trabalho compreende apenas às funcionalidades desenvolvidas no Web Service, no tocante à locadora de veículos, não sendo realizada a modelagem das funcionalidades do hotel, já que esta foi implementada apenas para demonstrar a utilização do serviço. Nas Seções 4.3.1 e 4.3.2 são apresentados e discutidos apenas os principais diagramas da modelagem, sendo que a modelagem completa está disponível no Anexo I. 4.3.1. Funcionalidades do Web Service As funcionalidades modeladas são relacionadas às reservas de veículos, as quais seriam disponibilizadas aos funcionários do hotel através da aplicação Web do hotel. São elas: • Buscar Veículos: buscar a relação dos veículos disponíveis para reserva; • Reservar Veículo: permitir a reserva de um veículo por um determinado cliente; • Buscar Reservas: buscar os dados das reservas, de acordo com os parâmetros desejados, tais como: identificador do cliente, senha, lista com os identificadores das reservas, período de realização das reservas (data inicial e data final do período) e status; • Alterar Reserva: permitir a alteração da data de retirada e de devolução do veículo; • Cancelar Reserva: permitir o cancelamento de uma determinada reserva. A Figura 11 apresenta o diagrama de casos de uso. Como pode ser observado na Figura 10, em todas as funcionalidades o ator representa a empresa Cliente. 43 Reservar Veiculos Buscar Veiculos Cliente Buscar Reservas Alterar Reserva Cancelar Reserva Figura 11 – Diagrama de Casos de Uso. 4.3.2. Diagrama de Classes Com base no diagrama de caso de uso, apresentado na Figura 10, e no desenvolvimento de cada uma das funcionalidades, foram definidas as classes necessárias à implementação do Web Service. A Figura 12 apresenta o diagrama de classes do Web Service. 44 Reserva idReserva : int dataReserva : java.util.Date dataRetirada : java.util.Date dataPrevDevolucao : java.util.Date dataDevolucao : java.util.Date quilometragemRetirada : int quilometragemDevolucao : int status : String valorQuilometro : float valorDiaria : float idVeiculo : int idCliente : int criarReserva() adicionarReserva() buscarReservas() buscarReserva() alterarReserva() cancelarReserva() 0..* possui 0..* possui 1 Veiculo idVeiculo : int modelo : String marca : String cor : String ano : int numPortas : int numPassageiros : int categHabilitacao : char quilometragemAtual : int valorQuilometro : float valorDiaria : float status : String buscarVeiculos() alterarVeiculo() Veiculo() Veiculos buscarVeiculos() alterarVeiculo() 1 Reservas Cliente (from Use Case View) idCliente : int senha : String nome : String responsavel : String status : String reservarVeiculo() buscarReservas() alterarReserva() cancelarReserva() Clientes buscarCliente() buscarCliente() Figura 12 – Diagrama de Classes do Web Service. No diagrama apresentado na Figura 12, a classe Cliente representa a empresa Cliente, a qual foi definida como o ator no diagrama de casos de uso apresentado na Figura 10. A classe Veiculo define os dados de cada veículo que serão armazenados no sistema, e que são relevantes no conjunto das operações. A classe Reserva define os dados das reservas 45 realizadas e que também são relevantes no conjunto das atividades. Além dos dados, representados pelos atributos das classes, são definidos também os métodos de cada classe, necessários na realização das operações. Não foram representados neste diagrama os métodos de acesso aos atributos das classes devido à quantidade de atributos existentes. Além das classes que definem as entidades do sistema, foram representadas também as classes que, no desenvolvimento da modelagem, tornaram-se necessárias. As classes Clientes, Veiculos e Reservas definem classes com métodos estáticos que servem de classes controladoras e que, desta forma, ficam isoladas no diagrama. Na Seção 4.5 será descrita a implementação do Serviço. 4.4. Considerações sobre o serviço No serviço implementado, em cada solicitação ao Web Service deve ser realizada a autenticação do Cliente, necessitando assim que os dados de identificação da empresa Cliente sejam encaminhados juntos com os demais dados de cada solicitação. Devido às características da aplicação, a operação de autenticação dos Clientes deve ficar transparente aos usuários das aplicações Clientes. Como o código da aplicação não fica à vista do usuário, os dados de autenticação podem ficar embutidos no código. Além disso, observou-se que o reenvio destes dados em cada solicitação não acarreta aumento significativo no tempo de execução da solicitação. Em uma situação em que o Servidor atendesse a um número maior de solicitações, a manutenção de sessões poderia sobrecarregar a memória do Servidor. Uma alternativa para esta situação seria a adoção do monitoramento de sessão com a definição de sessões com tempo reduzido, e sempre com o reenvio dos dados de identificação do Cliente. A manutenção de sessões permitiria maior agilidade na execução da funcionalidade, evitando que a toda solicitação fosse realizada a verificação dos dados do Cliente na base de dados do sistema. O reenvio dos dados permitirá a verificação imediata dos dados no caso de tempo de sessão expirado. De qualquer forma, ficou definido neste trabalho não adotar o gerenciamento de sessão por esta ser a maneira mais complexa de ser implementada. 46 Na modelagem, ficou definido que deveria existir um status relacionado ao cliente: ativo, para o cliente que está em dia com as suas obrigações; e inativo, para os clientes que possuem alguma pendência. Em todas as funcionalidades, com exceção da ação de busca de reservas, o cliente deve estar com status definido como ativo, proporcionando à locadora de veículos que somente esses possam solicitar a execução das funcionalidades. Quanto à funcionalidade de busca de reservas, ela ficaria ativa até mesmo aos Clientes com status definido como inativo, proporcionando aos mesmos que solicitassem ao sistema, através desta funcionalidade, os dados relativos às reservas realizadas, possibilitando um acompanhamento completo. Neste trabalho, a locadora de veículos não tem a responsabilidade de armazenar os dados pessoais dos condutores dos veículos, ficando esta tarefa a cargo de cada Cliente. Dentro de um contexto do mundo real, por questões contratuais, inclusive a respeito da necessidade de realização de seguros dos veículos, poderia ser necessária a manutenção pela locadora dos dados dos condutores, o que significaria a necessidade de envio destes dados no ato da solicitação da reserva, o que alteraria a estrutura do Web Service. Não foi implementada uma funcionalidade para confirmação de reservas, uma vez que se buscou analisar apenas questões de comunicação, e não o desenvolvimento completo de um sistema para uma locadora de veículos. Finalizada a modelagem do Web Service, passou-se à fase de codificação das classes da interface e da implementação do Serviço, que é apresentada na seção 4.5. Por fim, foi implementado um cliente para testar o serviço, um trecho do código é apresentado na seção 4.6. O código completo do cliente será apresentado no Anexo III. 4.4.1. Questão Legal do Serviço O trabalho desenvolvido buscou abordar questões tecnológicas para a modalidade de comércio eletrônico business-to-business, não fazendo parte do foco abordar questões legais a respeito, uma vez que envolve vários fatores. Além disso, no que diz respeito a legislação, não existe uma definição em relação aos B2B no Brasil, nem a respeito de empresas do mesmo país nem em relação a empresas atuando em países distintos, o que 47 complicaria um pouco mais a questão legal. No entanto, passou-se a uma rápida análise desse assunto em relação ao comércio eletrônico, que foi descrita baseada em leituras em grupos de discussão e em sites de economia, sem grande relevância científica. As funcionalidades disponibilizadas pela locadora de veículos às empresas Clientes através do Web Service não configura comercialização de produto ou serviço através de meio eletrônico. O que se entende é que é apenas uma forma de comunicação e solicitação de serviço, tal como ocorre com o telefone ou outro meio de comunicação. O serviço prestado pela locadora às empresas Clientes não ocorre de fato no meio eletrônico, ficando este meio apenas como forma de solicitação, no qual a entrega do veículo se dá pessoalmente. Passando-se a analisar a situação em que a contratação ocorreria de forma virtual, em que as empresas Clientes contratariam com a locadora de veículos através de contrato disponibilizado por meio eletrônico, e não pessoalmente, é necessário buscar uma análise para o assunto no tocante a questões legais quanto ao contrato firmado. A busca por ambas as partes em exigir o cumprimento do contrato pode ser uma tarefa difícil, principalmente quando se tratar de empresas situadas em países distintos. Por fim, mesmo quando o contrato é firmado pessoalmente, observa-se que a confirmação de uma determinada reserva poderia ser um dos pontos mais relevantes nesta discussão caso não seja adotado um sistema confiável de confirmação de reserva, seja qual for o meio de comunicação. 4.5. Implementação do Serviço Conforme mencionado na Seção 2.4.3.1.1, o Servidor pode ser implementado de duas formas. Neste trabalho, a implementação foi realizada codificando-se a interface e a classe de implementação do Servidor. A interface do Serviço define os métodos que serão disponibilizados às aplicações Clientes. A Figura 13 apresenta o código da interface do Serviço. 48 1. package locadora; 2. 3. 4. import java.rmi.*; import java.rmi.RemoteException; import java.util.*; 5. public interface LocadoraIF extends Remote{ 6. public Object[] buscarVeiculos(int idCliente, String senha) throws RemoteException; 7. 8. public boolean reservarVeiculo(int idCliente, String senha, int idVeiculo, Date dataRetirada, Date dataPrevDevolucao) throws RemoteException; 9. 10. public Object[] buscarReservas(int idCliente, String senha, Object[] listIdReservas, Date dataInicialReservas, Date dataFinalReservas, String status) throws RemoteException; 11. 12. public boolean alterarReserva(int idCliente, String senha, int idReserva, Date dataRetirada, Date dataPrevDevolucao) throws RemoteException; 13. 14. public boolean cancelarReserva(int idCliente, String senha, int idReserva) throws RemoteException; 15. } Figura 13 – Implementação da Interface do Web Service. A codificação da interface apresentada na Figura 13 segue a especificação das funcionalidades do sistema. Considerando-se as características da aplicação, em todos os métodos definidos na interface, o identificador e a senha do Cliente são obrigatórios, com o intuito de permitir a autenticação do Cliente em cada solicitação às funcionalidades do Web Service. Através do método buscarVeiculos o Cliente solicita a lista dos veículos disponíveis para reserva. O método tem como parâmetros apenas os dados de identificação do Cliente. A lista é um array de objetos da classe Veiculo definida na modelagem. Com o método reservarVeiculo o Cliente pode solicitar a reserva de um determinado veículo, informando, além dos dados de identificação, o identificador do veículo, a data pretendida para retirada e a data provável para devolução. Caso a operação seja realizada com sucesso, o método retornará o identificador da reserva, para controle do Cliente. Caso ocorra falha na operação será retornado o valor -1. 49 O método buscarReservas possibilita que o Cliente possa obter relatórios de suas reservas, através de uma lista de reservas que é retornada. Como parâmetros o método possui os dados de identificação do Cliente, uma lista de identificadores de reservas especificados através do parâmetro listIdReservas, um intervalo de datas de realização das reservas especificado através dos parâmetros dataInicialReservas e dataFinalReservas. O último parâmetro é o status das reservas. Assim, o Cliente pode buscar as reservas que realizou tendo como base uma lista de identificadores de reservas, ou tendo como base um intervalo de datas da realização das reservas e o status. O método alterarReserva possibilita que o Cliente possa alterar a data de retirada e a data de devolução de uma determinada reserva. Além dos dados de identificação do Cliente, o método possui como parâmetros o identificador da reserva a ser alterada, a nova data de retirada e a nova data de devolução do veículo. Como resultado o método retorna um valor booleano especificando o valor verdadeiro (true) no caso de sucesso e o valor falso (false) para o caso de falha. O método cancelarReserva possibilita que o Cliente possa cancelar uma determinada reserva. Como resultado o método retorna um valor booleano especificando o valor verdadeiro (true) no caso de sucesso e o valor falso (false) para o caso de falha. 4.6. Implementação do Cliente Conforme foi mencionado na Seção 4.1, o cliente foi desenvolvido na linguagem PHP, a fim de demonstrar a interoperabilidade da tecnologia de Web Services. A implementação do Cliente corresponde a uma aplicação Web de um hotel, em que está disponível aos funcionários as funcionalidades para a realização de reserva de veículos aos hóspedes, fazendo uso das funcionalidades do Web Service. Foram implementadas somente as funcionalidades da aplicação Cliente que utilizam os métodos do Web Service, porém, em um caso real essa funcionalidade seria parte do sistema de gerenciamento do Hotel. Assim como no servidor, os dados necessários à realização das operações foram inseridos manualmente no banco de dados, para simplificar a implementação e deixar o foco do trabalho na comunicação entre as aplicações. 50 Na linguagem PHP, versão 5, a biblioteca de funções necessária para a criação de aplicações Clientes de Web Services e Servidores já está incorporada, necessitando apenas que seja feita a habilitação da biblioteca. Mais detalhes de configuração podem ser encontados em Php (2006). A implementação de um Cliente de um Web Service baseado em SOAP na linguagem PHP é bastante simplificada. Uma vez que se tenha habilitado a biblioteca php_soap.dll no arquivo de configuração php.ini, no diretório de instalação da linguagem, é possível instanciar um objeto da classe SoapClient, necessitando saber apenas a localização da WSDL do Serviço. A Figura 14 apresenta um trecho de código do arquivo veiculos.php, através do qual é realizada a busca dos veículos da locadora que estão disponíveis para reserva. 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. <?php $client = new SoapClient("http://localhost:8080/Locadora/locadora?WSDL"); $veiculos = ($client->buscarVeiculos(1,"senha1")); if (count($veiculos)<=0){ echo("Não existem veículos disponíveis para reserva!"); }else{ //apresenta um formulário para fornecimento dos dados para a reserve. //trecho omitido devido à extensão do código } ?> Figura 14 – Fragmento de Código do Arquivo veiculos.php. Na Figura 14 foi apresentado somente um fragmento do código do arquivo veículos.php devido à sua extensão. O arquivo na íntegra pode ser encontrado no Anexo III. Neste fragmento, observa-se que à variável $client é atribuído o objeto da classe SoapClient obtido através da instanciação da classe, tendo como parâmetro o endereço da WSDL do Serviço. Após a instanciação do objeto, é possível realizar chamadas a qualquer método implementado pelo Web Service. O código em negrito representa estas operações. A chamada ao método buscarVeiculos do Web Service, apresentada na linha 3 do fragmento de código da Figura 14, tem como parâmetros o identificador do Cliente, neste 51 caso a empresa parceira, e a senha. Como retorno, será atribuído à variável $veiculos um array com os dados dos veículos que estão disponíveis para reserva. Analisando o trecho apresentado nota-se a facilidade da codificação de um Cliente de um Web Service baseado em RPC, no qual as chamadas aos métodos remotos são realizadas da mesma forma que seriam feitas às chamadas aos métodos de um objeto local. No entanto, dificuldades podem ser observadas a respeito dos tipos de dados dos parâmetros e dos métodos de retorno. Apesar de todo o estudo da especificação da API JAX-RPC a respeito do mapeamento de dados, e da realização de testes com pequenas aplicações, foi observado que as diferenças entre as linguagens pode dificultar a integração das aplicações. Ainda a respeito do mapeamento de dados, pode-se citar como exemplo a dificuldade encontrada neste trabalho a respeito dos dados do tipo Data, onde a adoção das classes java.util.Date e java.sql.Date dificultou o desenvolvimento do trabalho, não permitindo que tanto um Cliente na própria linguagem java como o Cliente na linguagem PHP pudessem realizar chamadas aos métodos remotos. Assim, foi definido que os dados do tipo Data seriam representados como String no Servidor, com a forma “AAAA-MM-DD” para facilitar a inserção no banco de dados. Na busca por alternativas para o problema, foram realizadas consultas a diversos fóruns de discussão sobre o assunto, além de um exaustivo estudo da especificação da API da documentação das classes, sendo que a alternativa adotada foi a mais fácil de ser implementada, senão a única encontrada, uma vez que testes com outras alternativas não obtiveram êxito. Além da dificuldade nos tipos de dados que representam Data, foi notada também uma dificuldade na adoção dos tipos dos parâmetros e dos dados de retorno dos métodos remotos do Web Service. A utilização de classes definidas no desenvolvimento para estes dados não foi possível, embora a API defina que classes que não integram a API possam ser empregadas, desde que atendidos os requisitos quanto aos tipos de dados dos atributos, dos parâmetros e dos dados de retorno dos métodos. No caso dos métodos remotos buscarVeiculos e buscarReservas, são retornados arrays de objetos da classe java.util.Object, uma vez que as classes Veiculo e Reserva não puderam ser empregadas. 52 Feitas as adequações para sanar as dificuldades acima citadas, observou-se, no entanto, que deste ponto em diante a implementação do cliente foi realizada com certa facilidade, especialmente na linguagem PHP. Ressalte-se também que o fato da linguagem PHP disponibilizar funções nativas, tanto para criação de Web Services e Clientes quanto para acesso ao Sistema Gerenciador de Banco de Dados MySQL possibilitou otimizar o desenvolvimento da aplicação. 53 5. CONSIDERAÇÕES FINAIS O desenvolvimento do trabalho permitiu o levantamento das características da tecnologia de Web Services bem como da modalidade de comércio eletrônico Business-to-business (B2B), possibilitando uma avaliação mais concisa a respeito das tecnologias atuais utilizadas na integração de aplicações, bem como o levantamento das vantagens advindas da utilização do comércio eletrônico, sobretudo naquela modalidade. Foi possível notar a importância do emprego da tecnologia de Web Services na realização de processos de negócio. A informatização das empresas, associada à redução nos custos dos equipamentos, permitiu a automatização dos processos de negócio, tornando mais ágil, mais eficiente e menos dispendiosa a sua execução. Nota-se também a importância da utilização da tecnologia pelas empresas com a finalidade de expandir seus mercados consumidores, abrangendo regiões geográficas e faixas de mercado antes inatingíveis. Uma questão que não pode deixar de ser citada é a respeito da importância da busca de padronização no desenvolvimento de tecnologias, sobretudo a respeito da integração de aplicações desenvolvidas em plataformas e linguagens de programação diferentes. O padrão XML facilita o trabalho de padronização, possibilitando a criação de novos padrões, como é o caso, por exemplo, da linguagem WSDL e do protocolo SOAP. Em relação a B2B é importante citar que existem poucas informações no que diz respeito à legislação, sendo que nesse trabalho não foi abordada a relação legal entre as empresas. Desta forma, esse trabalho apontou a viabilidade em se utilizar os Web Services na ligação entre aplicações de empresas distintas e mostrou que, realmente, existe portabilidade na 54 utilização dessa tecnologia, já que cliente e servidor foram implementados em linguagens diferentes. No que diz respeito à comunicação entre aplicações cliente e servidor implementados em linguagens distintas, vale ressaltar que, apesar da portabilidade ser garantida pelas características dos Web Services, podem existir alguns problemas relacionados às características próprias das linguagens, como, por exemplo, os tipos de dados manipulados pelas mesmas. Baseando-se nos estudos realizados nesse trabalho uma questão que não pode ser definida é qual a melhor tecnologia de comunicação, RMI, CORBA ou Web Services, já que a escolha depende muito do problema que se quer resolver e, nesse trabalho, foi analisada apenas uma situação, não sendo realizado um estudo comparativo entre as mesmas. Para a situação apresentada, a princípio, a melhor escolha é o Web Service, por dois motivos: a facilidade da implementação do cliente, já que só é necessário conhecer a localização da WSDL; e a troca de dados XML. Em relação ao RMI, pode-se acrescentar, ainda, que a interoperabilidade é mais uma vantagem de se utilizar Web Services. Individualmente, é perceptível o grande valor trazido pelo desenvolvimento deste trabalho, evidenciando um notável aprendizado a respeito da tecnologia e dos aspectos relativos ao comércio eletrônico, o qual seguramente pode ser empregado no desenvolvimento de outros estudos e servir de base para outros trabalhos. Como trabalhos futuros, pode-se pensar o estudo de aspectos relativos à segurança de Web Services, uma vez que esta é uma questão essencial, principalmente quando se está abordando questões comerciais, como é o caso do Business-to-business. 55 6. REFERÊNCIAS BIBLIOGRÁFICAS (ALBUQUERQUE, 2001) ALBUQUERQUE, Fernando. TCP/IP – Internet Programação de Sistemas Distribuídos HTML, JavaScript e Java. Rio de Janeiro: Axcel Books, 2001. (AMOR, 2000) AMOR, Daniel. A ®Evolução do E-Business: Vivendo e Trabalhando em um Mundo Interconectado. São Paulo: Makron Books, 2000. (CASETTI, 1993) CASETTI, Orestes et al. Paradigmas para Construção de Sistemas Distribuídos. Brasília: 1993. Disponível em http://www.serpro.gov.br/publicacao/tematec/1993/ttec13. Acesso em 29/04/2006. CHAPPELL, David A. et al. Java Web Services. California: O’Reilly & Associates, 2002. (CHAPPELL, 2002) (COULOURIS, 2001) (HENDRICKS, 2002) COULOURIS, George et al. Distributed Systems – Concepts and Design, 3ª Edição, 2001. Adison Wesley, Pearson Education. HENDRICKS, Mack et al. Profissional Java Web Services. Rio de Janeiro: Alta Books, 2002. (HORSTMANN, 2003) HORSTMANN, Cay S. et al. Core Java 2 – Volume II – Recursos Avançados. São Paulo: Pearson Education do Brasil, 2003. (NUNES, 2005) NUNES, Luiz W. A. Análise da Utilização da API JAX-R para Acesso a Registros XML. 2005. 95 f. Trabalho de Estágio (Estágio Supervisionado como Requisito Parcial da Disciplina de Sistemas de Informação I) – Centro Universitário Luterano de Palmas, Universidade Luterana do Brasil, Palmas, 2005. 56 (OASIS, 2004) OASIS, Organization for the Advancement of Structured Information Standards. UDDI Spec TC. Disponível em <http://uddi.org/pubs/uddi-v3.0.2-20041019.htm>. Acesso em: 30 jun. 2006. (PHP, 2006) PHP, Linguagem PHP. Manual do PHP. Disponível em <http://www.php.net/manual/pt_BR/>. Acesso em: 03 jul. 2006. (RICCIONI, 2000) RICCIONI, Paulo Roberto. Introdução a Distribuídos com CORBA, Visual Books: 2000. (SILBERSCHATZ, 2004) SILBERSCHATZ, Abraham et al. Sistemas Operacionais com Java, 6ª Edição. Rio de Janeiro: Campus, 2004. (SILVESTRE, 2004) SILVESTRE, Larissa Jácome Barros. A Utilização do Padrão XML no Gerenciamento de Processos de Negócios. 2004. 91 f. Monografia (Pós-Graduação em Gestão em Novas Tecnologias) – Centro Universitário Luterano de Palmas, Universidade Luterana do Brasil, Palmas, 2004. (SUN, 2003) SUN, Sun Microsystems. Java API for XML-Based RPC Specification 1.1. Califórnia, 2003. Disponível em <http://java.sun.com/xml/downloads/jaxrpc.html>. Acesso em 30 jun. 2006. (SUN,2005) SUN, Sun Microsystems. J2EE 1.4 Tutorial. Disponível em <http://java.sun.com/j2ee/1.4/docs/tutorial/doc/>. Acesso em 30 jun. 2006. (TODD, 2003) TODD, Nick et al. Java Server Pages – O Guia do Desenvolvedor. Rio de Janeiro: Campus, 2003. (W3C, 2001) W3C, World Wide Web Consortium. Web Services Description Language. Disponível em <http://www.w3.org/TR/wsdl>. Acesso em: 31 jul. 2006. (W3C, 2002) W3C, World Wide Web Consortium. Web Services Architecture. Disponível em <http://www.w3.org/TR/2002/WD-ws-arch20021114/#whatisws>. Acesso em: 30 jun. 2006. Objetos 57 ANEXOS 58 ANEXO I: MODELAGEM DO WEB SERVICE CASOS DE USO EXPANDIDO Caso de Uso: Atores: Finalidade: Buscar Veículos Cliente Buscar a relação de veículos disponíveis para reserva. O cliente solicita a relação de veículos Visão Geral: disponíveis. Primário Tipo: O cliente deve possuir status “ativo”. Pré-condições: Não tem. Pós-condições: Seqüência Típica de Eventos Ação do Ator Resposta do Sistema 1. Este caso de uso começa quando o 2. O sistema verifica o status do cliente solicita os veículos cliente, busca e retorna uma lista disponíveis para reserva. com os dados dos veículos. 2. O sistema retorna mensagem de Seqüências Alternativas: erro informando que o status do cliente está “inativo”. 2. O sistema retorna mensagem de erro informando a inexistência de veículos disponíveis para reserva. 59 Caso de Uso: Atores: Finalidade: Visão Geral: Tipo: Pré-condições: Pós-condições: Reservar Veículo Cliente Permitir a reserva de um veículo por um determinado cliente. O cliente identifica o veículo, informa a data de retirada e a data de devolução. Primário O cliente deve possuir status “ativo”. O veículo deve estar disponível para reserva. É criado um objeto do conceito Reserva associado ao objeto do conceito Cliente e ao objeto do conceito Veículo. O atributo status do objeto do conceito Veículo é configurado como “reservado”. Seqüência Típica de Eventos Ação do Ator Resposta do Sistema 1. Este caso de uso começa quando o 2. O sistema verifica o status do cliente identifica o veículo, cliente, confirma a disponibilidade informa o período desejado para do veículo e retorna mensagem de locação, e confirma a operação. confirmação, contendo o identificador da Reserva. 2. O sistema retorna mensagem de Seqüências Alternativas: erro informando que o status do cliente está “inativo”. 2. O sistema retorna mensagem de erro informando que o veículo está indisponível para reserva. 60 Caso de Uso: Atores: Finalidade: Buscar Reservas Cliente Permitir a busca dos dados das reservas, de acordo com os parâmetros desejados. O cliente solicita as reservas de acordo Visão Geral: com os seguintes parâmetros: identificador do cliente, senha, identificadores das reservas, período da realização das reservas (data inicial e data final do período) e status. Primário Tipo: Não tem. Pré-condições: Não tem. Pós-condições: Seqüência Típica de Eventos Ação do Ator Resposta do Sistema 1. Este caso de uso começa quando o 2. O sistema identifica o cliente, cliente informa os parâmetros busca e retorna os dados das desejados e confirma a operação. reservas de acordo com os parâmetros. 2. O sistema retorna mensagem de Seqüências Alternativas: erro, informando que o cliente não foi identificado. 2. O sistema retorna mensagem de erro informando que não foram encontradas ocorrências de acordo com os parâmetros informados. 61 Caso de Uso: Atores: Finalidade: Alterar Reserva Cliente Permitir alteração em uma determinada reserva. O cliente identifica a reserva e informa o Visão Geral: novo período da locação. Primário Tipo: A reserva deve estar com status “a retirar” Pré-condições: e o cliente deve estar com status “ativo”. É alterado o período desejado para Pós-condições: locação. Seqüência Típica de Eventos Ação do Ator Resposta do Sistema 1. O cliente informa o novo período e 2. O sistema verifica o status do solicita alteração. cliente, realiza a alteração e retorna mensagem de confirmação. 2. O sistema retorna mensagem de Seqüências Alternativas: erro informando que o status do cliente está “inativo”. 2. O sistema retorna mensagem de erro informando que a reserva não existe. 2. O sistema retorna mensagem de erro informando que a reserva não permite alteração. 62 Caso de Uso: Atores: Finalidade: Visão Geral: Tipo: Pré-condições: Pós-condições: Cancelar Reserva Cliente Permitir o cancelamento de uma determinada reserva. O cliente identifica a reserva e solicita o cancelamento. Primário A reserva deve estar com status “a retirar” e o cliente deve possuir com status “ativo”. O status da reserva é configurado para “cancelada”. O atributo status do objeto do conceito Veículo é definido como “disponível”. Seqüência Típica de Eventos Ação do Ator Resposta do Sistema 1. Este caso de uso começa quando o 2. O sistema verifica o status do cliente solicita o cancelamento de cliente, confere o status da reserva uma determinada reserva. e altera para “cancelada”. 2. O sistema retorna mensagem de Seqüências Alternativas: erro informando que o status do cliente está “inativo”. 2. O sistema retorna mensagem de erro informando que a reserva não existe. 2. O sistema retorna mensagem de erro informando que a reserva não pode ser cancelada. 63 DIAGRAMAS DE CASOS DE USO Reservar Veiculos Buscar Veiculos Cliente Buscar Reservas Alterar Reserva Cancelar Reserva 64 MODELO CONCEITUAL Veiculo idVeiculo modelo marca cor ano numPortas numPassageiros categHabilitacao quilometragemAtual valorQuilometro valorDiaria status possui 1 0..* Reserva idReserva dataReserva dataRetirada dataPrevDevolucao dataDevolucao quilometragemRetirada quilometragemDevolucao status valorQuilometro valorDiaria idVeiculo idCliente possui 1 0..* Cliente (from Use Case View) idCliente senha nome responsavel status 65 DIAGRAMAS DE SEQÜÊNCIAS Buscar Veículos : Cliente buscarVeiculos(idCliente,senha) Sistema Reservar Veículo : Cliente Sistema reservarVeiculo(idCliente,senha,idVeiculo,dataRetirada,dataPrevDevolucao) 66 Buscar Reservas : Cliente Sistema buscarReservas(dadosDeBusca) dadosDeBusca: idCliente, senha, listIdReservas, dataInicialReservas, dataFinalReservas, status. Alterar Reserva : Cliente alterarReserva(idCliente,senha,idReserva,dataRetirada,dataPrevDevolucao) Sistema 67 Cancelar Reserva Sistema : Cliente cancelarReserva(idCliente,senha,idReserva) 68 CONTRATOS Buscar Veículos Contrato: Nome: Parâmetros: Responsabilidades: Exceções: Saída: Pré-condições: Pós-condições: Buscar Veículos buscarVeiculos(parâmetros) Cliente: • idCliente • senha Buscar os dados dos veículos cujo status é “disponível”. Cliente com status “inativo”. Não tem. Não tem. Não tem. Reservar Veículo Contrato: Nome: Parâmetros: Responsabilidades: Exceções: Saída: Pré-condições: Pós-condições: Reservar Veículo reservarVeiculo(parâmetros) Cliente: • idCliente • senha Veiculo: • idVeiculo Reserva: • dataRetirada • dataPrevDevolucao Realizar a reserva de um determinado veículo. Veículo já reservado. Não tem. O cliente deve possuir status “ativo”. É criado um objeto do conceito Reserva relacionado ao objeto do conceito Veículo e ao objeto do conceito Cliente. O atributo status do objeto do conceito Veículo é configurado como “reservado”. 69 Buscar Reservas Contrato: Nome: Parâmetros: Responsabilidades: Exceções: Saída: Pré-condições: Pós-condições: Buscar Reservas buscarReservas(parâmetros) Cliente: • idCliente • senha Reservas: • listIdReservas (lista com valores para o atributo idReserva das reservas a consultar) • dataInicialReservas • dataFinalReservas • status Buscar os dados das reservas realizadas, de acordo com os critérios desejados. Não tem. Não tem. O cliente deve ser identificado. Não tem. Alterar Reserva Contrato: Nome: Parâmetros: Responsabilidades: Exceções: Saída: Pré-condições: Pós-condições: Alterar Reserva alterarReserva(parâmetros) Cliente: • idCliente • senha Reserva: • idReserva • dataRetirada • dataPrevDevolucao Alterar a data de retirada e/ou a data de previsão para devolução de uma determinada reserva. Reserva com status “retirado”. Não tem. O cliente deve possuir status “ativo”. São alterados os valores dos atributos dataRetirada e dataPrevDevolucao do objeto do conceito Reserva. 70 Cancelar Reserva Contrato: Nome: Parâmetros: Responsabilidades: Exceções: Saída: Pré-condições: Pós-condições: Cancelar Reserva cancelarReserva(parâmetros) Cliente: • idCliente • senha Reserva: • idReserva Permitir o cancelamento de uma determinada reserva. Reserva com status diferente de “a retirar”. Não tem. O cliente deve possuir status “ativo”. O valor do atributo status do objeto do conceito Reserva é definido como “cancelada”. O valor do atributo status do objeto do conceito Veículo é definido como “disponível”. 71 DIAGRAMAS DE COLABORAÇÃO Buscar Veículos 3: cliente := buscarCliente(idCliente,senha) Cliente Clientes 2: cliente := buscarCliente(idCliente,senha) 1: buscarVeiculos(idCliente,senha) Sistema : Cliente 4: [cliente.getStatus() == "ativo"] listaVeiculos := buscarVeiculos() Veiculo Veiculos 5: listaVeiculos := buscarVeiculos() 72 Reservar Veículo 6: [veiculo.getStatus() == "disponivel"] alterarVeiculo(status) Veiculo Veiculos Cliente 5: veiculo := buscarVeiculo(idVeiculo) 4: [cliente.getStatus() == "ativo"] alterarVeiculo(idVeiculo,status) 3: cliente := buscarCliente(idCliente,senha) 1: reservarVeiculo(idCliente,senha,idVeiculo,dataRetirada,dataPrevDevolucao) 2: cliente := buscarCliente(idCliente,senha) Sistema Clientes : Cliente 7: reservarVeiculo(idCliente,idVeiculo,dataRetirada,dataPrevDevolucao) 9: [reserva != null] idReserva := adicionarReserva(reserva) 8: criarReserva(idCliente,idVeiculo,dataRetirada,dataPrevDevolucao) reserva: Reserva Reservas Reserva 73 Buscar Reservas Cliente Clientes 3: cliente := buscarCliente(idCliente,senha) 2: cliente := buscarCliente(idCliente,senha) 1: buscarReservas(idCliente,senha,listIdReservas,dataInicialReservas,dataFinalReservas,status) Sistema : Cliente 4: [cliente != null] reservas := buscarReservas(idCliente,listIdReservas,dataInicialReservas,dataFinalReservas,status) 5: reservas := buscarReservas(idCliente,listIdReservas,dataInicialReservas,dataFinalReservas,status) Reserva Reservas 74 Alterar Reserva Cliente Clientes 3: cliente := buscarCliente(idCliente,senha) 2: cliente := buscarCliente(idCliente,senha) 1: alterarReserva(idCliente,senha,idReserva,dataRetirada,dataPrevDevolucao) Sistema : Cliente 4: [cliente.getStatus() == "ativo"] alterarReserva(idCliente,idReserva,dataRetirada,dataPrevDevolucao) 5: reserva := buscarReserva(idReserva) Reserva Reservas 6: [reserva.getStatus() == "a retirar" && reserva.getIdCliente() == idCliente] alterarReserva(idReserva,dataRetirada,dataPrevDevolucao) 75 Cancelar Reserva Clientes Cliente Veiculo 3: cliente := buscarCliente(idCliente,senha) 8: alterarVeiculo(reserva.getIdVeiculo(),status) 2: cliente := buscarCliente(idCliente,senha) 7: alterarVeiculo(reserva.getIdVeiculo(),status) 1: cancelarReserva(idCliente,senha,idReserva) Sistema Veiculos : Cliente 4: [cliente.getStatus() == "ativo] reserva:= cancelarReserva(idCliente,idReserva) 5: reserva := buscarReserva(idReserva) Reserva Reservas 6: [reserva.getStatus() == "a retirar" && reserva.getIdCliente() == idCliente] cancelarReserva(idReserva) 76 DIAGRAMA DE CLASSES Reserva idReserva : int dataReserva : java.util.Date dataRetirada : java.util.Date dataPrevDevolucao : java.util.Date dataDevolucao : java.util.Date quilometragemRetirada : int quilometragemDevolucao : int status : String valorQuilometro : float valorDiaria : float idVeiculo : int idCliente : int criarReserva() adicionarReserva() buscarReservas() buscarReserva() alterarReserva() cancelarReserva() 0..* possui 0..* possui 1 Veiculo idVeiculo : int modelo : String marca : String cor : String ano : int numPortas : int numPassageiros : int categHabilitacao : char quilometragemAtual : int valorQuilometro : float valorDiaria : float status : String buscarVeiculos() alterarVeiculo() Veiculo() Veiculos buscarVeiculos() alterarVeiculo() 1 Reservas Cliente (from Use Case View) idCliente : int senha : String nome : String responsavel : String status : String buscarCliente() reservarVeiculo() buscarReservas() alterarReserva() cancelarReserva() Clientes buscarCliente() 77 ANEXO II: IMPLEMENTAÇÃO DO WEB SERVICE CLASSE CLIENTE package locadora; import java.sql.*; import java.sql.SQLException; public class Cliente{ public Cliente(){} public void setIdCliente(int idCliente){ this.idCliente = idCliente; } public int getIdCliente(){ return this.idCliente; } public void setSenha(String senha){ this.senha = senha; } public String getSenha(){ return this.senha; } public void setNome(String nome){ this.nome = nome; } public String getNome(){ return this.nome; } public void setResponsavel(String responsavel){ this.responsavel = responsavel; } public String getResponsavel(){ return this.responsavel; } 78 public void setStatus(String status){ this.status = status; } public String getStatus(){ return this.status; } public Cliente buscarCliente(int idCliente, String senha){ this.conexao = new Conexao(); try{ if (this.conexao.conecta()){ this.resultSet = conexao.consulta("SELECT * FROM cliente WHERE idCliente = "+idCliente+" AND senha = '"+senha+"';"); if (this.resultSet != null){ if (this.resultSet.next()){ this.setIdCliente(this.resultSet.getInt(1)); this.setSenha(this.resultSet.getString(2)); this.setNome(this.resultSet.getString(3)); this.setResponsavel(this.resultSet.getString(4)); this.setStatus(this.resultSet.getString(5)); this.conexao.desconecta(); this.conexao = null; return this; } } } return null; }catch(SQLException ex){ return null; } } } private int idCliente; private Conexao conexao; private ResultSet resultSet; private String senha, nome, responsavel, status; 79 CLASSE VEICULO package locadora; import java.util.*; import java.sql.*; import java.sql.SQLException; public class Veiculo{ public Veiculo(){} public void setIdVeiculo (int idVeiculo){ this.idVeiculo = idVeiculo; } public int getIdVeiculo(){ return this.idVeiculo; } public void setAno(int ano){ this.ano = ano; } public int getAno(){ return this.ano; } public void setNumPortas(int numPortas){ this.numPortas = numPortas; } public int getNumPortas(){ return this.numPortas; } public void setNumPassageiros(int numPassageiros){ this.numPassageiros = numPassageiros; } public int getNumPassageiros(){ return this.numPassageiros; } public void setQuilometragemAtual(int quilometragemAtual){ this.quilometragemAtual = quilometragemAtual; } 80 public int getQuilometragemAtual(){ return this.quilometragemAtual; } public void setModelo(String modelo){ this.modelo = modelo; } public String getModelo(){ return this.modelo; } public void setMarca(String marca){ this.marca = marca; } public String getMarca(){ return this.marca; } public void setCor(String cor){ this.cor = cor; } public String getCor(){ return this.cor; } public void setStatus(String status){ this.status = status; } public String getStatus(){ return this.status; } public void setCategHabilitacao(String categHabilitacao){ this.categHabilitacao = categHabilitacao; } public String getCategHabilitacao(){ return this.categHabilitacao; } public void setValorQuilometro(float valorQuilometro){ 81 } this.valorQuilometro = valorQuilometro; public float getValorQuilometro(){ return this.valorQuilometro; } public void setValorDiaria(float valorDiaria){ this.valorDiaria = valorDiaria; } public float getValorDiaria(){ return this.valorDiaria; } public ArrayList buscarVeiculos(){ this.conexao = new Conexao(); try{ if (this.conexao.conecta()){ this.resultSet = this.conexao.consulta("SELECT * FROM veiculo WHERE status = 'disponivel';"); if (this.resultSet != null){ ArrayList veiculos = new ArrayList(); while (this.resultSet.next()){ veiculos.add(this.resultSet.getInt(1)); veiculos.add(this.resultSet.getString(2)); veiculos.add(this.resultSet.getString(3)); veiculos.add(this.resultSet.getString(4)); veiculos.add(this.resultSet.getInt(5)); veiculos.add(this.resultSet.getInt(6)); veiculos.add(this.resultSet.getInt(7)); veiculos.add(this.resultSet.getString(8)); veiculos.add(this.resultSet.getInt(9)); veiculos.add(this.resultSet.getFloat(10)); veiculos.add(this.resultSet.getString(11)); veiculos.add(this.resultSet.getFloat(12)); } this.conexao.desconecta(); this.conexao = null; return veiculos; } } return null; }catch(SQLException ex){ return null; } 82 } public boolean alterarVeiculo(int idVeiculo, String status){ this.conexao = new Conexao(); if (this.conexao.conecta()){ boolean result = this.conexao.atualiza("UPDATE veiculo SET status = '"+status+"' WHERE idVeiculo = "+idVeiculo+";"); this.conexao.desconecta(); this.conexao = null; return result; } return false; } } private int idVeiculo, ano, numPortas, numPassageiros, quilometragemAtual; private String modelo, marca, cor, status, categHabilitacao; private float valorQuilometro, valorDiaria; private ResultSet resultSet; private Conexao conexao; 83 CLASSE RESERVA package locadora; import java.util.*; import java.util.StringTokenizer; import java.sql.*; import java.sql.SQLException; public class Reserva{ public Reserva(){} public Reserva(int idCliente, int idVeiculo, String dataRetirada, String dataPrevDevolucao){ this.idCliente = idCliente; this.idVeiculo = idVeiculo; this.dataRetirada = dataRetirada; this.dataPrevDevolucao = dataPrevDevolucao; } public void setIdReserva(int idReserva){ this.idReserva = idReserva; } public int getIdReserva(){ return this.idReserva; } public void setQuilometragemRetirada(int quilometragemRetirada){ this.quilometragemRetirada = quilometragemRetirada; } public int getQuilometragemRetirada(){ return this.quilometragemRetirada; } public void setQuilometragemDevolucao(int quilometragemDevolucao){ this.quilometragemDevolucao = quilometragemDevolucao; } public int getQuilometragemDevolucao(){ return this.quilometragemDevolucao; } public void setIdVeiculo(int idVeiculo){ this.idVeiculo = idVeiculo; 84 } public int getIdVeiculo(){ return this.idVeiculo; } public void setIdCliente(int idCliente){ this.idCliente = idCliente; } public int getIdCliente(){ return this.idCliente; } public void setDataReserva(String dataReserva){ this.dataReserva = dataReserva; } public String getDataReserva(){ return this.dataReserva; } public void setDataRetirada(String dataRetirada){ this.dataRetirada = dataRetirada; } public String getDataRetirada(){ return this.dataRetirada; } public void setDataPrevDevolucao(String dataPrevDevolucao){ this.dataPrevDevolucao = dataPrevDevolucao; } public String getDataPrevDevolucao(){ return this.dataPrevDevolucao; } public void setDataDevolucao(String dataDevolucao){ this.dataDevolucao = dataDevolucao; } public String getDataDevolucao(){ return this.dataDevolucao; } 85 public void setStatus(String status){ this.status = status; } public String getStatus(){ return this.status; } public void setValorQuilometro(float valorQuilometro){ this.valorQuilometro = valorQuilometro; } public float getValorQuilometro(){ return this.valorQuilometro; } public void setValorDiaria(float valorDiaria){ this.valorDiaria = valorDiaria; } public float getValorDiaria(){ return this.valorDiaria; } public int adicionarReserva(Reserva reserva){ this.conexao = new Conexao(); String sql = "INSERT INTO reserva (dataReserva,dataRetirada,dataPrevDevolucao,status,valorQuilometro,valorDiaria,id Veiculo,idCliente) "; sql += " VALUES (NOW(),'"+reserva.getDataRetirada()+"','"+reserva.getDataPrevDevolucao()+"','a retirar',2.0,100.00,"+reserva.getIdVeiculo()+","+reserva.getIdCliente()+");"; if (this.conexao.conecta()){ boolean result = this.conexao.atualiza(sql); this.conexao.desconecta(); } Reserva r = this.buscarReserva(0,reserva.getIdCliente(),reserva.getIdVeiculo(),reserva.getDataRe tirada(),reserva.getDataPrevDevolucao()); if (r != null){ return r.getIdReserva(); } return -1; } 86 public ArrayList buscarReservas(int idCliente,int idReservaBusca, String dataInicialReservas, String dataFinalReservas, String status){ this.conexao = new Conexao(); String sql = ""; if (idReservaBusca<=0){ sql += "SELECT * FROM reserva WHERE idCliente = "+idCliente+" AND dataReserva >= '"+dataInicialReservas+"'"; sql += " AND dataReserva <= '"+dataFinalReservas+"' AND status = '"+status+"';"; }else{ sql = "SELECT * FROM reserva WHERE idCliente = "+idCliente+" AND idReserva = "+idReservaBusca+";"; } if (this.conexao.conecta()){ this.resultSet = this.conexao.consulta(sql); try{ if (this.resultSet != null){ ArrayList reservas = new ArrayList(); while (this.resultSet.next()){ reservas.add(this.resultSet.getInt(1)); java.sql.Date aux = this.resultSet.getDate(2); if (aux!=null){ reservas.add(aux.toString()); }else{ reservas.add("0000-00-00"); } aux = this.resultSet.getDate(3); if (aux!=null){ reservas.add(aux.toString()); }else{ reservas.add("0000-00-00"); } aux = this.resultSet.getDate(4); if (aux!=null){ reservas.add(aux.toString()); }else{ reservas.add("0000-00-00"); } aux = this.resultSet.getDate(5); if (aux!=null){ reservas.add(aux.toString()); }else{ reservas.add("0000-00-00"); } 87 reservas.add(this.resultSet.getInt(6)); reservas.add(this.resultSet.getInt(7)); reservas.add(this.resultSet.getString(8)); reservas.add(this.resultSet.getFloat(9)); reservas.add(this.resultSet.getFloat(10)); reservas.add(this.resultSet.getInt(11)); reservas.add(this.resultSet.getInt(12)); } this.conexao.desconecta(); return reservas; } return null; }catch(SQLException ex){ ex.printStackTrace(); return null; } } } return null; public Reserva buscarReserva(int idReserva, int idCliente, int idVeiculo, String dataRetirada, String dataPrevDevolucao){ this.conexao = new Conexao(); if (this.conexao.conecta()){ if (idReserva >0){ this.resultSet = this.conexao.consulta("SELECT * FROM reserva WHERE idReserva = "+idReserva+";"); }else{ this.resultSet = this.conexao.consulta("SELECT * FROM reserva WHERE idCliente = "+idCliente+" and idVeiculo = "+idVeiculo+" and dataRetirada = '"+dataRetirada+"' and dataPrevDevolucao = '"+dataPrevDevolucao+"' and status = 'a retirar';"); } try{ this.resultSet.getDate(2); if (this.resultSet != null){ if (this.resultSet.next()){ this.setIdReserva(this.resultSet.getInt(1)); java.sql.Date aux = if (aux!=null){ this.setDataReserva(aux.toString()); }else{ this.setDataReserva("0000-00-00"); } 88 aux = this.resultSet.getDate(3); if (aux!=null){ this.setDataRetirada(aux.toString()); }else{ this.setDataRetirada("0000-00-00"); } aux = this.resultSet.getDate(4); if (aux!=null){ this.setDataPrevDevolucao(aux.toString()); }else{ this.setDataPrevDevolucao("000000-00"); } aux = this.resultSet.getDate(5); if (aux!=null){ this.setDataDevolucao(aux.toString()); }else{ 00"); this.setDataDevolucao("0000-00- } this.setQuilometragemRetirada(this.resultSet.getInt(6)); this.setQuilometragemDevolucao(this.resultSet.getInt(7)); this.setStatus(this.resultSet.getString(8)); this.setValorQuilometro(this.resultSet.getFloat(9)); this.setValorDiaria(this.resultSet.getFloat(10)); this.setIdVeiculo(this.resultSet.getInt(11)); this.setIdCliente(this.resultSet.getInt(12)); this.conexao.desconecta(); this.conexao = null; return this; } } return null; }catch(SQLException ex){ return null; } } return null; } 89 public boolean alterarReserva(int idReserva, String dataRetirada, String dataPrevDevolucao){ this.conexao = new Conexao(); if (this.conexao.conecta()){ boolean result = this.conexao.atualiza("UPDATE reserva SET dataRetirada = '"+dataRetirada+"', dataPrevDevolucao = '"+dataPrevDevolucao+"' WHERE idReserva = "+idReserva+";"); this.conexao.desconecta(); this.conexao = null; return result; } return false; } public boolean cancelarReserva(int idReserva){ this.conexao = new Conexao(); if (this.conexao.conecta()){ boolean result = this.conexao.atualiza("UPDATE reserva SET status = 'cancelada' WHERE idReserva = "+idReserva+";"); this.conexao.desconecta(); this.conexao = null; return result; } return false; } private int idReserva, quilometragemRetirada, quilometragemDevolucao, idVeiculo, idCliente; private String dataReserva, dataRetirada, dataPrevDevolucao, dataDevolucao; private String status; private float valorQuilometro, valorDiaria; private Conexao conexao; private ResultSet resultSet; /*public static void main(String args[]){ try{ Reserva r = new Reserva(); ArrayList result = r.buscarReservas(1,null,"2006-05-30","200606-30","a retirar"); if (result!=null){ Object[] resultado = result.toArray(); for (int i=0;i<resultado.length;i++){ System.out.println(resultado[i]); 90 }else{ } }*/ } System.out.println("Erro"); } }catch(Exception ex){ ex.printStackTrace(); } 91 CLASSE CLIENTES package locadora; public class Clientes{ public static Cliente buscarCliente(int idCliente, String senha){ Cliente cliente = new Cliente(); return cliente.buscarCliente(idCliente,senha); } } CLASSE VEICULOS package locadora; import java.util.*; public class Veiculos{ public static ArrayList buscarVeiculos(){ Veiculo veiculo = new Veiculo(); return veiculo.buscarVeiculos(); } } public static boolean alterarVeiculo(int idVeiculo, String status){ Veiculo veiculo = new Veiculo(); return veiculo.alterarVeiculo(idVeiculo,status); } 92 CLASSE RESERVAS package locadora; import java.util.*; public class Reservas{ public static int reservarVeiculo(int idCliente, int idVeiculo, String dataRetirada, String dataPrevDevolucao){ Reserva reserva = new Reserva(idCliente,idVeiculo,dataRetirada,dataPrevDevolucao); return reserva.adicionarReserva(reserva); } public static ArrayList buscarReservas(int idCliente, int idReserva, String dataInicialReservas, String dataFinalReservas, String status){ Reserva reserva = new Reserva(); return reserva.buscarReservas(idCliente,idReserva,dataInicialReservas,dataFinalReservas,s tatus); } public static boolean alterarReserva(int idCliente, int idReserva, String dataRetirada, String dataPrevDevolucao){ Reserva reserva = new Reserva(); reserva.buscarReserva(idReserva,0,0,"",""); if (reserva.getStatus().equals("a retirar") && (reserva.getIdCliente() == idCliente)){ return reserva.alterarReserva(idReserva,dataRetirada,dataPrevDevolucao); } return false; } public static Reserva cancelarReserva(int idCliente, int idReserva){ Reserva reserva = new Reserva(); reserva.buscarReserva(idReserva,0,0,"",""); if (reserva.getStatus().equals("a retirar") && (reserva.getIdCliente() == idCliente)){ reserva.cancelarReserva(idReserva); return reserva; } return null; } } 93 CLASSE CONEXAO package locadora; import java.sql.*; import java.sql.SQLException; public class Conexao{ private String driver = "sun.jdbc.odbc.JdbcOdbcDriver"; private String url = "jdbc:odbc:"; private String userName; private String password; private Connection con; private Statement st; private boolean conectado = false; public Conexao(){ this.url = this.url + "locadora"; this.userName = "webservice"; this.password = "webservicelocadora"; } public boolean conecta(){ if (!this.conectado){ try{ Class.forName(driver); this.con = DriverManager.getConnection(url,userName,password); this.st = this.con.createStatement(); this.conectado = true; } catch(Exception ex){ return false; } } return true; } public boolean desconecta(){ if (this.conectado){ try{ this.st.close(); this.con.close(); this.conectado = false; } catch(SQLException ex){ 94 } } return false; } return true; public boolean atualiza(String q){ try{ this.st.executeUpdate(q); return true; } catch(SQLException ex){ return false; } } } public ResultSet consulta(String q){ try{ return this.st.executeQuery(q); } catch(SQLException ex){ return null; } } 95 INTERFACE LOCADORAIF package locadora; import java.rmi.*; import java.rmi.RemoteException; import java.util.*; public interface LocadoraIF extends Remote{ public Object[] buscarVeiculos(int idCliente, String senha) throws RemoteException; public int reservarVeiculo(int idCliente, String senha, int idVeiculo, String dataRetirada, String dataPrevDevolucao) throws RemoteException; public Object[] buscarReservas(int idCliente, String senha, int idReserva, String dataInicialReservas, String dataFinalReservas, String status) throws RemoteException; public boolean alterarReserva(int idCliente, String senha, int idReserva, String dataRetirada, String dataPrevDevolucao) throws RemoteException; public boolean cancelarReserva(int idCliente, String senha, int idReserva) throws RemoteException; } 96 CLASSE LOCADORAIMPL package locadora; import java.rmi.*; import java.rmi.RemoteException; import java.util.*; public class LocadoraImpl implements LocadoraIF{ public LocadoraImpl(){ } public Object[] buscarVeiculos(int idCliente, String senha) throws RemoteException{ Cliente cliente = Clientes.buscarCliente(idCliente,senha); if (cliente != null){ if (cliente.getStatus().equals("ativo")){ return Veiculos.buscarVeiculos().toArray(); } } return null; } public int reservarVeiculo(int idCliente, String senha, int idVeiculo, String dataRetirada, String dataPrevDevolucao) throws RemoteException{ Cliente cliente = Clientes.buscarCliente(idCliente,senha); if (cliente != null){ if (cliente.getStatus().equals("ativo")){ if (Veiculos.alterarVeiculo(idVeiculo,"reservado")){ return Reservas.reservarVeiculo(idCliente,idVeiculo,dataRetirada,dataPrevDevolucao); } } } return -1; } public Object[] buscarReservas(int idCliente, String senha, int idReserva, String dataInicialReservas, String dataFinalReservas, String status) throws RemoteException{ Cliente cliente = Clientes.buscarCliente(idCliente,senha); if (cliente != null){ return Reservas.buscarReservas(idCliente,idReserva,dataInicialReservas,dataFinalReservas ,status).toArray(); } return null; } 97 public boolean alterarReserva(int idCliente, String senha, int idReserva, String dataRetirada, String dataPrevDevolucao) throws RemoteException{ Cliente cliente = Clientes.buscarCliente(idCliente,senha); if (cliente != null){ if (cliente.getStatus().equals("ativo")){ return Reservas.alterarReserva(idCliente,idReserva,dataRetirada,dataPrevDevolucao); } } return false; } public boolean cancelarReserva(int idCliente, String senha, int idReserva) throws RemoteException{ Cliente cliente = Clientes.buscarCliente(idCliente,senha); if (cliente != null){ if (cliente.getStatus().equals("ativo")){ Reserva reserva = Reservas.cancelarReserva(idCliente,idReserva); if (reserva != null){ return Veiculos.alterarVeiculo(reserva.getIdVeiculo(),"disponível"); } } } return false; } } 98 ARQUIVOS XML UTILIZADOS PELOS APLICATIVOS WSCOMPILE, JAR E WSDEPLOY Config-interface.xml 1. <?xml version="1.0" encoding="UTF-8"?> 2. <configuration xmlns="http://java.sun.com/xml/ns/jax-rpc/ri/config"> 3. <service name="Locadora" targetNamespace="urn:Foo" typeNamespace="urn:Foo" 4. packageName="locadora"> 5. <interface name="locadora.LocadoraIF"/> 6. </service> 7. </configuration> Jaxrpc-ri.xml 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15. 16. 17. 18. <?xml version="1.0" encoding="UTF-8"?> <webServices xmlns="http://java.sun.com/xml/ns/jax-rpc/ri/dd" version="1.0" targetNamespaceBase="urn:Foo" typeNamespaceBase="urn:Foo" urlPatternBase="/ws"> <endpoint name="Locadora" display-name="Servico Locadora" description="Web Service de uma Locadora de Veiculos usando JAX-RPC." interface="locadora.LocadoraIF" model="/WEB-INF/model.gz" implementation="locadora.LocadoraImpl"/> <endpointMapping endpointName="Locadora" urlPattern="/locadora"/> </webServices> 99 Web.xml 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN" "http://java.sun.com/j2ee/dtds/web-app_2_3.dtd"> <web-app> <display-name>Servico Locadora</display-name> <description>Web Service de uma Locadora de Veiculos usando JAX-RPC.</description> <session-config> <session-timeout>60</session-timeout> </session-config> </web-app> 100 ANEXO III: IMPLEMENTAÇÃO DA APLICAÇÃO CLIENTE INDEX.PHP <html> <head> <title>HOTEL - Página Inicial</title> </head> <body> <center> <table width="791" height="587" border="0"> <tr> <td colspan="2"><h3><h2>HOTEL</h3></td> </tr> <tr> <td width="136"> <table width="137" height="222" border="0"> <tr> <td height="48"><h5><a href="reserva_hospedagem.php?flag=hospedagem">Reservar Hospedagem</a></h5></td> </tr> <tr> <td height="43"><h5><a href="reserva_veiculo.php?flag=veiculo">Reservar Veículo</a></h5></td> </tr> <tr> <td height="42"><h5><a href="buscar_reserva_apto.php?flag=buscaa">Buscar Reserva Apto</a></h5></td> </tr> <tr> <td height="42"><h5><a href="buscar_reserva_veiculo.php?flag=buscav">Buscar Reserva Veiculo</a></h5></td> </tr> <tr> <td height="42"><h5><a href="cadastrar_cliente.php?flag=cliente">Cadastrar Cliente</a></h5></td> </tr> </table> </td> <td width="645"> </td> </tr> </table> </center> </body> </html> RESERVA_HOSPEDAGEM.PHP 101 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" /> <title>HOTEL - Reservar Hospedagem</title> <style type="text/css"> <!-.style1 {font-family: Verdana, Arial, Helvetica, sans-serif} --> </style> </head> <body> <center> <table width="791" height="550" border="0"> <tr> <td colspan="2"><h3><h2>HOTEL</h3></td> </tr> <tr> <td width="136"> <table width="137" height="222" border="0"> <tr> <td height="48"><h5><a href="reserva_hospedagem.php?flag=hospedagem">Reservar Hospedagem</a></h5></td> </tr> <tr> <td height="43"><h5><a href="reserva_veiculo.php?flag=veiculo">Reservar Veículo</a></h5></td> </tr> <tr> <td height="42"><h5><a href="buscar_reserva_apto.php?flag=buscaa">Buscar Reserva Apto</a></h5></td> </tr> <tr> <td height="42"><h5><a href="buscar_reserva_veiculo.php?flag=buscav">Buscar Reserva Veiculo</a></h5></td> </tr> <tr> <td height="42"><h5><a href="cadastrar_cliente.php?flag=cliente">Cadastrar Cliente</a></h5></td> </tr> </table> <td width="645"> <h2 align="center">RESERVA DE HOSPEDAGEM</h2><br><br> <form id="form1" name="form1" method="post" action="buscar_idcliente.php?flag=hospedagem"> <label>CPF do Cliente: 102 <input type="text" name="cpf" tabindex="0" /> </label> <label>Localizar <input type="submit" name="Submit" value="Submit" tabindex="1" /> </label> </form> <p align="center"><a href="cadastrar_cliente.php?flag=cliente">Cliente Não Cadastrado? Cadastrar</a></p> </td> </tr> </table> </center> </body> </html> 103 BUSCAR_IDCLIENTE.PHP <?php $host="localhost"; $user="aplicacaoweb"; $password="aplicacaowebhotel"; $database="hotel"; mysql_connect($host,$user,$password); mysql_select_db($database); $sql=stripSlashes("select idCliente from cliente where cpf = \"".$_POST['cpf']."\""); $result=mysql_query($sql); if (!$result){ echo("<a href=\"javascript:window.location='index.php'\">Página Inicial</a>"); }else{ $quantLinhas = mysql_num_rows($result); if ($quantLinhas>0){ $id=mysql_result($result,0); $id=(int)$id; $flag=$_GET['flag']; if (!strcmp($flag,"hospedagem")){ ?> <script language="javascript"> <?php echo("window.location=\"inserir_reserva_hospedagem.php?idCliente=".$id."\""); ?> </script> <?php }else{ if (!strcmp($flag,"veiculo")){ ?> <script language="javascript"> <?php echo("window.location=\"veiculos.php?idCliente=".$id."\""); ?> </script> <?php }else{ if (!strcmp($flag,"buscaa")){ ?> <script language="javascript"> <?php echo("window.location=\"reservasa.php?idCliente=".$id."\""); ?> </script> <?php }else{ if (!strcmp($flag,"buscav")){ ?> 104 <script language="javascript"> <?php echo("window.location=\"reservasv.php?idCliente=".$id."\""); ?> </script> <?php }else{ ?> <script language="javascript"> <?php echo("window.location=\"index.php\""); }else{ ?> } } } ?> </script> <?php } <body> <center> <table width="791" height="587" border="0"> <tr> <td colspan="2"><center><h2>HOTEL</h2></center></td> </tr> <tr> <td width="136"><table width="137" height="222" border="0"> <tr> <td height="48"><h5><a href="reserva_hospedagem.php">Reserva de Hospedagem</a></h5></td> </tr> <tr> <td height="43"><h5><a href="reserva_veiculo.php">Reserva de Veículos</a></h5></td> </tr> <tr> <td height="42"><h5><a href="buscar_reserva.php?flag=busca">Buscar Reserva</a></h5></td> </tr> <tr> <td height="42"><h5><a href="cadastrar_cliente.php">Cadastrar Cliente</a></h5></td> </tr> </table></td> <td width="645"><?php 105 echo("<center><h2>RESERVA DE HOSPEDAGEM</h2></center><br>"); echo("<center>Cliente não cadastrado!</center><br>"); echo("<center><a href=\"javascript:window.location='cadastrar_cliente.php?flag=cliente'\">Cadastrar Cliente</a></center>"); ?></td> </tr> </table> </center> </body> <?php } } ?> 106 INSERIR_RESERVA_HOSPEDAGEM.PHP <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" /> <title>HOTEL - Página Inicial</title> <style type="text/css"> <!-.style1 {font-family: Verdana, Arial, Helvetica, sans-serif} --> </style> </head> <body> <center> <table width="791" height="587" border="0"> <tr> <td colspan="2"><h3><h2>HOTEL</h3></td> </tr> <tr> <td width="136"> <table width="137" height="222" border="0"> <tr> <td height="48"><h5><a href="reserva_hospedagem.php?flag=hospedagem">Reservar Hospedagem</a></h5></td> </tr> <tr> <td height="43"><h5><a href="reserva_veiculo.php?flag=veiculo">Reservar Veículo</a></h5></td> </tr> <tr> <td height="42"><h5><a href="buscar_reserva_apto.php?flag=buscaa">Buscar Reserva Apto</a></h5></td> </tr> <tr> <td height="42"><h5><a href="buscar_reserva_veiculo.php?flag=buscav">Buscar Reserva Veiculo</a></h5></td> </tr> <tr> <td height="42"><h5><a href="cadastrar_cliente.php?flag=cliente">Cadastrar Cliente</a></h5></td> </tr> </table> </td> <td width="645"> <form id="form1" name="form1" method="post" action="inserir_hospedagem.php?idCliente=<?php echo ($_GET['idCliente']); ?>"> 107 <table border="1"><tr><td><p align="left"><label>Data de Chegada:</label></p></td><td><p align="left"><input type="text" name="dataChegada" tabindex="0" /></p></td></tr> <tr><td><p align="left"><label>Data de Saída:</label></p></td><td><p align="left"><label><input type="text" name="dataSaida" tabindex="1" /></td></tr> <tr><td><p align="left"><label>Quantidade de Adultos:</label></p></td><td><p align="left"><label><input type="text" name="numAdultos" tabindex="2" /></td></tr> <tr><td><p align="left"><label>Quantidade de Crianças (< 2 anos):</label></p></td><td><p align="left"><label><input type="text" name="numCriancas" tabindex="3" /></td></tr> <tr><td><p align="center"><label><input name="tipoApartamento" type="radio" value="1" /></label></p></td><td><p align="left"><label>Suíte de Luxo Ideal para 2 Adultos</label></p></td></tr> <tr><td><p align="center"><label><input name="tipoApartamento" type="radio" value="2" /></label></p></td><td><p align="left"><label>Suíte de Luxo Ideal para Casal</label></p></td></tr> <tr><td><p align="center"><label><input name="tipoApartamento" type="radio" value="3" tabindex="4" /></label></p></td><td><p align="left"><label>Suíte de Luxo - Ideal para Casal e 1 Criança (< 2 anos)</label></td></tr> <tr><td><p align="center"><label><input name="tipoApartamento" type="radio" value="4" tabindex="5" /></label></p></td><td><p align="left"><label>Suíte de Luxo - Ideal para Casal e 1 Criança (> 2 anos)</label> </td></tr> <tr><td><p align="center"><label><input name="tipoApartamento" type="radio" value="5" /></label></p></td><td><p align="left"><label>Suíte Standard Ideal para 2 Adultos</label></td></tr> <tr><td><p align="center"><label><input name="tipoApartamento" type="radio" value="6" /></label></p></td><td><p align="left"><label>Suíde Standard Ideal para Casal</label></td></tr> <tr><td><p align="center"><label><input name="tipoApartamento" type="radio" value="7" tabindex="6" /></label></p></td><td><p align="left"><label>Suíte Standard - Ideal para 2 Adultos e 1 Crinça (< 2 anos)</label></td></tr> <tr><td><p align="center"><label><input name="tipoApartamento" type="radio" value="8" /></label></p></td><td><p align="left"><label>Suíte Standard Ideal para 2 Adultos e 1 Criança (> 2 anos)</label></td></tr> <tr><td> </td><td><input type="submit" name="Submit" value="Concluir" /></td><tr> </form> </td> </tr> </table> </center> </body> </html> 108 INSERIR_HOSPEDAGEM.PHP <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" /> <title>Untitled Document</title> </head> <body> <?php $host="localhost"; $user="aplicacaoweb"; $password="aplicacaowebhotel"; $database="hotel"; $idHost=mysql_connect($host,$user,$password); if ($idHost){ $idDb=mysql_select_db($database,$idHost); } $sql=stripSlashes("insert into reservaapto values (null,".$_GET['idCliente'].",\"".$_POST['tipoApartamento']."\",NOW(),\"".$_POST['data Chegada']."\",\"".$_POST['dataSaida']."\",150,".$_POST['numAdultos'].",".$_POST['num Criancas'].",'reservada')"); $result=mysql_query($sql); if ($result>0){ echo "<h3>Reserva realizada!</h3>"; }else{ echo ("<h3>Reserva não realizada!</h3>"); echo(mysql_error($idHost)); } ?> </body> </html> 109 RESERVA_VEICULO.PHP <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" /> <title>HOTEL - Reserva de Veículo</title> <style type="text/css"> <!-.style1 {font-family: Verdana, Arial, Helvetica, sans-serif} --> </style> </head> <body> <center> <table width="791" height="587" border="0"> <tr> <td colspan="2"><h3><h2>HOTEL</h3></td> </tr> <tr> <td width="136"> <table width="137" height="222" border="0"> <tr> <td height="48"><h5><a href="reserva_hospedagem.php?flag=hospedagem">Reservar Hospedagem</a></h5></td> </tr> <tr> <td height="43"><h5><a href="reserva_veiculo.php?flag=veiculo">Reservar Veículo</a></h5></td> </tr> <tr> <td height="42"><h5><a href="buscar_reserva_apto.php?flag=buscaa">Buscar Reserva Apto</a></h5></td> </tr> <tr> <td height="42"><h5><a href="buscar_reserva_veiculo.php?flag=buscav">Buscar Reserva Veiculo</a></h5></td> </tr> <tr> <td height="42"><h5><a href="cadastrar_cliente.php?flag=cliente">Cadastrar Cliente</a></h5></td> </tr> </table> <td width="645"> <h2 align="center">RESERVA DE VEÍCULO</h2><br><br> <form id="form1" name="form1" method="post" action="buscar_idcliente.php?flag=veiculo"> 110 <label>CPF do Cliente: <input type="text" name="cpf" tabindex="0" /> </label> <label>Localizar <input type="submit" name="Submit" value="Submit" tabindex="1" /> </label> </form> <p align="center"><a href="cadastrar_cliente.php?flag=cliente">Cliente Não Cadastrado? Cadastrar</a></p> </td> </tr> </table> <center> </body> </html> 111 VEICULOS.PHP <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" /> <title>Untitled Document</title> </head> <body> <body> <center> <table width="791" height="587" border="0"> <tr> <td colspan="2"><h3><h2>HOTEL</h3></td> </tr> <tr> <td width="136"><table width="137" height="222" border="0"> <tr> <td height="48"><h5><a href="reserva_hospedagem.php">Reserva de Hospedagem</a></h5></td> </tr> <tr> <td height="43"><h5><a href="reserva_veiculo.php">Reserva de Veículos</a></h5></td> </tr> <tr> <td height="42"><h5><a href="buscar_reserva.php?flag=busca">Buscar Reserva</a></h5></td> </tr> <tr> <td height="42"><h5><a href="cadastrar_cliente.php">Cadastrar Cliente</a></h5></td> </tr> </table></td> <td width="645"> <?php $client = new SoapClient("http://localhost:8080/Locadora/locadora?WSDL"); $veiculos = ($client->buscarVeiculos(1,"senha1")); if (count($veiculos)<=0){ echo("Não existem veículos disponíveis para reserva!"); }else{ echo("<form id='form1' name='form1' method='post' action='inserir_reserva_veiculo.php?idCliente=".$_GET['idCliente']."'>"); echo("<table border='1'><tr><td></td><td></td></tr>"); 112 echo("<tr><td>Data de Chegada:</td><td><input type='text' name='dataRetirada' tabindex='0' /></td></tr>"); echo("<tr><td>Data de Saída:</td><td><input type='text' name='dataPrevDevolucao' tabindex='1' /></td></tr>"); for ($i=0;$i<count($veiculos);$i=$i+12){ echo("<tr><td><input name='idVeiculo' type='radio' value='".$veiculos[0]."'/></td><td>"); echo("<table><tr><td><p align='left'>Modelo:</p></td><td><p align='left'>".$veiculos[$i+1]."</p></td></tr>"); echo("<tr><td><p align='left'>Marca:</p></td><td><p align='left'>".$veiculos[$i+2]."</p></td></tr>"); echo("<tr><td><p align='left'>Cor:</p></td><td><p align='left'>".$veiculos[$i+3]."</p></td></tr>"); echo("<tr><td><p align='left'>Ano:</p></td><td><p align='left'>".$veiculos[$i+4]."</p></td></tr>"); echo("<tr><td><p align='left'>Portas:</p></td><td><p align='left'>".$veiculos[$i+5]."</p></td></tr>"); echo("<tr><td><p align='left'>Passageiros:</p></td><td><p align='left'>".$veiculos[$i+6]."</p></td></tr>"); echo("<tr><td><p align='left'>Habilitação:</p></td><td><p align='left'>".$veiculos[$i+7]."</p></td></tr>"); echo("<tr><td><p align='left'>Valor Quilômetro Adicional:</p></td><td><p align='left'>".$veiculos[$i+9]."</p></td></tr>"); echo("<tr><td><p align='left'>Valor Diária:</p></td><td><p align='left'>".$veiculos[$i+11]."</p></td></tr></table></td></tr>"); } echo("<tr><td> </td><td><input type='submit' name='Submit' value='Concluir' /></td></tr></table></form>"); } ?> </td> </tr> </table> </center> </body> </body> </html> 113 INSERIR_RESERVA_VEICULO.PHP <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" /> <title>HOTEL - Página Inicial</title> <style type="text/css"> <!-.style1 {font-family: Verdana, Arial, Helvetica, sans-serif} --> </style> </head> <body> <center> <table width="791" height="587" border="0"> <tr> <td colspan="2"><h3><h2>HOTEL</h3></td> </tr> <tr> <td width="136"><table width="137" height="222" border="0"> <tr> <td height="48"><h5><a href="reserva_hospedagem.php?flag=hospedagem">Reservar Hospedagem</a></h5></td> </tr> <tr> <td height="43"><h5><a href="reserva_veiculo.php?flag=veiculo">Reservar Veículo</a></h5></td> </tr> <tr> <td height="42"><h5><a href="buscar_reserva.php?flag=busca">Buscar Reserva</a></h5></td> </tr> <tr> <td height="42"><h5><a href="cadastrar_cliente.php?flag=cliente">Cadastrar Cliente</a></h5></td> </tr> </table></td> <td width="645"> <?php $client = new SoapClient("http://localhost:8080/Locadora/locadora?WSDL"); $aux = (int) $_POST['idVeiculo']; $reserva = $client>reservarVeiculo(1,"senha1",$aux,$_POST['dataRetirada'],$_POST['dataPrevDevolucao']); 114 if ($reserva>0){ echo("Reserva Realizada!"); $host="localhost"; $user="aplicacaoweb"; $password="aplicacaowebhotel"; $database="hotel"; $idHost=mysql_connect($host,$user,$password); if ($idHost){ $idDb=mysql_select_db($database,$idHost); } $reserva = (int) $reserva; $id = $_GET['idCliente']; $id = (int) $id; $insercao = "insert into reservaauto values (".$reserva.",".$id.",'a retirar')"; $query = mysql_query($insercao,$idHost); if ($query>0){ echo "<br>Banco de dados do cliente ok."; }else{ echo "<br>Banco de dados do cliente não atualizado. Erro: ".mysql_error($idHost); } }else{ echo("Reserva Não Realizada!"); } ?> </td> </tr> </table> </center> </body> </html> 115 BUSCAR_RESERVA_APTO.PHP <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" /> <title>HOTEL - Reserva de Veículo</title> <style type="text/css"> <!-.style1 {font-family: Verdana, Arial, Helvetica, sans-serif} --> </style> </head> <body> <center> <table width="791" height="587" border="0"> <tr> <td colspan="2"><h3><h2>HOTEL</h3></td> </tr> <tr> <td width="136"> <table width="137" height="222" border="0"> <tr> <td height="48"><h5><a href="reserva_hospedagem.php?flag=hospedagem">Reservar Hospedagem</a></h5></td> </tr> <tr> <td height="43"><h5><a href="reserva_veiculo.php?flag=veiculo">Reservar Veículo</a></h5></td> </tr> <tr> <td height="42"><h5><a href="buscar_reserva_apto.php?flag=buscaa">Buscar Reserva Apto</a></h5></td> </tr> <tr> <td height="42"><h5><a href="buscar_reserva_veiculo.php?flag=buscav">Buscar Reserva Veiculo</a></h5></td> </tr> <tr> <td height="42"><h5><a href="cadastrar_cliente.php?flag=cliente">Cadastrar Cliente</a></h5></td> </tr> </table> <td width="645"> <h2 align="center">BUSCA DE RESERVA DE APARTAMENTO</h2><br><br> <form id="form1" name="form1" method="post" action="buscar_idcliente.php?flag=buscaa"> 116 <label>CPF do Cliente: <input type="text" name="cpf" tabindex="0" /> </label> <label>Localizar <input type="submit" name="Submit" value="Submit" tabindex="1" /> </label> </form> <p align="center"><a href="cadastrar_cliente.php?flag=cliente">Cliente Não Cadastrado? Cadastrar</a></p> </td> </tr> </table> <center> </body> </html> 117 RESERVASA.PHP <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" /> <title>Untitled Document</title> </head> <body> <body> <center> <table width="791" height="587" border="0"> <tr> <td colspan="2"><h3><h2>HOTEL</h3></td> </tr> <tr> <td width="136"><table width="137" height="222" border="0"> <tr> <td height="48"><h5><a href="reserva_hospedagem.php">Reserva de Hospedagem</a></h5></td> </tr> <tr> <td height="43"><h5><a href="reserva_veiculo.php">Reserva de Veículos</a></h5></td> </tr> <tr> <td height="42"><h5><a href="buscar_reserva.php?flag=busca">Buscar Reserva</a></h5></td> </tr> <tr> <td height="42"><h5><a href="cadastrar_cliente.php">Cadastrar Cliente</a></h5></td> </tr> </table></td> <td width="645"> <?php $host="localhost"; $user="aplicacaoweb"; $password="aplicacaowebhotel"; $database="hotel"; mysql_connect($host,$user,$password); mysql_select_db($database); $consulta_reserva_apto="select cliente.nome, tipoapartamento.descricao, reservaapto.dataReserva, reservaapto.dataChegada, reservaapto.dataSaida, reservaapto.valorDiaria, reservaapto.numAdultos, reservaapto.numCriancas from cliente, 118 reservaapto, tipoapartamento where cliente.idCliente=".$_GET['idCliente']." and cliente.idCliente = reservaapto.idCliente and reservaapto.idTipoApto = tipoapartamento.idTipo and (not reservaapto.status='finalizada')"; $sql=stripSlashes($consulta_reserva_apto); $result=mysql_query($sql); if (!$result){ echo("Erro na consulta!"); echo("<a href=\"javascript:window.location='index.php'\">Página Inicial</a>"); }else{ $quantLinhas = mysql_num_rows($result); if ($quantLinhas>0){ $id=mysql_fetch_row($result); echo("<form id='form1' name='form1' method='post' action=''>"); echo("<table border='1'><tr> <td></td><td><center><h3>Reservas Localizadas</h3></center></td></tr>"); while ($id){ echo("<tr><td>Nome:</td><td>".$id[0]."</td></tr>"); echo("<tr><td>Apartamento:</td><td>".$id[1]."</td></tr>"); echo("<tr><td>Data da Reserva:</td><td>".$id[2]."</td></tr>"); echo("<tr><td>Data de Chegada:</td><td>".$id[3]."</td></tr>"); echo("<tr><td>Data de Saída:</td><td>".$id[4]."</td></tr>"); echo("<tr><td>Valor da Diária:</td><td>".$id[5]."</td></tr>"); echo("<tr><td>Número de Adultos:</td><td>".$id[6]."</td></tr>"); echo("<tr><td>Número de Crianças:</td><td>".$id[7]."</td></tr>"); $id=mysql_fetch_row($result); } echo("<tr><td> </td><td><input type='submit' name='Submit' value='Concluir' /></td></tr></table></form>"); }else{ echo("Nenhuma reserva encontrada!"); } } ?> </td> </tr> </table> </center> </body> </body> </html> 119 BUSCAR_RESERVA_VEICULO.PHP <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" /> <title>HOTEL - Reserva de Veículo</title> <style type="text/css"> <!-.style1 {font-family: Verdana, Arial, Helvetica, sans-serif} --> </style> </head> <body> <center> <table width="791" height="587" border="0"> <tr> <td colspan="2"><h3><h2>HOTEL</h3></td> </tr> <tr> <td width="136"> <table width="137" height="222" border="0"> <tr> <td height="48"><h5><a href="reserva_hospedagem.php?flag=hospedagem">Reservar Hospedagem</a></h5></td> </tr> <tr> <td height="43"><h5><a href="reserva_veiculo.php?flag=veiculo">Reservar Veículo</a></h5></td> </tr> <tr> <td height="42"><h5><a href="buscar_reserva_apto.php?flag=buscaa">Buscar Reserva Apto</a></h5></td> </tr> <tr> <td height="42"><h5><a href="buscar_reserva_veiculo.php?flag=buscav">Buscar Reserva Veiculo</a></h5></td> </tr> <tr> <td height="42"><h5><a href="cadastrar_cliente.php?flag=cliente">Cadastrar Cliente</a></h5></td> </tr> </table> <td width="645"> <h2 align="center">BUSCA DE RESERVA DE VEÍCULO</h2><br><br> <form id="form1" name="form1" method="post" action="buscar_idcliente.php?flag=buscav"> 120 <label>CPF do Cliente: <input type="text" name="cpf" tabindex="0" /> </label> <label>Localizar <input type="submit" name="Submit" value="Submit" tabindex="1" /> </label> </form> <p align="center"><a href="cadastrar_cliente.php?flag=cliente">Cliente Não Cadastrado? Cadastrar</a></p> </td> </tr> </table> <center> </body> </html> 121 RESERVASV.PHP <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" /> <title>Untitled Document</title> </head> <body> <body> <center> <table width="791" height="587" border="0"> <tr> <td colspan="2"><h3><h2>HOTEL</h3></td> </tr> <tr> <td width="136"><table width="137" height="222" border="0"> <tr> <td height="48"><h5><a href="reserva_hospedagem.php">Reserva de Hospedagem</a></h5></td> </tr> <tr> <td height="43"><h5><a href="reserva_veiculo.php">Reserva de Veículos</a></h5></td> </tr> <tr> <td height="42"><h5><a href="buscar_reserva.php?flag=busca">Buscar Reserva</a></h5></td> </tr> <tr> <td height="42"><h5><a href="cadastrar_cliente.php">Cadastrar Cliente</a></h5></td> </tr> </table></td> <td width="645"> <?php $host="localhost"; $user="aplicacaoweb"; $password="aplicacaowebhotel"; $database="hotel"; mysql_connect($host,$user,$password); mysql_select_db($database); $consulta_reserva_auto="select idReservaAuto from reservaauto where idCliente =".$_GET['idCliente']." and status='a retirar'"; $sql=stripSlashes($consulta_reserva_auto); 122 $result=mysql_query($sql); if (!$result){ echo("Erro na consulta!"); echo("<a href=\"javascript:window.location='index.php'\">Página Inicial</a>"); }else{ $quantLinhas = mysql_num_rows($result); if ($quantLinhas>0){ $id=mysql_fetch_row($result); while($id){ $client = new SoapClient("http://localhost:8080/Locadora/locadora?WSDL"); $reservas = ($client>buscarReservas(1,"senha1",$id[0],"","","a retirar")); if (count($reservas)<=0){ echo("Não existem reservas a retirar!"); }else{ echo("<table border='1'><tr> <td></td><td><center><h3>Reservas de Veículos Localizadas</h3></center></td></tr>"); for ($i=0;$i<count($reservas);$i+=12){ $idReserva=$reservas[$i]; echo("<tr><td>Data da Reserva:</td><td>".$reservas[$i+1]."</td></tr>"); $dataRetirada=$reservas[$i+2]; echo("<tr><td>Data Retirada:</td><td>".$dataRetirada."</td></tr>"); $dataPrevDevolucao=$reservas[$i+3]; echo("<tr><td>Data Prevista para Devolução:</td><td>".$dataPrevDevolucao."</td></tr>"); echo("<tr><td>Data de Devolução:</td><td>".$reservas[$i+4]."</td></tr>"); echo("<tr><td>Quilometragem Retirada:</td><td>".$reservas[$i+5]."</td></tr>"); echo("<tr><td>Quilometragem Devolução:</td><td>".$reservas[$i+6]."</td></tr>"); echo("<tr><td>Status:</td><td>".$reservas[$i+7]."</td></tr>"); echo("<tr><td>Valor do Quilometro:</td><td>".$reservas[$i+8]."</td></tr>"); echo("<tr><td>Valor da Diária:</td><td>".$reservas[$i+9]."</td></tr>"); echo("<tr><td>Identificador do Veículo:</td><td>".$reservas[$i+10]."</td></tr>"); echo("<tr><td>Identificador do Cliente:</td><td>".$reservas[$i+11]."</td></tr>"); echo("<tr><td><a href='cancelar_reserva.php?idReserva=".$idReserva."'>Cancelar</a></td><td><a href='alterar_reserva.php?idReserva=".$idReserva."&dataRetirada=".$dataRetirada."&da taPrevDevolucao=".$dataPrevDevolucao."'>Alterar</a></td></tr>"); 123 } }else{ ?> } } } echo("</table>"); } $id=mysql_fetch_row($result); echo("Nenhuma reserva encontrada!"); </td> </tr> </table> </center> </body> </body> </html><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" /> <title>Untitled Document</title> </head> <body> </body> </html> 124 CANCELAR_RESERVA.PHP <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" /> <title>Untitled Document</title> </head> <body> <body> <center> <table width="791" height="587" border="0"> <tr> <td colspan="2"><h3><h2>HOTEL</h3></td> </tr> <tr> <td width="136"><table width="137" height="222" border="0"> <tr> <td height="48"><h5><a href="reserva_hospedagem.php">Reserva de Hospedagem</a></h5></td> </tr> <tr> <td height="43"><h5><a href="reserva_veiculo.php">Reserva de Veículos</a></h5></td> </tr> <tr> <td height="42"><h5><a href="buscar_reserva.php?flag=busca">Buscar Reserva</a></h5></td> </tr> <tr> <td height="42"><h5><a href="cadastrar_cliente.php">Cadastrar Cliente</a></h5></td> </tr> </table></td> <td width="645"> ?> <?php $client = new SoapClient("http://localhost:8080/Locadora/locadora?WSDL"); $cancelar = ($client->cancelarReserva(1,"senha1",$_GET['idReserva'])); if (!$cancelar){ echo("Não foi possível cancelar a reserva!"); }else{ echo("Reserva cancelada!"); } 125 </td> </tr> </table> </center> </body> </body> </html> 126 ALTERAR_RESERVA.PHP <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" /> <title>Untitled Document</title> </head> <body> <body> <center> <table width="791" height="587" border="0"> <tr> <td colspan="2"><h3><h2>HOTEL</h3></td> </tr> <tr> <td width="136"><table width="137" height="222" border="0"> <tr> <td height="48"><h5><a href="reserva_hospedagem.php">Reserva de Hospedagem</a></h5></td> </tr> <tr> <td height="43"><h5><a href="reserva_veiculo.php">Reserva de Veículos</a></h5></td> </tr> <tr> <td height="42"><h5><a href="buscar_reserva.php?flag=busca">Buscar Reserva</a></h5></td> </tr> <tr> <td height="42"><h5><a href="cadastrar_cliente.php">Cadastrar Cliente</a></h5></td> </tr> </table></td> <td width="645"> <form name="form1" method="post" action="alterar_reserva_ws.php?idReserva=<?php echo($_GET['idReserva'])?>"> <label>Data de Retirada: </label><input type="text" name="dataRetirada" value=<?php echo($_GET['dataRetirada'])?> /> <label>Data Prevista Para Devolução: </label><input type="text" name="dataPrevDevolucao" value=<?php echo($_GET['dataPrevDevolucao'])?> /> <input type="submit" name="Submit" value="Alterar"/> </form> </td> </tr> </table> 127 </center> </body> </body> </html> 128 ALTERAR_RESERVA_WS.PHP <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" /> <title>Untitled Document</title> </head> <body> <body> <center> <table width="791" height="587" border="0"> <tr> <td colspan="2"><h3><h2>HOTEL</h3></td> </tr> <tr> <td width="136"><table width="137" height="222" border="0"> <tr> <td height="48"><h5><a href="reserva_hospedagem.php">Reserva de Hospedagem</a></h5></td> </tr> <tr> <td height="43"><h5><a href="reserva_veiculo.php">Reserva de Veículos</a></h5></td> </tr> <tr> <td height="42"><h5><a href="buscar_reserva.php?flag=busca">Buscar Reserva</a></h5></td> </tr> <tr> <td height="42"><h5><a href="cadastrar_cliente.php">Cadastrar Cliente</a></h5></td> </tr> </table></td> <td width="645"> <?php $client = new SoapClient("http://localhost:8080/Locadora/locadora?WSDL"); $alterar = ($client>alterarReserva(1,"senha1",$_GET['idReserva'],$_POST['dataRetirada'],$_POST['dataPre vDevolucao'])); if (!$alterar){ echo("Não foi possível alterar a reserva!"); }else{ echo("Reserva alterada!"); } 129 ?> </td> </tr> </table> </center> </body> </body> </html> 130 CADASTRAR_CLIENTE.PHP <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" /> <title>HOTEL - Cadastrar Cliente</title> <style type="text/css"> <!-.style1 {font-family: Verdana, Arial, Helvetica, sans-serif} --> </style> </head> <body> <center> <table width="791" height="587" border="0"> <tr> <td colspan="2"><h3><h2>HOTEL</h3></td> </tr> <tr> <td width="136"> <table width="137" height="222" border="0"> <tr> <td height="48"><h5><a href="reserva_hospedagem.php?flag=hospedagem">Reservar Hospedagem</a></h5></td> </tr> <tr> <td height="43"><h5><a href="reserva_veiculo.php?flag=veiculo">Reservar Veículo</a></h5></td> </tr> <tr> <td height="42"><h5><a href="buscar_reserva_apto.php?flag=busca">Buscar Reserva Apto</a></h5></td> </tr> <tr> <td height="42"><h5><a href="buscar_reserva_veiculo.php?flag=busca">Buscar Reserva Veiculo</a></h5></td> </tr> <tr> <td height="42"><h5><a href="cadastrar_cliente.php?flag=cliente">Cadastrar Cliente</a></h5></td> </tr> </table> <td width="645"> <h2>CADASTRO DE CLIENTE</h2><br><br> <form id="form1" name="form1" method="post" action=""> <table> 131 /></td></tr> /></td></tr> /></td></tr> <tr><td>CPF:</td><td><input type="text" name="cpf" tabindex="0" <tr><td>Nome:</td><td><input type="text" name="nome" tabindex="1" <tr><td>E-mail:</td><td><input type="text" name="email" tabindex="3" <tr><td>Endereço:</td><td><input type="text" name="endereco" tabindex="4" /></td></tr> <tr><td>Complemento:</td><td><input type="text" name="complemento" tabindex="5" /></td></tr> <tr><td>Cidade:</td><td><input type="text" name="cidade" tabindex="6" /></td></tr> <tr><td>UF:</td><td><input type="text" name="uf" tabindex="7" /></td></tr> <tr><td>CEP:</td><td><input type="text" name="cep" tabindex="8" /></td></tr> <tr><td>Bairro:</td><td><input type="text" name="bairro" tabindex="9" /></td></tr> <tr><td>Telefone:</td><td><input type="text" name="telefone" tabindex="10" /></td></tr> <tr><td> </td><td><input type="submit" name="submit" value="Confirmar" tabindex="11" /></td></tr> </table> </form> </td> </tr> </table> </center> </body> </html>