作者: admin

  • php验证码

    demo:https://www.dongshushu.com/yanzhengma/index.php

    验证码authcode.php

    <?php 
    
    //设置画布大小和颜色
    $image = imagecreatetruecolor(100,30);
    
    $bgcolor = imagecolorallocate($image,255,255,255);
    
    imagefill($image,0,0,$bgcolor);
    
    //设置session变量
    session_start();
    $code = '';
    
    
    // 输出验证码内容
    
    for($i=0;$i<4;$i++){
    
    $data = 'abcdefghijklmnopqrstuvwxyz123456789';
    
    $content = substr($data,rand(0,strlen($data)-1),1);
    
    
    $textcolor = imagecolorallocate($image,rand(0,100),rand(0,100),rand(0,100));
    
    $fontsize = 6 ;
    
    $x = ($i*100/4)+6;
    
    $y = rand(2,10);
    
    imagestring($image,$fontsize,$x,$y,$content,$textcolor);
    
    $code.=$content;
    
    }
    
    
    $_SESSION['code']=$code;
    
    //echo $_SESSION['code']; exit;
    // 打印干扰像素点
    for($i=0; $i<200; $i++){
    
    
    $pixelcolor = imagecolorallocate($image,rand(100,255),rand(100,255),rand(100,255));
    
    imagesetpixel($image, rand(1,99) , rand(1,29) , $pixelcolor);
    
    }
    
    // 打印干扰线
    for($i=0; $i<3; $i++){
    
            $linecolor = imagecolorallocate($image,rand(100,255),rand(100,255),rand(100,255));
            imageline($image,rand(1,99),rand(1,29),rand(1,99),rand(1,29),$linecolor);
    
    }
    header('content-type:image/png');
    
    imagepng($image);
    
    //end
    imagedestroy($image);

    表单页面 index.php

    <?php 
    session_start();
    
    if(isset($_REQUEST['authcode'])){
    	if(strtolower($_REQUEST['authcode']) == $_SESSION['code']){
    		echo "验证成功";
    	}else{
    		echo "验证失败";
    	}
    	exit();
    }
    
    ?>
    <!DOCTYPE html>
    <html lang="cn">
    <head>
    	<meta charset="UTF-8">
    	<title>验证码</title>
    </head>
    <body>
    	<h1>验证码</h1>
    	<hr>
    	<form action="" method="post">
    		<img src="./authcode.php?random=<?php echo rand(); ?>" alt="验证码" id="authcode"><a href="javascript:;" onclick="changeUrl()">换一个</a><br>
    		<label for="">验证码</label><input type="text" name="authcode" placeholder="请输入验证码"><br>
    		<input type="submit" value="提交">
    	</form>
    	<script>
    	function changeUrl(){
    		document.getElementById('authcode').src='./authcode.php?random='+Math.random();
    	}
    	</script>
    </body>
    </html>
  • php文件上传

    一,form表单

    <form action="upload.php" method="post" enctype="multipart/form-data">
      <label for="file">请选择你要上传的文件</label><input type="file" name="file">
      <input type="submit" value="上传">
    </form>

    二,upload.php

    <?php 
    print_r($_FILES);
    ?>

    两个函数

    copy(file,newloc)
    move_uploaded_file(file,newloc)

    三,服务器配置

  • php注册和登录

    一,php注册页面
    二,数据库建立

    create database site;
    create table user(
    id int,
    usename varchar(255),
    password varchar(255)
    ) ;

     

  • 为wordpress制作插件

    <?php
    /*
    Plugin Name: 插件名称
    Plugin URI: http://URI_Of_Page_Describing_Plugin_and_Updates
    Description: 插件的简单描述
    Version: 插件版本号, 例如: 1.0
    Author: 插件作者
    Author URI: http://URI_Of_The_Plugin_Author作者地址
    */
    ?>
  • 阿里云web服务器配置

    一,购买了一台新的阿里云服务器

    登录到服务器

    ssh root@ip

    二,更新yum源

    https://opsx.alibaba.com/mirror

    1,备份

    mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.backup

    2,下载新的CentOS-Base.repo 到/etc/yum.repos.d/

    //CentOS 7
    wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo
    //或者
    curl -o /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo

    3,之后运行yum makecache生成缓存

    三,安装mariadb

    yum install mariadb-server mariadb-libs

    安装完成后启动mariadb服务

    sudo systemctl start mariadb

    设置开机自启动mariadb

    sudo systemctl enable mariadb

    mariadb的配置

    mysql_secure_installation

    输入当前 root 用户的密码, 直接回车 . 要设置 root 密码吗? 是的 … 再确认一次 … 是否要删除匿名用户吗? 是的 , 想要禁用 root 用户远程登录吗? 可以 ,要删除掉 test 这个数据库吗? 确定 ,最后会提示,要重新加载权限吗? 再输入一个 Y,表示确定

    查看是否安装成功

    mysql -u root -p

    查看所有数据库

    show databases;

     

     

     

  • php生成静态页面

    一,buffer

    <?php
    echo 1;

    我们都运行程序浏览器访问,会显示1。
    但是其实这中间会经历一个buffer,我们可以这样理解:这个1数据会先到php缓存区,当这个缓冲区满了之后,再传给客户端(浏览器)。
    这个过程大致流程如下:

    内容 -> php buffer -> tcp -> 终端(浏览器)

    php.ini

    output_buffering = on
    #打开output缓冲,默认打开的。

    output_buffering打开与关闭的区别:
    1.打开了php输出缓存: echo,print -> php output_buffring -> server buffering -> browser buffering -> browser display
    2.未打开php输出缓存: echo,print -> server buffering -> browser buffering -> browser display

    我们在代码里获取缓存区内容:

    <?php
    
    echo 1;
    echo "<hr/>";
    
    // 获取php缓存区的内容
    $buffer = ob_get_contents();
    echo $buffer;

    如果在php配置文件php.inioutput_buffering = on是开启的,那么上面代码在浏览器上会显示2个1和2条横线,查看网页源代码如下:

    1<hr/>1<hr/>

    如果php.ini中是关闭的,那么只会显示一次。

    当然我们也可以在代码中,临时开启php缓冲区

    <?php
    ob_start(); // 开始php缓存,写在最前面
    
    echo 1;
    echo "<hr/>";
    
    // 获取php缓存区的内容
    $buffer = ob_get_contents();
    echo $buffer;
  • 1

    <html>
      <head></head>
      <body></body>
    </html>
    <pre><code class="language-css">
    body{margin:0; background-color:red;}
    </code></pre>