当前位置: 首页 > 编程笔记 >

在Nginx上部署ThinkPHP项目教程

伏欣悦
2023-03-14
本文向大家介绍在Nginx上部署ThinkPHP项目教程,包括了在Nginx上部署ThinkPHP项目教程的使用技巧和注意事项,需要的朋友参考一下

前段时间用Apache配合TP开发了一个小型网站,也算是我使用TP的第一次实战。我习惯使用pathinfo模式,本地运行一切正常,然而部署到服务器上时,由于对方使用的是Nginx,默认是不支持ThinkPHP的pathinfo模式,所以导致路径错误,出现了页面循环跳转的问题,于是就把nginx下载下来在本地亲自测试。

      其实,要解决nginx不支持pathinfo的问题,有两个解决思路,一是不使用pathinfo模式,二是修改nginx的配置文件,使它支持pathinfo。为了使问题简单化,我选择了第一种方式,因为就第二种方式,我查了很多资料,发现大家的方法不尽相同,有的还差别很大,容易造成误导,所以我选择从简出发,选择普通模式,虽然有一定的风险。当把index.php对应的前台代码修改完毕之后,发现前台基本正常,可是后台仍然出现重定向的问题。折腾了半天之后,我才想到看一下日志文件,原来是编辑器的问题,看来日志文件真的很重要,以前一直不重视。在config.php文件的第一行出现了输出,

      在sublime下,一般会为UTF-8文件添加BOM头,这个BOM头在window下通常是看不见的,可以通过其他的编辑器查看到,Linux下也可以直接看到,通常显示出来是一个乱码字符,把这个字符删除即可,或者简单一点,直接在第一行回车,再删除就可以了。到这里,后台基本可以访问了。

      有几个小问题需要说明一下。

      1.在登录的时候,我是通过外部js文件发送Ajax请求进行验证的,在js与ThinkPHP模块函数通信遇到了点问题,一直不知道正确的路径该怎么写,也没有查到相关资料,只能各种试,好在找到了解决办法,通过直接带上入口文件名的方式,代码如下


 var url="system.php?m=Login&a=doLog";

 $.post(url,{"staffname":$staffname,"staffpwd":$staffpwd,"verifycode":$verifycode},function(data){

     if(data=="codeerr"){

           alert("验证码错误!");

     }else if(data=="authempty"){

           alert("请输入用户名或密码!")

     }else if(data=="autherr"){

           alert("用户名或密码错误!");

     }else if(data=="success"){

           alert("登录成功!");

            location.href="system.php?m=Index&a=index";   //访问首页

     }

    当然,此为普通模式下的访问方式,如果是pathinfo的话,只需要把红色部分如下修改即可


 var url="doLog";

 $.post(url,{"staffname":$staffname,"staffpwd":$staffpwd,"verifycode":$verifycode},function(data){

       if(data=="codeerr"){

               alert("验证码错误!");

       }else if(data=="authempty"){

               alert("请输入用户名或密码!")

       }else if(data=="autherr"){

               alert("用户名或密码错误!");

       }else if(data=="success"){

               alert("登录成功!");

               location.href="../Index/index";   //跳转首页,访问其他模块的方法

      2.下载文件的时候,总是莫名多出许多html的东西,原因是缓冲区没有清空,可以通过以下代码进行修改,不过这种方式实际上是下载的仍然是html格式的文件,只不过改了一下后缀名为xls而已,因而用excel打开的时候会提示格式问题,忽略即可。同时需要注意使用 icov()函数转换编码,因为xls默认编码格式并非utf-8.


ob_start();

ob_end_clean();

Header( "Content-type: application/octet-stream"); 

Header( "Accept-Ranges: bytes "); 

Header( "Content-type:application/vnd.ms-excel;charset=gb2312");   

Header( "Content-Disposition:attachment;filename={$filename}.xls");

      3.在删除文件时会遇到路径问题,因为项目中使用的较多的是相对路径,即相对入口文件而言,但是删除文件则需要使用绝对路径,我并没有找到合适的解决方法,只好用了比较保守的方式,代码如下


 $path="./Public/uploads/";    

 $path=str_replace("\\","/",realpath($path)."/");  //获取绝对路径,并转换分隔符

       4.在配置nginx和php方面,我使用了fastCGI的方式,将如下代码保存为cmd文件,直接点击运行就可以了

"F:\php\php-cgi.exe" -b 127.0.0.1:9000 -c "F:\php\php.ini"     //后面是php文件的路径
      然后在nginx的配置文件里加上几句话


 location ~ \.php/?.* {

            root           myapplications;

            fastcgi_pass   127.0.0.1:9000;

             fastcgi_index  index.php;

             fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;

            include        fastcgi_params;

            #定义变量 $path_info ,用于存放pathinfo信息

             set $path_info "";

             #定义变量 $real_script_name,用于存放真实地址

             set $real_script_name $fastcgi_script_name;

             #如果地址与引号内的正则表达式匹配

             if ($fastcgi_script_name ~ "^(.+?\.php)(/.+)$") {

                     #将文件地址赋值给变量 $real_script_name

                     set $real_script_name $1;

                     #将文件地址后的参数赋值给变量 $path_info

                     set $path_info $2;

             }

             #配置fastcgi的一些参数

             fastcgi_param SCRIPT_FILENAME $document_root$real_script_name;

             fastcgi_param SCRIPT_NAME $real_script_name;

             fastcgi_param PATH_INFO $path_info;

         }

 类似资料:
  • 本文向大家介绍Python开发之Nginx+uWSGI+virtualenv多项目部署教程,包括了Python开发之Nginx+uWSGI+virtualenv多项目部署教程的使用技巧和注意事项,需要的朋友参考一下 1、新建独立运行环境,命名为env 2、激活虚拟环境 [root@vultr projects]# source env/bin/activate 执行后命令提示符前面会出现一个env

  • 今天的目标是完成一个 Python Web 项目的线上部署,我们使用最新的 Django 项目搭建一个简易的 Web 工程,然后基于 Nginx 服务部署该 Python Web 项目。 1. 前期准备 1.1 安装虚拟环境pyenv 首先要知道,使用虚拟环境逐渐成了 python 项目开发中的一种主流方式。pyenv 可以帮我们生成多个 python 的虚拟环境,这样我可以在同一台机器上使用 p

  • 本文向大家介绍CentOS8上用Docker部署开源项目Tcloud的教程,包括了CentOS8上用Docker部署开源项目Tcloud的教程的使用技巧和注意事项,需要的朋友参考一下 一、安装Docker 1、我是虚拟机装的Centos7,linux 3.10 内核,docker官方说至少3.8以上,建议3.10以上(ubuntu下要linux内核3.8以上) root账户登录,查看内核版本如下

  • 2. 项目部署 本章主要介绍如何部署Camel。 首先,介绍Vagrant这个虚拟机工具。借助Vagrant,我们可以保证本地开发及测试环境与线上环境的一致。 随后介绍slb-admin的部署。管理端本地也要安装Dengine,用以测试Nginx配置文件的语法是否正确。此外,还需要部署数据库:MySQL及MongoDB。 最后介绍Nginx服务器的部署。我们可以根据具体需求部署Nginx集群,每台

  • 描述 本文档提供了 3 种部署方式,对应 Jboot 里的 3 种打包方式。 通过 脚本 运行 在 打包方式 文档中,我们可以把项目打包成一个 .zip 的压缩包项目,里面带有 jboot.sh (和 jboot.bat) 执行脚本, 只需要我们解压 .zip 压缩文件,通过如下命令就可以对 jboot 项目进行启动和停止。 # 启动 ./jboot.sh start # 停止 ./jboot.

  • 部署中,你可以先构建打包生成环境代码,再启动服务。因此,构建和启动分为下面两条命令: next build next start 例如,使用now去部署package.json配置文件如下: { "name": "my-app", "dependencies": { "next": "latest" }, "scripts": { "dev": "next",