centos nginx php codeigniter配置

2017-09-01  本文已影响0人  bosshida

2017-09-01

昨天想用CI重写一个公众号的功能,因为之前用thinkphp3写的,感觉现在不想再看回原代码了。以前是LAMP,现在因为服务器配置较低,装了LNMP。

花了很多时间来配置nignx,CI在NGINX上要配置,但我对NGINX一点都不懂,有空时要认真学下NGINX配置。现在记录一下昨天的做的配置,以备以后可能会用到,也会以后有人遇到同样问题可以快速解决。因为到目前我都没学到nginx的配置,本文章只是以自己的认识来写,可能有部分名词或理解是不恰当的,之后学习了nginx配置后再来更改。

首先说明一下,我的CI项目放在二级目录。就是说,我网站默认的访问目录是www,在www目录下,放置了index.php,是可以通过域名/index.php或直接域名来访问成功的。而我的CI项目是放丰www目录下的project目录(按自己的项目命名)。目录结构如下:

- www
  -- index.php
  -- project
    --- application
    --- system
    --- index.php
    --- ...

关于nginx的配置:

首先进入nginx的conf目录,系统默认用nginx.conf为配置文件,打开nginx.conf,里面有个http{...}的配置项,nginx都是以这种形式作为配置项的。留意最后一行是

include conf.d/*.conf;

这行代表,nginx启动时会包括conf.d目录下的所有.conf后缀的文件作为补充配置文件。

接着打开当前目录(把nginx的conf目录)的conf.d目录,有个default.conf文件,先把这个文件备份,以防之后修改到不成功,还可以运行原来的文件。

然后打开default.conf,里面有个server{}的配置项,在stackoverflow上有人说要改server_name,但我试了不改也是可以运行的。主要要改动的地方是在server{}内增加一个配置项。

当前可以看到server{}内有很多类似如下的配置项:

location / {
  ...
}

首先我把location /{}这个配置项修改为:

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

注意:location/{之间必须要有空格,有一次少输一个空格就提示配置文件错误。#是注释的一行,换成try_files一行,就可以了。每一行必须要以;结束。

然后在这个配置项下,增加一个配置项:

location /project/ {
  alias /www/project/;
  try_files $uri $uri/ /project/index.php;
  location ~ \.php$ {
    fastcgi_split_path_info ^(.+\.php)(/.+)$;
    fastcgi_index   index.php;
    fastcgi_pass    127.0.0.1:9000;
    include        fastcgi_params;
    fastcgi_param   SCRIPT_FILENAME $request_filename;
  }
}

然后重启nginx就可以。其实之前看stackoverflow都已经修改成这样的配置,但试了还不行,就是因为没重启nginx。之前用apche,在centos里直接service httpd restart就可以了,但我的centos不能通过service重启,找不到服务。为了重启nginx也是费了很多时间去找方法。最后看到一种方法,进入nginx的sbin目录,执行如下两行命令:

./nginx -s stop
./nginx

这样就重启了nignx。另外可以通过nginx -t path/to/conf_file来测试配置文件是否有错误。

nginx这时就配置完成了。接着要配置一下CI.

进入www/project/application/config,找到config.php文件,把如下三项修改为

$config['base_url'] = 'http://your_host_url/';
$config['index_page'] = '';
$config['uri_protocol'] = 'REQUEST_URI';

然后访问你的项目的controller的方法,应该就可以的了。

另外,再说下,CI与dodgepudding/wechat-php-sdk的配合使用。

本来想用overtrue/easywechat的,刚好昨天他的论坛挂了,一直上不了,想看文档都看不了,就换回这个以前用过的库,对于微信公众号的简单开发其实也够用了。

dodgepudding/wechat-php-sdk要与CI整合,其实也很简单,不用composer。

  1. 首先下载 wechat.class.php ,放在application\vendor目录下(可能需要新建vendor目录),我把wechat.class.php文件名的w改为大写W。

  2. 然后下载 CI_Wechat.php 放在application\libraries目录下,修改里面的require_once代码

    //这个是要根据你的项目目录配置,用这个应该都没问题的了
    require_once(APPPATH . 'vendor/Wechat.class.php');
    
  3. CI_Wechat.php文件里,可以看到会导入config目录里的wechat.php配置文件里的wechat配置项。这需要在application\config目录里新增一个wechat.php文件。编辑此文件,内容如下:

    <?php
    $config['wechat'] = [
                'app_id' => 'your_app_id',
                'secret' => 'your_app_secret',
                'token' => 'your_token',
                'log' => [
                    'level' => 'debug',
                    'file' => '../logs',
                ],
            ];
    
  4. 最后在application/controller里,新增或使用默认的controller,里面用如下代码,就可以成功在微信公众平台,修改开发配置了。

    <?php
    class Weixin extends CI_Controller {
    
        public function index() {
            $this->load->library('CI_Wechat');
            $this->ci_wechat->valid();
            $type = $this->ci_wechat->getRev()->getRevType();
            switch($type){
                case Wechat::MSGTYPE_TEXT:
                    $this->ci_wechat->text("reply text")->reply();
                    exit;
                    break;
                default:
                        $this->ci_wechat->text("welcome")->reply();
            }
        }
    
    }
    

    注意:如果配置通过后,把$this->ci_wechat->valid();这一行注释掉。

到此为止,简单的把LNMP+CI+wechat-php-sdk就整合完成,可以进行功能开发了。

上一篇下一篇

猜你喜欢

热点阅读