我使用这种方法从服务器端获取数据到客户端。但我在验证服务器文件时遇到了问题。
在允许读取数据之前,我想检查用户名和密码。我试着用一种额外的方法,但我不起作用。
服务器
class MyService
{
public function add($x, $y)
{
return $x + $y;
}
}
$options = array(
'uri' => 'http://server/namespace',
'location' => 'http://server/location',
);
$server = new SOAPServer(null, $options);
$server->setObject(new MyService());
$server->handle();
客户端
$options = array(
'uri' => 'http://server/namespace',
'location' => 'http://server/location',
);
$client = new SOAPClient(null, $options);
echo $client->add(10, 10);
发布于 2015-08-04 20:08:05
如果您可以使用硬编码的用户名和密码以及HTTP基本身份验证,则可以将以下代码放在服务器文件的顶部:
if (! isset($_SERVER['PHP_AUTH_USER']) ||
$_SERVER['PHP_AUTH_USER'] !== 'foo' ||
$_SERVER['PHP_AUTH_PW'] !== 'bar') {
header('WWW-Authenticate: Basic realm="My service"');
header('HTTP/1.1 401 Unauthorized');
echo 'Unauthorized';
exit;
}
这将检查HTTP身份验证数据是否存在,如果不存在,将向客户端发送HTTP 401错误。如果存在身份验证数据,则将根据硬编码用户名foo和密码栏对其进行验证。
为了从客户端脚本中传递用户名/密码,请按以下方式调整客户机中的$options
:
$options = array(
'uri' => 'http://server/namespace',
'location' => 'http://server/location',
'login' => 'foo', // username
'password' => 'bar' // password
);
$client = new SOAPClient(null, $options);
请注意,HTTP基本身份验证是最简单的设置,但用户名和密码将以准纯文本形式传输到服务器。因此,至少应该对服务端点使用SSL,以便对所有通信进行加密。
HTTP摘要身份验证更安全,因为它只发送凭据的散列,但它需要更多的工作来设置。一个很好的起点是the HTTP authentication page in the PHP manual。
为了验证服务器端接收到的用户名/密码数据,您还可能希望使用具有有效用户名/密码/登录令牌的数据库,而不是使用示例中的硬编码凭据。
发布于 2015-08-03 10:49:33
为什么不将username+pass作为soap中的一个参数发送。在服务器端,您应该有一个基本对象,它具有所有的身份验证逻辑,并让"MyService“继承它。基对象将始终处理请求,如果它通过身份验证,则将详细信息传递给MyService。
https://stackoverflow.com/questions/31751719
复制相似问题