> 백엔드 개발 > PHP 튜토리얼 > webservice——nusoap 자세한 설명

webservice——nusoap 자세한 설명

WBOY
풀어 주다: 2016-07-30 13:30:12
원래의
1533명이 탐색했습니다.

PHP SOAP 서버

PHP와 NuSoap을 사용하여 SOAP 서버를 설정하는 것은 매우 쉽습니다. 기본적으로 웹 서비스에 노출하려는 기능을 작성하고 NuSoap에 등록하기만 하면 됩니다. 좋습니다. PHP SOAP 서버 설정을 완료하려면 두 가지 단계가 더 필요합니다. 먼저, PHP 코드에서 NuSoap 개체의 인스턴스를 생성한 다음 HTTP POST 메서드를 사용하여 원본 데이터를 NuSoap에 전달하여 처리해야 합니다.

NuSOAP의 사용은 다음과 같습니다. 상대적으로 간단하며 가장 일반적으로 사용되는 클래스는 비누서버(soap_server)와 비누클라이언트(이며, 그 중 비누서버(soap_server)는 웹서비스 서비스를 생성하는 데 사용되고, 비누클라이언트 클래스는 웹서비스(를 호출하는 데 사용된다). 클래스는 lib/nusoap.php 에 있으므로 Webservice 인터페이스 프로그램을 생성하거나 호출할 때 이 파일을 참조해야 합니다.

NuSoap은 PHP 환경에서 사용되는 WebService 프로그래밍 도구입니다. WebService를 생성하거나 호출합니다. 이는 HTTP를 통해 SOAP 메시지를 보내고 받는 PHP 언어로 완전히 작성된 일련의 PHP 클래스인 오픈 소스 소프트웨어입니다. NuSphere Corporation(http://dietrich.ganx4.com/nusoap/)에서 개발했습니다. NuSOAP의 한 가지 장점은 확장 라이브러리 지원이 필요하지 않다는 것입니다. 이 기능을 사용하면 NuSoap을 모든 PHP 환경에서 사용할 수 있으며 서버 보안 설정의 영향을 받지 않습니다.

1.먼저 http://sourceforge.net/projects/nusoap에 접속합니다. / nusoap.zip을 다운로드하세요.
2.
서버: nusoapService.php 파일을 생성합니다.

[php] 일반 사본 보기

  1. require_once("lib /nusoap.php"); 비누서버();
  2. // 문자 깨짐 방지 $server->soap_defencoding = 'UTF-8'
  3. $server
  4. ->decode_utf8 = false >'UTF-8' '테스트'); 🎜>// wsdl 지원 열기
  5. / *
  6. 클라이언트가 접근해야 하는 프로그램을 등록하세요 해당 값 입력: bool ->"xsd:boolean" string->"xsd: string"
  7. int->"xsd:int" float->"xsd :float" */ $server
  8. ->등록( 'GetTestStr',
  9. // 메소드 이름
  10. 배열 (
  11. "name" => "xsd:string"
  12. ), // 매개변수, 기본값은 "xsd:string"
  13. array ("return" => "xsd:string" ) ) // 반환 값, 기본값은 "xsd:string"
  14. //isset 변수 설정 여부 확인 $HTTP_RAW_POST_DATA = isset ( $HTTP_RAW_POST_DATA
  15. ) ?
  16. $HTTP_RAW_P OST_DATA : ''; //service 클라이언트가 입력한 데이터를 처리합니다.
  17. $server->서비스( $HTTP_RAW_POST_DATA
  18. 🎜>기능
  19. GetTestStr($name) {  return "안녕하세요, { $name } !";
  20. } ?>
  21. 3.클라이언트:
  22. nusoapClient.php 생성
  23. 파일입니다.
  24. [php] 일반 사본 보기
    1. require_once("lib /nusoap.php");
    2. /* >WSDL을 통해 WebService 호출
    3. 매개변수 1 WSDL 파일의 주소(물음표 뒤의 wsdl은 대문자로 사용할 수 없음)
    4. 매개변수 2는 다음을 지정합니다. WSDL 사용
    5. $client = newsoapclient('http://localhost/nusoapService.php?wsdl', true);
    6. */
    7. $client
    8. =
    9. 비누 클라이언트( 'http://localhost/nusoapService.php' ); 🎜>$client->soap_defencoding = 'UTF-8'
    10. $client->decode_utf8 = false
    11. $client->xml_encoding = 'UTF-8';
    12. //매개변수는 배열 형식으로 Pass로 변환됩니다.
    13. $paras = 배열 (
    14. '이름' =>; '이소룡' ) // 대상 메소드에 매개변수가 없는 경우 다음 매개변수는 생략 가능
    15. $result
    16. = $client->call(
    17. 'GetTestStr'
    18. , $paras ) // 오류를 확인하고 반환 값을 가져옵니다.
    19. if
    20. (! $err =
    21. $client
    22. ->getError ()) {  echo " 반환 결과: ",
    23. $result
    24. ; } else { echo " 호출 오류: "
    25. ,
    26. $err;
    27. ? >  [php] 일반 사본 보기
      1. require_once("lib /nusoap.php");
      2. /* >WSDL을 통해 WebService 호출
      3. 매개변수 1 WSDL 파일의 주소(물음표 뒤의 wsdl은 대문자로 사용할 수 없음)
      4. 매개변수 2는 다음을 지정합니다. WSDL 사용
      5. $client = newsoapclient('http://localhost/nusoapService.php?wsdl', true);
      6. */
      7. $client
      8. =
      9. 비누클라이언트( 'http://localhost/nusoapService.php?wsdl',true); $client->soap_defencoding = 'UTF-8'
      10. $client->decode_utf8 = false
      11. $client
      12. - >xml_encoding = 'UTF-8';
      13. / / 매개변수는 배열 형식으로 전달됩니다.
      14. $paras
      15. = 배열 (
      16. '이름'
      17. => '이소룡' ) / / 대상 메소드에 매개변수가 없는 경우 다음 매개변수는 생략 가능
      18. $client
      19. -> 호출( 'GetTestStr',
      20. $paras
      21. ) $document = $client->document
      22. echo $document;
      23. 참고: 반환 결과: 안녕하세요, { Bruce 이씨 } ! WSDL
      24. WSDL은 웹 서비스를 설명하는 데 사용되는 XML 언어입니다. 웹 서비스 클라이언트에 서비스에 접근하는 데 필요한 모든 정보를 제공하는 기계가 읽을 수 있는 형식입니다. NuSOAP는 특히 WDSL 파일을 구문 분석하고 해당 파일에서 정보를 추출하는 클래스를 제공합니다. Soapclient 개체는 wsdl 클래스를 사용하여 개발자가 서비스를 더 쉽게 호출할 수 있도록 합니다. WSDL 정보를 사용하여 메시지를 생성함으로써 프로그래머는 이를 호출하기 위한 작업의 이름과 매개변수만 알면 됩니다.
      25. NuSOAP를 통해 WSDL을 사용하면 다음과 같은 이점이 있습니다. 네임스페이스, 엔드포인트 URL, 매개변수 이름 등과 같은 모든 서비스 메타파일을 WSDL 파일에서 직접 얻을 수 있으므로 클라이언트가 다음에 동적으로 적응할 수 있습니다. 서버측 변경. 이 데이터는 항상 서버에서 사용할 수 있으므로 더 이상 사용자 스크립트에 이 데이터를 하드 코딩할 필요가 없습니다. soap_proxy 클래스를 사용할 수 있습니다. 이 클래스는 Soapclient 클래스에서 파생되며 WDSL 파일에 자세히 설명된 작업에 해당하는 메서드를 추가합니다. 이제 사용자는 이를 통해 이러한 메소드를 직접 호출할 수 있습니다.
      soapclient 클래스에는 비누_proxy 클래스의 객체를 반환하는 getProxy() 메서드가 포함되어 있습니다. Soap_proxy 클래스는 Soapclient 클래스에서 파생되며 WSDL 문서에 정의된 작업에 해당하는 메서드를 추가하고 사용자가 끝점의 원격 메서드를 호출할 수 있도록 합니다. 이는 비누클라이언트 개체가 WDSL 파일로 초기화된 경우에만 적용됩니다. 장점은 사용자가 사용하기 쉽다는 것이고 단점은 성능입니다. PHP에서 객체를 생성하는 데 시간이 많이 걸리고 실용적인 목적에 부합하지 않습니다(그리고 이 기능은 실용적인 목적을 제공하지 않습니다).






      [php ] 일반 사본 보기

      1. require_once("lib /nusoap.php"); 비누 클라이언트(
      2. 'http://localhost/nusoapService.php?wsdl'
      3. ,true); $client->soap_defencoding = 'UTF-8'
      4. $client->decode_utf8 = false 'UTF-8';
      5. // 프록시 클래스 생성 $proxy =
      6. $client->getProxy(); >//원격 함수 호출
      7. $sq = $proxy
      8. ->GetTestStr(
      9. '브루스 리'); > (!$err=$proxy
      10. ->getError()) { print_r($sq
      11. ) 🎜>인쇄 "ERROR : $err"
      12.  print '요청:'<span></span>.<span></span>$p<span></span>->request.
      13. ''
      14. ; '응답:'.str_replace
      15. ('><' , ">n<"
      16. , $p->응답)' '
      17. ?> :http://localhost/
      18. nusoapService .php에서 생성된 wsdl 파일
      19. 메소드 이름을 클릭하세요. 이런 식으로 서비스에 몇 줄의 코드를 추가함으로써 NuSOAP를 사용하는 서비스에 대한 시각적 문서를 제공합니다. 하지만 그것이 우리가 할 수 있는 전부는 아닙니다. NuSOAP를 사용하여 서비스에 일부 WSDL 호출을 추가하면 서비스에 대한 WSDL 및 기타 문서를 생성할 수 있습니다. 대조적으로, 적어도 우리의 간단한 예에서는 클라이언트에서 할 수 있는 일이 많지 않습니다. 아래의 클라이언트는 WSDL을 사용하지 않는 클라이언트와 다르지 않습니다. 유일한 차이점은 이전과 같이 서비스 엔드포인트 대신 WSDL의 URL을 제공하여 Soapclent 클래스를 구문 분석한다는 것입니다. NuSoap이 WebService를 호출할 때 잘못된 코드에 대한 솔루션: [php] 일반 사본 보기$client->soap_defencoding = 'utf-8'$client->decode_utf8 = false; 
      $client


      ->xml_encoding = 'utf-8'; >

      파일 코드는 출력이 있습니다, 그렇지 않으면 호출 시 다음과 유사한 오류가 보고됩니다.

      라인 x(

      라인 번호

      )에서 SOAP 페이로드를 구문 분석하는 중 XML 오류: 예약된 XML 이름

      webservice——nusoap 자세한 설명

      nusoap

      을 사용하여

      WebService를 구현합니다.

      php
      1. SOAP 확장, 는 nusoap의 SoapClient 클래스와 php5로 인해 내장- SOAP 클래스에서. 해결책
      2. 1. php5의 내장 비누 확장(Windows에서는 php_soap.dll)을 로드하지 않도록 php.ini를 수정합니다.
      3. 2. 일부는 nusoap의 SoapClient 클래스 이름도 변경했습니다. 본인인증
      [php] 일반 사본 보기

      1. 헤더('content-type: text/xml; charset=UTF-8 ');  
      2. require_once('nusoap.php');  
      3. $params = 배열('인증 헤더'  =>  배열(  
      4.     '콘텐츠 유형' =>  'text/xml;  charset=UTF-8',  
      5.     'SOAPAction'  =>  '사용자 기능',  
      6. )  
      7. );  
      8. $client = new nusoap_client('http:// www.yourdomain.com/service.asmx?wsdl', true, '''''''');  
      9. $client->setHeaders('    
      10. "http://tempuri.org/webservice">  

    28.   사용자 이름< ;/tns:사용자 이름>   
    29.   password     
    30.  
    31. ');  
    32. $err = $client->getError();  
    33. if ($err) {  
    34.     에코 '

      생성자 오류

      '</span><span> . </span><span>$오류</span><span> . </span><span>'
      '
      ;  
    35. }  
    36. $result = $client->call('YourFunction'$params'''', 거짓, 참);  
    37. if ($client->fault) {  
    38.     에코 '

      Fault

      '</span><span>;  </span></span></li>
      <li><span>    print_r(<span>$result</span><span>);  </span></span></li>
      <li><span>    <span>에코</span><span> </span><span>'
      '
      ;  
    39. 그밖에 {  
    40.     $err  = $client->getError();  
    41.      ($err) {  
    42.         에코 '

      오류

      '</span><span> . </span><span>$오류</span><span> . </span><span>'
      '
      ;  
    43.     } 그밖에 {  
    44.         에코 '

      결과

      <사전>'
      ;  
    45. //print_r($result);  
    46.          에코 '';  
    47.     }  
    48. }
    49. 에코 '

      요청

      <사전>'
      . htmlspecialchars($client->요청, ENT_QUOTES) '';
    50. 에코 '

      응답

      '</span><span><.>$client</.></span><span>->응답, ENT_QUOTES) </span><span>'
      '
      ?> 위의 내용은 webservice-nusoap에 대한 자세한 설명을 포함하여 PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.
관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿