Moodle接受从外部站点登录

时间:2013-04-15 14:27:26

标签: php moodle

我们正在将Moodle添加到我们的站点(不同的服务器,不同的子域,但是相同的主域,并且服务器设置为能够彼此通信),我们想要它做的是:< / p>

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

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

1 个答案:

答案 0 :(得分:10)

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

由于我们的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也可以正常工作,解析标题以获取Moodle设置的cookie,然后使用基本域而不是更具体的Moodle自行设置这些cookie子域。如果用户具有来自更具体的子域的现有cookie,则可能会导致一些问题,因此请务必删除名称为MoodleSession的任何现有cookie。