ci 验证码不存图片和点击刷新图片 php

本文介绍了一种使用PHP和CodeIgniter框架生成验证码的方法。通过自定义函数create_captcha,可以灵活设置验证码的长度、样式及字体等参数,并实现验证码图片的动态生成。此外,还提供了如何在控制器中调用该函数生成验证码并将其输出到前端页面的具体示例。
摘要由CSDN通过智能技术生成

直接复制替换就可以

<?php  if ( ! defined('BASEPATH')) exit('No direct script access allowed');


if ( ! function_exists('create_captcha'))
{
    function create_captcha($data = '', $font_path = '')
    {
        $defaults = array('word' => '', 'word_length' => 4, 'img_width' => '150', 'img_height' => '30', 'font_path' => '', 'expiration' => 7200);


        foreach ($defaults as $key => $val)
        {
            if ( ! is_array($data))
            {
                if ( ! isset($key) OR $key == '')  //$key前面自己多加一个$
                {
                    $key = $val; //$key前面自己多加一个$
                }
            }
            else                                                           //因为两个$  发生bug 可能是csdn的问题   

            {

                //$key前面自己多加一个$

                $key = ( ! isset($data[$key])) ? $val : $data[$key];   //后面这个不用加
            }
        }
        /*
                        if ($img_path == '' OR $img_url == '')
                        {
                                return FALSE;
                        }


                        if ( ! @is_dir($img_path))
                        {
                                return FALSE;
                        }


                        if ( ! is_writable($img_path))
                        {
                                return FALSE;
                        }


                        if ( ! extension_loaded('gd'))
                        {
                                return FALSE;
                        }


                        // -----------------------------------
                        // Remove old images
                        // -----------------------------------


                        list($usec, $sec) = explode(" ", microtime());
                        $now = ((float)$usec + (float)$sec);


                        $current_dir = @opendir($img_path);


                        while ($filename = @readdir($current_dir))
                        {
                                if ($filename != "." and $filename != ".." and $filename != "index.html")
                                {
                                        $name = str_replace(".jpg", "", $filename);


                                        if (($name + $expiration) < $now)
                                        {
                                                @unlink($img_path.$filename);
                                        }
                                }
                        }


                        @closedir($current_dir);


        */                

        // -----------------------------------

        // Do we have a "word" yet?
        // -----------------------------------


        if ($word == '')
        {
            $pool = '0123456789';  //纯数字的验证码


            $str = '';
            for ($i = 0; $i < $word_length; $i++)
            {
                $str .= substr($pool, mt_rand(0, strlen($pool) -1), 1);
            }


            $word = $str;
        }


        // -----------------------------------
        // Determine angle and position
        // -----------------------------------


        $length        = strlen($word);
        $angle        = ($length >= 6) ? rand(-($length-6), ($length-6)) : 0;
        $x_axis        = rand(6, (360/$length)-16);
        $y_axis = ($angle >= 0 ) ? rand($img_height, $img_width) : rand(6, $img_height);


        // -----------------------------------
        // Create image
        // -----------------------------------


        // PHP.net recommends imagecreatetruecolor(), but it isn't always available
        if (function_exists('imagecreatetruecolor'))
        {
            $im = imagecreatetruecolor($img_width, $img_height);
        }
        else
        {
            $im = imagecreate($img_width, $img_height);
        }


        // -----------------------------------
        //  Assign colors
        // -----------------------------------


        $bg_color                = imagecolorallocate ($im, 255, 255, 255);
        $border_color        = imagecolorallocate ($im, 153, 102, 102);
        $text_color                = imagecolorallocate ($im, 204, 153, 153);
        $grid_color                = imagecolorallocate($im, 255, 182, 182);
        $shadow_color        = imagecolorallocate($im, 255, 240, 240);


        // -----------------------------------
        //  Create the rectangle
        // -----------------------------------


        ImageFilledRectangle($im, 0, 0, $img_width, $img_height, $bg_color);


        // -----------------------------------
        //  Create the spiral pattern
        // -----------------------------------


        $theta                = 1;
        $thetac                = 7;
        $radius                = 16;
        $circles        = 20;
        $points                = 32;


        for ($i = 0; $i < ($circles * $points) - 1; $i++)
        {
            $theta = $theta + $thetac;
            $rad = $radius * ($i / $points );
            $x = ($rad * cos($theta)) + $x_axis;
            $y = ($rad * sin($theta)) + $y_axis;
            $theta = $theta + $thetac;
            $rad1 = $radius * (($i + 1) / $points);
            $x1 = ($rad1 * cos($theta)) + $x_axis;
            $y1 = ($rad1 * sin($theta )) + $y_axis;
            imageline($im, $x, $y, $x1, $y1, $grid_color);
            $theta = $theta - $thetac;
        }


        // -----------------------------------
        //  Write the text
        // -----------------------------------


        $use_font = ($font_path != '' AND file_exists($font_path) AND function_exists('imagettftext')) ? TRUE : FALSE;


        if ($use_font == FALSE)
        {
            $font_size = 5;
            $x = rand(0, $img_width/($length/3));
            $y = 0;
        }
        else
        {
            $font_size        = 16;
            $x = rand(0, $img_width/($length/1.5));
            $y = $font_size+2;
        }


        for ($i = 0; $i < strlen($word); $i++)
        {
            if ($use_font == FALSE)
            {
                $y = rand(0 , $img_height/2);
                imagestring($im, $font_size, $x, $y, substr($word, $i, 1), $text_color);
                $x += ($font_size*2);
            }
            else
            {
                $y = rand($img_height/2, $img_height-3);
                imagettftext($im, $font_size, $angle, $x, $y, $text_color, $font_path, substr($word, $i, 1));
                $x += $font_size;
            }
        }




        // -----------------------------------
        //  Create the border
        // -----------------------------------


        imagerectangle($im, 0, 0, $img_width-1, $img_height-1, $border_color);


        // -----------------------------------
        //  Generate the image
        // -----------------------------------


        // $img_name = $now.'.jpg';


        // ImageJPEG($im, $img_path.$img_name);


        // $img = "<img src=\"$img_url$img_name\" width=\"$img_width\" height=\"$img_height\" style=\"border:0;\" alt=\" \" />";
        #直接输出
        header("Content-Type:image/jpeg");
        imagejpeg($im);


        ImageDestroy($im);
        #返回生成的验证码字符串
        return $word;
        // return array('word' => $word, 'time' => $now, 'image' => $img);
    }

}

直接复制替换验证码类就可以

php代码:   

//生成

    public function getCaptcha()
    {
        $this->load->helper('captcha');
        $vals = array(
            'word_length' => 6
        );
        $cap = create_captcha($vals);
        set_cookie('captcha',md5($cap),300);

    }

html代码:

<td colspan="2" align="right">
    <img src="<?php echo base_url();?>index.php?c=welcome&m=getCaptcha" alt="" οnclick= this.src="<?php echo base_url();?>index.php?c=welcome&m=getCaptcha&"+Math.random()  title="看不清?点击刷新验证码。"/>
</td>














评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值