怎么搭建php服务器?

怎么搭建php服务器?,第1张

在windows下安装apache php mysql。

从各官方网站下了APACHE2.050、PHP5、MYSQL4.0.20、PHPMYADMIN2.57。

apache_2.0.50-win32-x86-no_ssl.msi。

php-5.0.0-Win32.zip。

较好的可移植性、可靠性以及较高的运行效率使 PHP 语言在当下行业网站建设中独占鳌头。利用 PHP 语言进行行业网站设计,能够实现数据库的实时性更新,网站的日常维护和管理简单易行,进而提高用户的使用效率。

扩展资料:

PHP加密:

加密总是与安全密不可分,而每个PHPer都必须将应用安全作为必要的设计思路融入代码中,以下是一些最佳实践的建议。

不要再使用MD5,不要使用sha1,基本上已经没有破解难度了。请使用 password_hash来哈希密码,由于 password_hash函数已帮你处理好了加盐。

而且作为盐的随机字串已通过加密算法成为了哈希的一部分password_verify()函数会自动将盐从哈希中提取出来,所以你无需考虑盐的存储问题。通信接口的签名,请使用非对称算法对签名秘钥进行加密, 并对秘钥设置有效期,定期更换。

参考资料来源:百度百科-PHP

vue在服务端部署时,我们都知道通过npm run build 指令打包好的dist文件,通过http指定是可以直接浏览的,Thinkphp通过域名指向index.php文件才可以浏览。要使前端正常调用后端数据,有两种方法:1、前端跨域调用后端数据,2、前端打包文件部署在后端的服务器文件夹下(同域)。

web服务器: apache

一、跨域

在服务器配置站点:

在路径/home/www/  下创建test项目文件夹,用来放项目文件。  

找到httpd-vhosts.conf文件配置站点  

前端站点:  

    ServerName test.test.com  

    DocumentRoot "/home/www/test/dist"    

    DirectoryIndex index.html  

后端站点:  

    ServerName test.testphp.com  

    DocumentRoot "/home/www/test/php"    

    DirectoryIndex index.php  

将前端打包好的dist文件放在/home/www/test/ 文件夹下,运行http://test.test.com可浏览,当路径改变时,刷新会出现404错误。此时dist文件下创建一个.htaccess文件,当路径不存在时,路径指向http://test.test.com/index.html能解决此问题。

  RewriteEngine On  

  RewriteBase /  

  RewriteRule ^index\.html$ - [L]  

  RewriteCond %{REQUEST_FILENAME} !-f  

  RewriteCond %{REQUEST_FILENAME} !-d  

  RewriteRule . /index.html [L]  

在/home/www/test文件夹下创建项目根目录php文件夹,将thinkphp文件放在php下。TP5的入口文件在public文件下,在这将public下的入口文件index.php挪到php文件夹下(个人习惯将入口文件放在项目根目录), 后端绑定Index模块。

前端调用后端接口,存在跨域,跨域解决方法有好几种,在这我将在后端php做配置,解决跨域问题,在公用控制器设置跨域配置:

class Common extends Controller  

{  

    public $param  

    // 设置跨域访问  

    public function _initialize()  

    {  

        parent::_initialize()  

        isset($_SERVER['HTTP_ORIGIN']) ? header('Access-Control-Allow-Origin: '.$_SERVER['HTTP_ORIGIN']) : ''  

        header('Access-Control-Allow-Credentials: true')  

        header('Access-Control-Allow-Methods: GET, POST, PUT, DELETE, OPTIONS')  

        header("Access-Control-Allow-Headers: Origin, X-Requested-With, Content-Type, Accept, authKey, sessionId")  

$param =  Request::instance()->param()  

$this->param = $param  

    }  

}  

前端调用登录接口: this.axios.post('http://test.testphp.com/index.php/base/login', {user: '', password: ''})。

(可在webpack.base.conf.js文件下可定义接口:http://test.testphp.com/index.php/)

二、同域

后端配置同上,公共配置器中的header配置注释。将前端的dist文件下的所有文件(包含.htaccess),放在php文件夹下。将后端index控制器的index方法的路径重定向php下的index.html文件:

namespace app\index\controller  

use think\Controller  

class Index extends Controller  

{  

    public function index() {  

$this->redirect('/index.html')  

    }  

}  

前端调用登录接口: this.axios.post('/index.php/base/login', {user: '', password: ''})

转自:https://blog.csdn.net/qq_35465132/article/details/78986675

1,切换到nginx的配置目录,找到nginx.conf文件

    cd   /usr/local/nginx/conf

    vim  nginx.conf

2,如果是单项目部署的话,只需要在nginx.conf文件里面加上以下

server{

        listen 80

        # 域名,本地测试可以使用127.0.0.1或localhost

        server_name www.zhangc.cn

        # php项目根目录

        root /home/data-www/blog

        location /{

                # 定义首页索引文件的名称

                index index.php index.html index.htm

                # 影藏入口文件

                if (-f $request_filename/index.html){

                            rewrite (.*) $1/index.html break

                }

                if (-f $request_filename/index.php){

                            rewrite (.*) $1/index.php

                }

                if (!-f $request_filename){

                            rewrite (.*) /index.php

                }

                try_files $uri $uri/ /index.php?$query_string

        }

        # PHP 脚本请求全部转发到 FastCGI处理. 使用FastCGI协议默认配置.

        # Fastcgi服务器和程序(PHP)沟通的协议

        .location ~ .*\.php${

                # 设置监听端口

                fastcgi_pass 127.0.0.1:9000

                # 设置nginx的默认首页文件

                fastcgi_index index.php

                # 设置脚本文件请求的路径

                fastcgi_param SCRIPT_FILENAME$document_root$fastcgi_script_name

                # 引入fastcgi的配置文件

                includefastcgi_params

                fastcgi_split_path_info ^(.+?\.php)(/.*)$

                set $path_info $fastcgi_path_info

                fastcgi_param PATH_INFO $path_info

                try_files $fastcgi_script_name =404

        }

}

3,如果多项目部署,就需要配置vhost

第一步:编辑nginx.conf文件,在最后加上     include    vhost/*.conf

第二步:进入vhost文件夹,创建    域名.conf    文件,如创建一个:quanma.meyat.com.conf

第三步:编辑quanma.meyat.com.conf文件,内容如下:

        server

        {

                listen 80

                server_name quanma.meyat.com

                index index.html index.htm index.php default.html default.htm default.php

                root /data/wwwroot/default/quanma/public/

                #error_page 404 /404.html

                location / {

                        index index.html index.php

                        if (-f $request_filename/index.html){

                                rewrite (.*) $1/index.html break

                        }

                        if (-f $request_filename/index.php){

                                rewrite (.*) $1/index.php

                        }

                        if (!-f $request_filename){

                                rewrite (.*) /index.php

                        }

                        try_files $uri $uri/ /index.php?$query_string

                }

                location ~ [^/]\.php(/|$)

                {

                        # comment try_files $uri =404to enable pathinfo

                        #try_files $uri =404

                        fastcgi_pass 127.0.0.1:9000

                        fastcgi_index index.php

                        include fastcgi_params

                        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name

                        fastcgi_split_path_info ^(.+?\.php)(/.*)$

                        set $path_info $fastcgi_path_info

                        fastcgi_param PATH_INFO $path_info

                        try_files $fastcgi_script_name =404

                        #include fastcgi.conf

                        #include pathinfo.conf

            }

            location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$

            {

                    expires 30d

            }

            location ~ .*\.(js|css)?$

            {

                    expires 12h

            }

            # Disallow access to .ht, .svn, .bzr, .git, .hg, .cvs directories

            location ~ /\.(ht|svn|bzr|git|hg|cvs) {

                    deny all

            }

            #access_log /date/nginx/bmp.com.conf/access.log main

}


欢迎分享,转载请注明来源:夏雨云

原文地址:https://www.xiayuyun.com/zonghe/84680.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-03-05
下一篇2023-03-05

发表评论

登录后才能评论

评论列表(0条)

    保存