Php Homestead VM上的Moodle安装错误
我已经在我的Mac(OSX约塞米蒂)上安装了Homestead虚拟机和Moodle安装文件夹。我还创建了“moodledata”文件夹,并通过我的系统命令行授予其权限0777以及“moodledata/sessions”文件夹(我尝试在VM内通过SSH执行此操作,但似乎没有更改权限)。但是,通过我的系统检查权限后,发现该文件夹可以从VM内部写入 然后,我继续进行安装,该安装运行并创建了DB表,并进行了检查,其中显示了2个检查警告: 要检查的Intl和xmlrpc 我不相信这些是必要的初始安装,所以进行。当我开始创建管理员用户时,我遇到了一个问题。页面(/user/editadvanced.php?id=2)停止加载任何图像,当我发布表单时,我收到一个错误:“提交的sesskey不正确,表单未接受!” 我想这可能是由于会话不能在moodledata文件夹中写入,但是我已经检查过了,现在我没有想法了 我附上了几个截图 非常感谢,迈克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 我不相信这些是必要的初始安装,所
好的,经过几天的努力,我通过编辑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没有记录它?或者我们做错了什么?