我在本地计算机上安装SimpleSAMLPHP,所以我构建了2个虚拟主机:
<VirtualHost auth.saml.net>
ServerAdmin [email protected]
ServerName auth.saml.net
AddDefaultCharset UTF-8
Alias /simplesaml c:/wamp/www/Idp/simplesamlphp/www/
<Directory c:/wamp/www/Idp/simplesamlphp/www/ >
Order Deny,Allow
Allow from all
</Directory>
</VirtualHost>
<VirtualHost client.saml.net>
ServerAdmin [email protected]
ServerName client.saml.net
AddDefaultCharset UTF-8
Alias /simplesaml c:/wamp/www/Sp/simplesamlphp/www/
<Directory c:/wamp/www/Sp/simplesamlphp/www/ >
Order Deny,Allow
Allow from all
</Directory>
</VirtualHost>
第一个用于我的身份提供者,第二个用于我的服务提供者。
但是当我尝试通过这种方式连接到我的身份提供者时:
require_once('../../Sp/simplesamlphp/lib/_autoload.php');
$authService = new SimpleSAML_Auth_Simple("default-sp");
$authService->requireAuth();
我有这个错误:
SimpleSAML_Error_NoState: NOSTATE
Backtrace:
2 C:\wamp\www\Sp\simplesamlphp\lib\SimpleSAML\Auth\State.php:225 (SimpleSAML_Auth_State::loadState)
1 C:\wamp\www\Sp\simplesamlphp\modules\saml\www\sp\saml2-acs.php:63 (require)
0 C:\wamp\www\Sp\simplesamlphp\www\module.php:134 (N/A)
我在某个论坛上看到,在那种情况下,我必须替换config / config.php文件:
'store.type' => 'phpsession',
创建人:
'store.type' => 'sql',
所以我替换了服务提供者和身份提供者上的文件:
'store.type' => 'sql',
'store.sql.dsn' => 'mysql:host=localhost;dbname=test',
'store.sql.username' => 'root',
'store.sql.password' => '',
'store.sql.prefix' => 'simpleSAMLphp',
我有一些到达数据库的数据,但是我仍然遇到相同的错误。
奇怪的是,当我尝试在服务提供商平台上直接将我连接到身份提供商时,我没有此错误。
最佳答案
我发现解决方案是小白痴。
当我尝试通过这种方式连接到服务提供商时:
require_once('../../Sp/simplesamlphp/lib/_autoload.php');
$authService = new SimpleSAML_Auth_Simple("default-sp");
$authService->requireAuth();
我在本地主机上,而不在服务提供商(client.saml.net)上,因此我只需要将文件移动到/ Sp / simplesamlphp / www /路径中,并更改第一行即可,现在可以使用了。