加入收藏 | 设为首页 | 会员中心 | 我要投稿 安卓应用网 (https://www.0791zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > PHP > 正文

php – Moodle接受从外部网站登录

发布时间:2020-05-25 09:16:55 所属栏目:PHP 来源:互联网
导读:我们将Moodle添加到我们的站点(不同的服务器,不同的子域,但是相同的主域,并且服务器设置为能够彼此通信),我们想要它做的是: 用户访问主站点 用户登录 用户单击指向Moodle的链接 用户无需重新输入信息即可自动登录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_fields将登录凭据发布到moodle登录脚本,虽然cURL也可以正常工作,解析标题以获取Moodle设置的cookie,然后使用基本域而不是更具体的Moodle子域自己设置这些cookie.如果用户具有来自更具体的子域的现有cookie,则可能会导致一些问题,因此请务必删除名称为MoodleSession的任何现有cookie.

(编辑:安卓应用网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读