Php Homestead VM上的Moodle安装错误

Php Homestead VM上的Moodle安装错误,php,nginx,moodle,homestead,Php,Nginx,Moodle,Homestead,我已经在我的Mac(OSX约塞米蒂)上安装了Homestead虚拟机和Moodle安装文件夹。我还创建了“moodledata”文件夹,并通过我的系统命令行授予其权限0777以及“moodledata/sessions”文件夹(我尝试在VM内通过SSH执行此操作,但似乎没有更改权限)。但是,通过我的系统检查权限后,发现该文件夹可以从VM内部写入 然后,我继续进行安装,该安装运行并创建了DB表,并进行了检查,其中显示了2个检查警告: 要检查的Intl和xmlrpc 我不相信这些是必要的初始安装,所

我已经在我的Mac(OSX约塞米蒂)上安装了Homestead虚拟机和Moodle安装文件夹。我还创建了“moodledata”文件夹,并通过我的系统命令行授予其权限0777以及“moodledata/sessions”文件夹(我尝试在VM内通过SSH执行此操作,但似乎没有更改权限)。但是,通过我的系统检查权限后,发现该文件夹可以从VM内部写入

然后,我继续进行安装,该安装运行并创建了DB表,并进行了检查,其中显示了2个检查警告: 要检查的Intl和xmlrpc

我不相信这些是必要的初始安装,所以进行。当我开始创建管理员用户时,我遇到了一个问题。页面(/user/editadvanced.php?id=2)停止加载任何图像,当我发布表单时,我收到一个错误:“提交的sesskey不正确,表单未接受!” 我想这可能是由于会话不能在moodledata文件夹中写入,但是我已经检查过了,现在我没有想法了

我附上了几个截图

非常感谢,迈克


好的,经过几天的努力,我通过编辑NGINX配置文件解决了自己的问题。以下是默认情况下的情况:

server {
    listen 80;
    server_name example.com;
    root /home/forge/example.com;

    # FORGE SSL (DO NOT REMOVE!)
    # ssl_certificate;
    # ssl_certificate_key;

    ssl_protocols TLSv1 TLSv1.1 TLSv1.2;

    index index.html index.htm index.php;

    charset utf-8;

    location / {
        try_files $uri $uri/ /index.php?$query_string;
    }

    location = /favicon.ico { access_log off; log_not_found off; }
    location = /robots.txt  { access_log off; log_not_found off; }

    access_log off;
    error_log  /var/log/nginx/example.com-error.log error;

    error_page 404 /index.php;

    location ~ \.php$ {
        fastcgi_split_path_info ^(.+\.php)(/.+)$;
        fastcgi_pass unix:/var/run/php5-fpm.sock;
        fastcgi_index index.php;
        include fastcgi_params;
    }

    location ~ /\.ht {
        deny all;
    }
}
这就是我把它改成的,它现在起作用了:

server {
    listen 80;
    server_name example.com; #REPLACE SERVER NAME

    root /var/www/example.com/www/; #REPLACE MOODLE INSTALL PATH
    error_log /var/www/example.com/log/example.com_errors.log; #REPLACE MOODLE ERROR LOG PATH
    access_log /var/www/example.com/log/example.com_access.log; #REPLACE MOODLE ACCESS LOG PATH

    rewrite ^/(.*\.php)(/)(.*)$ /$1?file=/$3 last;

    location / {
        index index.php index.html index.htm;
        try_files $uri $uri/ /index.php;
    }

    fastcgi_intercept_errors on;

    location ~ \.php$ {
        fastcgi_split_path_info ^(.+\.php)(/.+)$;

        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;

        fastcgi_pass unix:/var/run/php5-fpm.sock;
        fastcgi_index index.php;

        include fastcgi_params;
    }

    location ~ /\.ht {
        deny all;
    }
}

我还没来得及看看上面配置的哪个部分解决了这个问题,也许有人知道可以直接看到?我怀疑这可能是重写规则?不管怎样,我希望这能在将来帮助其他人,我真的很高兴能让这一切顺利进行

我可以确认,这只是该特定配置文件的重写部分,尽管在页面中没有以这种方式记录


我猜
location~[^/]\.php(/|$){
部分与重写规则
rewrite^/(.\.php)(/)(.*)$/$1?文件=/$3 last;
location~\.php$做的事情是一样的{
指令。将需要进行一些测试来更改location指令,以查看其是否也起作用。

进一步调查后,仅此一行:rewrite^/(.\.php)(/)(.*)(.*))$/$1?file=/$3 last;Moodle现在有一个特定的nginx配置页面:我可以确认,如果没有重写规则,这是行不通的,那么:为什么Moodle没有记录它?或者我们做错了什么?