Php Moodle接受来自外部站点的登录

Php Moodle接受来自外部站点的登录,php,moodle,Php,Moodle,我们正在将Moodle添加到我们的站点(不同的服务器、不同的子域,但相同的主域,并且服务器被设置为能够相互通信),我们希望它能够做到: 用户访问主站点 用户登录 用户单击Moodle的链接 用户将自动登录到Moodle,而无需重新输入其信息 如果用户添加书签或直接访问Moodle,他们仍然可以直接登录 我们已经使用db auth(外部数据库认证)设置了它,因此来自主站点的帐户也适用于Moodle,我只是不知道如何让Moodle接受现有凭据并自动登录用户。因此,我能够解决这个问题,并认为我会分

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

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

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

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

由于我们的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_字段将登录凭据发布到moodle登录脚本,尽管cURL也可以工作,但我解析了头以获得cookies moodle集,然后自己使用基本域而不是更具体的moodle子域来设置这些cookies。如果用户拥有来自更特定子域的现有cookie,则可能会导致一些问题,因此,请务必删除任何名为MoodleSession的现有cookie。

您是否使用了一个域或两个子域?如果它位于不同的域上?您能否帮助我如何将您的外部站点连接到您的moodle..我尝试了很多..但我做不到..您能帮助我吗