php 生成图片,给图片加水印

用php生成一张图片,并给图片添加水印的方法。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
<?php
    $path 'p1.jpg';
    $path1 'p2.png';
    $img = imagecreatefromstring(file_get_contents($path)); //获取图片
    $img1 = imagecreatefromstring(file_get_contents($path1));
    
    //将水印图片复制到目标图片上,最后个参数50是设置透明度,这里实现半透明效果
    imagecopymerge($img$img1, 10, 10, 0, 0, 100, 100, 50);
    //如果水印图片本身带透明色,则使用imagecopy方法
    imagecopy($img$img1, 100, 100, 0, 0,97,206);
    
    $fontcolor1 = imagecolorallocate($img,255,255,255); //定义颜色
    imagettftext($img,20,90,100,600,$fontcolor1,'035-CAI978.ttf','字体大小');  //设置字体
    
    $fontcolor = imagecolorallocate($img,0,0,0);
    imagestring($img, 3, 2, 3, "Hello world!"$fontcolor);  //写入文字
    imagestring($img, 10, 10, 10, "Hello world!222222222"$fontcolor);  //继续写入文字 
    
    header('Content-Type: image/jpeg');
    imagejpeg($img);
    imagedestroy($img);
?>

MySQL:if语句、if…else语句、case语句,使用方法解析!

if语句做为表达式使用,语法格式如下:

1
IF(expr1,expr2,expr3)

说明:              

如果 expr1 是TRUE (expr1 <> 0 and expr1 <> NULL),则 IF()的返回值为expr2; 否则返回值则为 expr3。IF() 的返回值为数字值或字符串值,具体情况视其所在语境而定。

例子:             

1
select *,if(age=1,"男","女"as ages from user;

当然如果作为表达式的话,if也可以用CASE when来实现的:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
/* 下面这个将输出:男 */
SELECT
    CASE 
        WHEN THEN '男'
        WHEN THEN '女'
        ELSE '未知'
    END
as ages
/* 下面这个将输出:女 */
SELECT
    CASE 
        WHEN THEN '男'
        WHEN THEN '女'
        ELSE '未知'
    END
as ages
/* 下面这个将输出:未知 */
SELECT
    CASE 
        WHEN THEN '男'
        WHEN THEN '女'
        ELSE '未知'
    END
as ages
/*   当然还有一种写法  输出:未知 */
SELECT
    CASE
        WHEN 3=1 THEN '男'
        WHEN 3=2 THEN '女'
        ELSE '未知'
    END
as ages
SELECT
    CASE
        WHEN 3=1 THEN '男'
        WHEN 3=2 THEN '女'
    WHEN (3=4 || 3!=nullTHEN '测试'
        ELSE '未知'
    END
as ages

从上面的例子我们可以看出得很明白了,case后面的值=when后台的值,然后就会输出when后面跟的then后的值。如果都不等行的话,就输出else后的值。

IF…ELSE…做为流程控制语句使用,语法格式如下:

1
2
3
4
5
6
7
IF search_condition THEN
    statement_list  
[ELSEIF search_condition THEN]  
    statement_list ...  
[ELSE
    statement_list]  
END IF

说明:              

与PHP中的IF语句类似

当IF中条件search_condition成立时,执行THEN后的statement_list语句、

否则判断ELSEIF中的条件成立时,执行其后的statement_list语句、

否则继续判断其他分支。

当所有分支的条件均不成立时,执行ELSE分支。

search_condition是一个条件表达式,可以由“=、<、<=、>、>=、!=”等条件运算符组成,并且可以使用AND、OR、NOT对多个表达式进行组合。

例子:             

建立一个存储过程,该存储过程通过学生学号(student_no)和课程编号(course_no)查询其成绩(grade),

返回成绩和成绩的等级,成绩大于90分的为A级,小于90分大于等于80分的为B级,小于80分大于等于70分的为C级,依次到E级

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
create procedure dbname.proc_getGrade  
(stu_no varchar(20),cour_no varchar(10))  
BEGIN
declare stu_grade float;  
select grade into stu_grade from grade where student_no=stu_no and course_no=cour_no;  
if stu_grade>=90 then
    select stu_grade,'A';  
elseif stu_grade<90 and stu_grade>=80 then
    select stu_grade,'B';  
elseif stu_grade<80 and stu_grade>=70 then
    select stu_grade,'C';  
elseif stu_grade70 and stu_grade>=60 then
    select stu_grade,'D';  
else
    select stu_grade,'E';  
end if;  
END

注意:IF作为一条语句,在END IF后需要加上分号“;”以表示语句结束,其他语句如CASE、LOOP等也是相同的。

PHP 图片处理类(图片加水印,图片加文字,图片缩略处理,获取图片信息等)

PHP 图片处理类(图片加水印,图片加文字,图片缩略处理,获取图片信息等)

 

<?php
header('content-type:text/html;charset=utf-8');
class Imgs
{
    /**
     * 取得图片宽
     * @param string $src 图片相对路径或绝对路径
     */
    public static function get_width($src)
    {
        return imagesx($src);
    }
    /**
     * 取得图片高
     * @param string $src 图片相对路径或绝对路径
     */
    public static function get_height($src)
    {
        return imagesy($src);
    }
    /** 
     * 图片缩放函数   
     * @param string $src 图片相对路径或绝对路径 
     * @param int $w 缩略图宽
     * @param int $h 缩略图高
     * @return array code:状态。msg:提示信息
     **/
    public static function thumb($src,$w=null,$h=null)     
    {   
        if(empty($src)) return array('code'=>false , 'msg'=>'请指定$src');
        $temp pathinfo($src);
        #  文件名
        $name $temp["basename"];
        #  文件所在的文件夹
        $dir $temp["dirname"];
        #  文件扩展名
        $extension $temp["extension"];
        #  缩略图保存路径,新的文件名为*.thumb.jpg
        $savepath "{$dir}/thumb_{$name}";
        
        #  获取图片的基本信息
        $info getimagesize($src);
        #  获取图片宽度
        $width $info[0];
        #  获取图片高度
        $height $info[1];
        if(!empty($w)){
            $temp_w=$w;                         #  计算原图缩放后的宽度
            $temp_h=intval($height*($w/$width));#  计算原图缩放后的高度
        }else{
            $temp_w=intval($width*($h/$height));#  计算原图缩放后的宽度
            $temp_h=$h;                         #  计算原图缩放后的高度
        }
        #  创建画布
        $temp_img=imagecreatetruecolor($temp_w,$temp_h);
        switch ($info[2])     
        {     
            case 1:     
                $im=imagecreatefromgif($src);   
                imagecopyresampled($temp_img,$im,0,0,0,0,$temp_w,$temp_h,$width,$height); 
                imagegif($temp_img,$savepath, 100);   
                break;     
            case 2:     
                $im=imagecreatefromjpeg($src);   
                imagecopyresampled($temp_img,$im,0,0,0,0,$temp_w,$temp_h,$width,$height);     
                imagejpeg($temp_img,$savepath, 100);      
                break;     
            case 3:     
                $im=imagecreatefrompng($src);  
                imagecopyresampled($temp_img,$im,0,0,0,0,$temp_w,$temp_h,$width,$height); 
                imagepng($temp_img,$savepath, 100);    
                break;     
        }        
        imagedestroy($im); 
        return $savepath;
    
    /** 
     * 图片添加水印   
     * @param string $src  1、图片相对路径或绝对路径  2、以逗号隔开的宽高值('800,600')
     * @param array  属性值:
     *                    res:水印资源(1、图片相对路径或绝对路径,2、字符串)
     *                 pos:图片水印添加的位置,取值范围:0~9
     *                         0:随机位置,在1~8之间随机选取一个位置
    *                         1:顶部居左 2:顶部居中 
     *                         3:顶部居右 4:左边居中
     *                         5:图片中心 6:右边居中 
     *                         7:底部居左 8:底部居中 
     *                         9:底部居右
     *                 font:    字体库(相对路径或绝对路径)
     *                 fontSize:文字大小
     *                 color:   水印文字的字体颜色(255,255,255)
     *                 name:    图片保存名称
     * @return array    code:状态、 msg:提示信息、 url:图片地址
     **/
    public static function setWater($src$arr=array())
    {  
        if(empty($src)) return array('code'=>false , 'msg'=>'请指定$src');
        $def array(
            'res'       => '小川编程',
            'pos'       => 7,
            'font'      => './1.ttf',
            'fontSize'  => 24,
            'color'     => '255,255,255',
            'name'      => null
        );
        $def array_merge($def,$arr);
        /**
            判断$src是不是图片,不是就创建画布
        */
        if(!file_exists($src)){
            if(empty($def['name'])) return array('code'=>false , 'msg'=>'请指定图片名称');
            # 计算画布宽高
            $obj explode(','$src);
            if(count($obj)!=2) return array('code'=>false , 
                'msg'=>'请给正确的宽高,或你给的不是一个有效的地址!');
            $srcImg_w is_numeric($obj[0]) ? $obj[0] : 400 ;
            $srcImg_h is_numeric($obj[1]) ? $obj[1] : 300 ;
            # 创建画布
            $dst_img = @imagecreatetruecolor($srcImg_w,$srcImg_h);
        }else{
            #  获取图片信息
            $srcInfo = @getimagesize($src);
            $srcImg_w $srcInfo[0];
            $srcImg_h $srcInfo[1];
            if(empty($def['name'])) $def['name'] = $src;
            #  动态的把图片导入内存中
            switch ($srcInfo[2]){ 
                case 1: 
                    $dst_img = imagecreatefromgif($src); 
                break
                case 2: 
                    $dst_img = imagecreatefromjpeg($src); 
                break
                case 3: 
                    $dst_img = imagecreatefrompng($src); 
                break
                default
                    return array('code'=>false , 'msg'=>'目标图片类型错误');
                exit
            }
        }
        /**
            计算出水印宽高
        */
        if(!file_exists($def['res'])){
            if(!file_exists($def['font']))
                return array('code'=>false , 'msg'=>'字体库不存在');
            $box = @imagettfbbox($def['fontSize'], 0, $def['font'], $def['res']);
            $logow = max($box[2], $box[4]) - min($box[0], $box[6]);
            $logoh = max($box[1], $box[3]) - min($box[5], $box[7]);  
        }else{
            $resInfo = @getimagesize($def['res']);
            $res_w $resInfo[0];
            $res_h $resInfo[1];
            if($srcImg_w $res_w || $srcImg_h $res_h)
                return array('code'=>false , 'msg'=>'水印图片过大');
            #  动态的把图片导入内存中
            switch ($resInfo[2]){ 
                case 1: 
                    $markim = imagecreatefromgif($def['res']); 
                break
                case 2: 
                    $markim = imagecreatefromjpeg($def['res']); 
                break
                case 3: 
                    $markim = imagecreatefrompng($def['res']); 
                break
                default
                    return array('code'=>false , 'msg'=>'水印图片类型错误');
                exit
            }
            $logow $res_w;
            $logoh $res_h;
        }
        /**
            计算水印显示位置
        */
        if($def['pos'] == 0) $def['pos'] = rand(1, 9);
        switch($def['pos'])
        {
            case 1:
                $x = +10;
                $y = +10+$def['fontSize'];
            break;
            case 2:
                $x = ($srcImg_w $logow) / 2;
                $y = +10+$def['fontSize'];
            break;
            case 3:
                $x $srcImg_w $logow - 10;
                $y = +10+$def['fontSize'];
            break;
            case 4:
                $x = +10;
                $y = ($srcImg_h $logoh) / 2 + $def['fontSize'];
            break;
            case 5:
                $x = ($srcImg_w $logow) / 2;
                $y = ($srcImg_h $logoh) / 2 + $def['fontSize'];
            break;
            case 6:
                $x $srcImg_w $logow - 10;
                $y = ($srcImg_h $logoh) / 2 + $def['fontSize'];
            break;
            case 7:
                $x = +10;
                $y $srcImg_h $logoh $def['fontSize'] - 10;
            break;
            case 8:
                $x = ($srcImg_w $logow) / 2;
                $y $srcImg_h $logoh $def['fontSize'] - 10;
            break;
            case 9:
                $x $srcImg_w $logow - 10;
                $y $srcImg_h $logoh $def['fontSize'] - 10;
            break;
            default
                return array('code'=>false , 'msg'=>'水印位置不支持');
            exit;
        }
        /**
            把图片水印或文字水印,加到目标图片中
        */
        if(file_exists($def['res'])){
            imagecopy($dst_img$markim$x$y, 0, 0, $logow$logoh);
            imagedestroy($markim);
        }else{
            $rgb explode(','$def['color']);
            if(count($rgb)!=3) return array('code'=>false , 'msg'=>'请给正确的字体颜色');
            if(!is_numeric($rgb[0]) || !is_numeric($rgb[1]) || !is_numeric($rgb[2])) 
                return array('code'=>false , 'msg'=>'请给正确的字体颜色');
            if($rgb[0]>255 || $rgb[1]>255 || $rgb[2]>255) 
                return array('code'=>false , 'msg'=>'请给正确的字体颜色');
            $def['color'] = imagecolorallocate($dst_img$rgb[0], $rgb[1], $rgb[2]);
            imagettftext($dst_img$def['fontSize'], 0, $x
                $y$def['color'], $def['font'],$def['res']);
        }
        /**
            保存处理过的图片(有水印了的图片)
        */
        $name explode('.'$def['name']);
        switch (strtolower($name[2])) {
            case 'jpeg':
                    imagejpeg($dst_img$def['name']);
                break;
            case 'jpg':
                    imagejpeg($dst_img$def['name']);
                break;
            case 'png':
                    imagepng($dst_img$def['name']);
                break;
            case 'gif':
                    imagegif($dst_img$def['name']);
                break;
            default:
                    return array('code'=>false , 'msg'=>'保存图片类型有误');
                break;
        }
        #  销毁图片内存资源
        imagedestroy($dst_img);
        return array('code'=>true , 'msg'=>'添加水印成功''url'=>$def['name']);
    }
}
/*
    创建一个800*600的图再加logo.jpg图片作为水印.
    1、另存为new_thumb.jpeg
    2、水印在中间显示
*/
#  参数:
$arr = [
    #  水印图片路径(如果不存在将会被当成是字符串水印)
    'res'  => './logo.jpg',
    #  水印显示位置
    'pos'  => 5,
    #  不指定name(会覆盖原图,也就是保存成thumb.jpeg)
    'name' => './800x600.jpeg',  
];
$res = Imgs::setWater('800,600'$arr);
print_r($res);
/*
    给图片thumb.jpeg加:小川编程,作为水印
    1、另存为new_thumb.jpeg
    2、水印顶部居右显示
    3、字体大小为:30
*/
#  参数:
$arr = [
    #  水印图片路径(如果不存在将会被当成是字符串水印)
    'res'  => '小川编程',
    #  水印显示位置
    'pos'  => 3,
    #  不指定name(会覆盖原图,也就是保存成thumb.jpeg)
    'name' => './new1.jpg',  
    #  字体大小
    'fontSize'=>30,
    #  字体颜色
    'color'=>'255,255,0',
]; 
$res = Imgs::setWater('./1.jpg'$arr);
print_r($res);
?>

PHP+Mysql防止SQL注入的3种方法!

PHP+Mysql防止SQL注入的3种方法:

方法一:

mysql_real_escape_string — 转义 SQL 语句中使用的字符串中的特殊字符,并考虑到连接的当前字符集 !

使用方法如下:

1
2
3
$sql = "select count(*) as ctr from users where username
='".mysql_real_escape_string($username)."' and 
password='". mysql_real_escape_string($pw)."' limit 1";

使用  mysql_real_escape_string() 作为用户输入的包装器,就可以避免用户输入中的任何恶意 SQL 注入。

方法二:

打开magic_quotes_gpc来防止SQL注入

php.ini中有一个设置:magic_quotes_gpc = Off
这个默认是关闭的,如果它打开后将自动把用户提交对sql的查询进行转换,
比如把 ‘ 转为 \’等,对于防止sql注射有重大作用。

如果magic_quotes_gpc=Off,则使用addslashes()函数

方法三:

自定义函数

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
/**
* 防止sql注入自定义方法一
* author: xiaochuan
* @param: mixed $value 参数值
*/
function check_param($value=null) { 
        #  select|insert|update|delete|\'|\/\*|\*|\.\.\/|\.\/|union|into|load_file|outfile
    $str 'select|insert|and|or|update|delete|\'|\/\*|\*|\.\.\/|\.\/|union|into|load_file|outfile';
    if(!$value) {
        exit('没有参数!'); 
    }elseif(eregi($str$value)) { 
        exit('参数非法!');
    }
    return true; 
 
/**
* 防止sql注入自定义方法二
* author: xiaochuan
* @param: mixed $value 参数值
*/
function str_check( $value ) { 
    if(!get_magic_quotes_gpc()) { 
        // 进行过滤 
        $value addslashes($value); 
    
    $value str_replace("_""\_"$value); 
    $value str_replace("%""\%"$value); 
     
   return $value
 
/**
* 防止sql注入自定义方法三
* author: xiaochuan
* @param: mixed $value 参数值
*/
function post_check($value) { 
    if(!get_magic_quotes_gpc()) {
        // 进行过滤  
        $value addslashes($value);
    
    $value str_replace("_""\_"$value); 
    $value str_replace("%""\%"$value); 
    $value nl2br($value); 
    $value = htmlspecialchars($value); 
    return $value
}