7

我们正在将 Moodle 添加到我们的站点(不同的服务器,不同的子域,但相同的主域,并且服务器设置为能够相互通信),我们希望它做的是:

  • 用户访问主站点
  • 用户登录
  • 用户单击指向 Moodle 的链接
  • 用户无需重新输入信息即可自动登录 Moodle
  • 如果用户添加书签或直接访问 Moodle,他们仍然可以直接登录

我们已经使用 db auth(外部数据库身份验证)设置了它,因此主站点的帐户也适用于 Moodle,我只是不知道如何让 Moodle 接受现有凭据并自动登录用户。

4

1 回答 1

11

所以我能够解决这个问题,并认为我会分享我的解决方案,以防其他人将来遇到类似问题。

由于我们的 Moodle 站点和主站点在同一个域上,我所做的是在主站点的登录脚本中,我添加了以下代码:

$postData = array('username' => $username, 'password' => $password);
$post = http_post_fields('http://moodle.example.com/login/index.php', $postData);
$headers = http_parse_headers($post);
foreach($headers['Set-Cookie'] as $cookie)
{
    $details = http_parse_cookie($cookie);
    foreach ($details->cookies as $name => $value)
        setcookie($name, $value, $details->expires, $details->path, 'example.com');
}

基本上,我使用 http_post_fields 将登录凭据发布到 moodle 登录脚本,尽管 cURL 应该也可以工作,解析标头以获取 cookie Moodle 集,然后使用基本域而不是更具体的 Moodle 子域自己设置这些 cookie。如果用户拥有来自更具体的子域的现有 cookie,这可能会导致一些问题,因此请务必删除名称为 MoodleSession 的任何现有 cookie。

于 2013-04-17T15:26:57.140 回答