• +86 18940128339
  • 3056844889@qq.com

Category Archive PHP

Docker搭建 nginx+php+mysql+redis

一.创建 /app/www /app/docker_files

二. /app/www 项目目录

三.docker配置目录

1.nginx 创建目录 /app/www/nginx /app/www/nginx/

Dockerfile

from nginx
COPY ./conf/conf.d/ /etc/nginx/conf.d/
COPY ./conf/certs/ /etc/nginx/certs/
COPY ./conf/nginx.conf /etc/nginx/nginx.conf

2.php 创建目录 /app/docker_files/php

Dockerfile

FROM php:8.0-fpm

ENV WWW_PATH "/www"

RUN mkdir ${WWW_PATH}

RUN  sed -i s@/archive.ubuntu.com/@/mirrors.aliyun.com/@g /etc/apt/sources.list
RUN  sed -i s@/deb.debian.org/@/mirrors.aliyun.com/@g /etc/apt/sources.list
RUN  apt-get clean


RUN pecl install redis-5.3.7 && docker-php-ext-enable redis

RUN apt-get update && apt-get install -y \
		libfreetype6-dev \
		libjpeg62-turbo-dev \
		libpng-dev \
	&& docker-php-ext-configure gd --with-freetype --with-jpeg \
	&& docker-php-ext-install -j$(nproc) gd

RUN apt-get install -y \
    zlib1g-dev \
    libzip-dev

RUN docker-php-ext-install zip
RUN docker-php-ext-install pdo pdo_mysql
RUN docker-php-ext-install bcmath

RUN apt-get install -y procps
RUN apt-get install -y vim
RUN apt-get install -y supervisor

WORKDIR ${WWW_PATH}

RUN php -r "copy('https://install.phpcomposer.com/installer', 'composer-setup.php');" && php composer-setup.php && php -r "unlink('composer-setup.php');"

RUN mv composer.phar /usr/local/bin/composer

RUN composer config -g repo.packagist composer https://mirrors.aliyun.com/composer

3.redis 创建目录/app/docker_files/redis

Dockerfile

FROM redis
COPY ./redis.conf /usr/local/etc/redis/redis.conf

4.mysql 创建目录 /app/docker_files/mysql /app/docker_files/mysql/conf /app/docker_files/mysql/data

Dockerfile

FROM mysql:5.7

COPY conf/ /etc/mysql/conf.d/
COPY data/ /var/lib/mysql/

EXPOSE 3306

5. docker-comose.yml 配置

version: '3'
services:
  web:
    build: './nginx'
    image: 'nginx-server:1.0'
    container_name: 'nginx-server'
    ports:
      - "80:80"
      - "443:443"
    volumes:
      - '/app/docker_files/nginx/conf/nginx.conf:/etc/nginx/nginx.conf'
      - '/app/docker_files/nginx/conf/conf.d:/etc/nginx/conf.d'
      - '/app/docker_files/nginx/conf/certs:/etc/nginx/certs'
      - '/app/www:/usr/share/nginx/html'
    networks:
      - lnmp
  php:
    build: './php'
    image: 'php-server:1.0'
    container_name: 'php-server'
    ports:
      - "9000:9000"
    volumes:
      - "/app/www:/www"
    networks:
      - lnmp
  redis:
    build: './redis'
    image: 'redis-server:1.0'
    container_name: 'redis-server'
    ports:
      - "6379:6379"
    networks:
      - lnmp
  db:
    build: './mysql'
    image: 'db-server:1.0'
    container_name: 'db-server'
    ports:
      - "3366:3306"
    volumes:
      - "/app/docker_files/mysql/conf:/etc/mysql/conf.d"
      - "/app/docker_files/mysql/data:/var/lib/mysql"
    restart: always
    environment:
      MYSQL_ROOT_PASSWORD: 123456
    networks:
      - lnmp
networks:
  lnmp:
    driver: bridge

laravel

1.创建一个名为laravel的laravel项目

composer create-project laravel/laravel --prefer-dist ./QZ_20_0712

命令解释:

composer:表示执行该程序;

create-project :创建项目

laravel/laravel:需要创建的项目名称;

–prefer-dist:优先下载压缩包方式,而不是直接从GitHub上下载源码

2.php artisan

(1)数据表

//创建迁移 建表
php artisan make:migration create_demo_table
//重建数据库,在原本的迁移文件中增加字段后执行
php artisan migrate:refresh
//数据表迁移
php artisan migrate
//数据表回滚
php artisan migrate:rollback

(2)功能列表

php artisan list

(3)make 列表

  make:cast             Create a new custom Eloquent cast class
  make:channel          Create a new channel class
  make:command          Create a new Artisan command
  make:component        Create a new view component class
  make:controller       Create a new controller class
  make:event            Create a new event class
  make:exception        Create a new custom exception class
  make:export           Create a new export class
  make:factory          Create a new model factory
  make:import           Create a new import class
  make:job              Create a new job class
  make:listener         Create a new event listener class
  make:mail             Create a new email class
  make:middleware       Create a new middleware class
  make:migration        Create a new migration file
  make:model            Create a new Eloquent model class
  make:notification     Create a new notification class
  make:observer         Create a new observer class
  make:policy           Create a new policy class
  make:provider         Create a new service provider class
  make:request          Create a new form request class
  make:resource         Create a new resource
  make:rule             Create a new validation rule
  make:seeder           Create a new seeder class
  make:test             Create a new test class

PHP常用代码

PHP读写文件的方法

文件操作

// 判断是否是一个文件
var_dump(is_file('./demo.txt')); // bool(true)

// 读取文件字节数
var_dump(filesize('./demo.txt')); // int(11)

// 文件重命名
rename('./demo.txt', './demo.txt.bak');

// 删除文件
unlink('./demo.txt');

写入文件

// 打开文件
$file = fopen('./demo.txt', 'w');
// 只读:r
// 读写,文件覆盖:r+
// 清空写入:w
// 可创建清空写入:w+
// 追加写入:a
// 创建追加写入:a+

// 写入内容到文件
fwrite($file, 'Hello World');
// 关闭文件
fclose($file);

读取文件内容

// 写入内容到文件
fwrite($file, 'Hello World');
// 关闭文件
fclose($file);
$file = fopen('./demo.txt', 'r');
$filesize = filesize('./demo.txt');
$content = fread($file, $filesize);
var_dump($content); // string(11) "Hello World"
fclose($file);

通过快捷方式读取文件内容

// 读取文件到数组
$lines = file('./demo.txt');
var_dump($lines);
// array(4) {
//     [0]=>string(7) "赠人"
//     [1]=>string(22) "李群玉〔唐代〕"
//     [2]=>string(49) "曾留宋玉旧衣裳,惹得巫山梦里香。"
//     [3]=>string(48) "云雨无情难管领,任他别嫁楚襄王。"
// }
// 读取文件内容
$lines = file_get_contents('./demo.txt');
var_dump($lines);
// string(126) "赠人
// 李群玉〔唐代〕
// 曾留宋玉旧衣裳,惹得巫山梦里香。
// 云雨无情难管领,任他别嫁楚襄王。"

PHP常见问题

一.cookie和session的作用和区别

cookie数据保存在客户端,session数据保存在服务端

session:

简单的说,当你登陆一个网站的时候,如果web服务器端使用的是session,那么所有的数据都保存在服务器上,客户端每次请求服务器的时候会发送当前会话sessionid,服务器根据当前sessionid判断相应的用户数据标志,以确定用户是否登陆或具有某种权限。由于数据是存储在服务器上面,所以你不能伪造。

cookie:

sessionid是服务器和客户端连接时候随机分配的,如果浏览器使用的是cookie,那么所有数据都保存在浏览器端,比如你登陆以后,服务器设置了cookie用户名,那么当你再次请求服务器的时候,浏览器会将用户名一块发送给服务器,这些变量有一定的特殊标记。服务器会解释为cookie变量,所以只要不关闭浏览器,那么cookie变量一直是有效的,所以能够保证长时间不掉线。

如果你能够截获某个用户的cookie变量,然后伪造一个数据包发送过去,那么服务器还是 认为你是合法的。所以,使用cookie被攻击的可能性比较大。

如果cookie设置了有效值,那么cookie会保存到客户端的硬盘上,下次在访问网站的时候,浏览器先检查有没有cookie,如果有的话,读取cookie,然后发送给服务器。

所以你在机器上面保存了某个论坛cookie,有效期是一年,如果有人入侵你的机器,将你的cookie拷走,放在他机器下面,那么他登陆该网站的时候就是用你的身份登陆的。当然,伪造的时候需要注意,直接copy cookie文件到 cookie目录,浏览器是不认的,他有一个index.dat文件,存储了 cookie文件的建立时间,以及是否有修改,所以你必须先要有该网站的 cookie文件,并且要从保证时间上骗过浏览器

两个都可以用来存私密的东西,session过期与否,取决于服务器的设定。cookie过期与否,可以在cookie生成的时候设置进去。

二.Redis五种类型的常用命令

1.String常用命令 get、set、incr、decr、mget

2.List 常用命令:lpush、lpop、rpush、rpop、llen

lpush:从列表List的左边插入一个元素。

lpop:从列表List的左边移出一个元素。

rpush:从列表List的右边插入一个元素。

rpop:从列表List的右边移出一个元素。

llen:打印当前列表List中的元素个数。

3.Set 常用命令 sadd、srem、scard、sismember

sadd:往set中添加数据。

srem:从set中删除数据。

scard:查看set中存在的元素个数。

sismember:查看set中是否存在某个数据。

4.hash 常用命令 hget、hset、hmget

hget:通过key值,从hash里取对应的value

hset:往hash里,添加key-value

hmget:一次性获取多个key的value

5.zset (有序集合)常用命令 zadd、zcard、zrange、zrem、zrevrange

zadd:添加数据

zrem:删除元素

zrem 还可以一次性删除多个元素:

zcard:查询数据

zrange:数据排序,根据分数从小到大

ChatGPT PHP

1.聊天模型

$curl = curl_init();
curl_setopt_array($curl, array(
    CURLOPT_URL => "https://api.openai.com/v1/chat/completions",
    CURLOPT_RETURNTRANSFER => true,
    CURLOPT_ENCODING => "",
    CURLOPT_MAXREDIRS => 10,
    CURLOPT_TIMEOUT => 0,
    CURLOPT_FOLLOWLOCATION => true,
    CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
    CURLOPT_CUSTOMREQUEST => "POST",
    CURLOPT_POSTFIELDS => json_encode(array(
        "model" => "gpt-3.5-turbo",
        'max_tokens' => 2000,
        "messages" => [array("role" => "user", "content" => $prompt)],
    )),
    CURLOPT_HTTPHEADER => array(
        "Content-Type: application/json",
        "Authorization: Bearer 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",
    ),
));
$response = curl_exec($curl);
curl_close($curl);

2.图片生成

$curl = curl_init();
curl_setopt_array($curl, array(
    CURLOPT_URL => "https://api.openai.com/v1/images/generations",
    CURLOPT_RETURNTRANSFER => true,
    CURLOPT_ENCODING => "",
    CURLOPT_MAXREDIRS => 10,
    CURLOPT_TIMEOUT => 0,
    CURLOPT_FOLLOWLOCATION => true,
    CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
    CURLOPT_CUSTOMREQUEST => "POST",
    CURLOPT_POSTFIELDS => json_encode(array(
        "prompt" => $prompt,
        "n" => 1,
        "size" => "1024x1024",
        'response_format' => "b64_json",
    )),
    CURLOPT_HTTPHEADER => array(
        "Content-Type: application/json",
        "Authorization: Bearer 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",
    ),
));
$response = curl_exec($curl);
curl_close($curl);