我在本地计算机上安装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 /路径中,并更改第一行即可,现在可以使用了。

10-08 09:21