复制代码代码如下:
class MyFramework_Soap_server extends Zend_Soap_Server {
protected $_login = '';
保護された $_password = '';
パブリック関数 __construct($wsdl = null, array $options = null) {
parent::__construct($wsdl,$options);
if(isset($options['login'])){
$this->_login=$options['login'];
$this->_password=$options['パスワード'];
$this->_authenticate();
}
}
プライベート関数 _authenticate(){
$this->setAuthenticate($this->_login,$this->_password);
}
パブリック関数 setHttpLogin($login){
$this->login=$login;
}
パブリック関数 setHttpPassword($password){
$this->_password=$password;
if(isset($this->_login)){
$this->_authenticate();
}
}
public function setAuthenticate($login,$password){
if ($_SERVER['PHP_AUTH_USER']!=$login || $_SERVER['PHP_AUTH_PW']!=$password) {
header('WWW -認証: 基本レルム="MyFramework レルム"');
header('HTTP/1.0 401 Unauthorized');
echo "このリソースにアクセスするには、有効なログイン ID とパスワードを入力する必要があります。n";
終了;
}
}
}
?>
复制代码代码如下:
class Soap_server_test {
public $view = '';
パブリック $params = '';
パブリック $requestObj = '';
パブリック $dbObj = '';
function __construct() {
$this->view = $GLOBALS['view'];
$this->params = $GLOBALS['params'];
$this->requestObj = $GLOBALS['requestObj'];
$this->dbObj = $GLOBALS['dbObj'];
}
関数indexAction(){
if(isset($_GET['wsdl'])) {
$autodiscover = new MyFramework_Soap_AutoDiscover();
$autodiscover->setClass('Model_Service_SoapClassSetTest');
$autodiscover->handle();
終了;
} else {
//$opti => 'UTF-8','ログイン'=>'唐建','パスワード'=>'123456');
$opti => 'UTF-8');
$soap = new MyFramework_Soap_Server("http://tj.MyFramework.com/default/soap_server_test/index?wsdl",$options);
$soap->setHttpLogin('tangjian');
$soap->setHttpPassword('123456');
$soap->setClass('Model_Service_SoapClassSetTest');
$soap->handle();
終了;
}
}
関数 clientAction() {
//$opti => 'UTF-8','login'=>'tangjian','password'=>'123456',
// 'compression' =>SOAP_COMPRESSION_GZIP);
$opti => 'UTF-8',
'圧縮' =>SOAP_COMPRESSION_GZIP);
$client = new MyFramework_Soap_Client('http://tj.MyFramework.com/default/soap_server_test/index?wsdl',$options);
$client->setHttpLogin('tangjian');
$client->setHttpPassword('123456');
$result=$client->getPass('tang',"man");
print_r($result);
}
}
?>
以上、php ペイコードを介して zend_soap を再封入し、http 接続の安全認証を実現する php ペイ コードで、php ペイコードに関する内容が含まれており、PHP 教則に関心のある友人の助けになることが望ましいです。