php实现拼图滑块验证的思考及部分实现
实现拼图滑块验证,我觉得其中比较关键的一点就是裁剪图片,最起码需要裁剪出下面两张图的样子

底图

滑块图
一张底图和一张滑块图,其中底图实现起来比较简单可以使用添加水印的方式直接将一张拼图形状的半透明图与一张底图合并起来就可以啦,但是实现滑块图就不能够直接使用某个php提供的函数来直接实现啦,但是这也不是不能完成的事情,大致思路如下:
1.准备好拼图形状的一张滑块模型图,例如

然后创建一个相同大小的透明图片
list($width_z, $height_z, $type_z, $attr_z) = getimagesize(滑块模型地址);
$img = imagecreatetruecolor($width_z, $height_z);
imagesavealpha($img, true);
$bg = imagecolorallocatealpha($img, 255, 0, 0, 127);
imagefill($img, 0, 0, $bg);
2.获取底图的像素矩阵(主要获取图片中每个像素的 颜色索引/rgb 的值)
$background = imagecreatefromjpeg(底图图片地址);
list($width_t, $height_t, $type_t, $attr_t) = getimagesize(底图图片地址);
for ($i=0; $i < $width_t; $i++) {
for ($j=0; $j < $height_t; $j++) {
//获取每个像素的颜色索引值
$color2 = imagecolorat($background, $i, $j);
}
}
3.获取滑块模型图的像素矩阵,并获取矩阵中的黑色区域部分的像素点的坐标
list($width_z, $height_z, $type_z, $attr_z) = getimagesize("滑块模型图地址");
$cover = imagecreatefrompng("滑块模型图地址");
for ($i=0; $i < $width_z; $i++) {
for ($j=0; $j < $height_z; $j++) {
//获取每个像素的颜色索引值
$color2 = imagecolorat($cover, $i, $j);
if($color2 == 0){
//此时的 $i 和 $j 分别表示的是黑色区域的像素点的x,y坐标
}
}
}
4.在底图像素矩阵中按照步骤3中获取的坐标结合底图的实际情况获取像素值
5.将步骤4中获取的像素值,逐个设置到步骤1生成的透明图片上,这样滑块图就做好啦
//设置指定图像的xy坐标的颜色索引
bool imagesetpixel ( resource $image , int $x , int $y , int $color )
整体代码:
<?php
//遮盖层
list($width_z, $height_z, $type_z, $attr_z) = getimagesize("cover.png");
$cover = imagecreatefrompng("cover.png");
//创建一个和遮盖层同样大小的图片
$img = imagecreatetruecolor($width_z, $height_z);
imagesavealpha($img, true);
$bg = imagecolorallocatealpha($img, 255, 0, 0, 127);
imagefill($img, 0, 0, $bg); //背景层
list($width_t, $height_t, $type_t, $attr_t) = getimagesize("background.jpg"); $background = imagecreatefromjpeg("background.jpg"); $width_max = $width_t-$width_z-10;
$height_max = $height_t-$height_z-10; $width_ini = rand($width_z+10,$width_max);
$height_ini = rand(10,$height_max); $width_limit = $width_ini + $width_z;
$height_limit = $height_ini + $height_z; for ($i=$width_ini; $i < $width_limit; $i++) {
for ($j=$height_ini; $j < $height_limit; $j++) { $color2 = imagecolorat($background, $i, $j); //判断索引值区分具体的遮盖区域
if(imagecolorat($cover, $i-$width_ini, $j-$height_ini) == 0){
imagesetpixel($img, $i-$width_ini, $j-$height_ini, $color2);
} $color1 = imagecolorat($cover, $i-$width_ini, $j-$height_ini);
$s = imagecolorallocatealpha($background, 192, 192, 192, 45);
if($color1 == 0){
imagesetpixel($background,$i,$j,$s);
} }
} //生成背景图
imagepng($background);
//生成滑块图
imagepng($img);
?>
php实现拼图滑块验证的思考及部分实现的更多相关文章
- selenium滑块验证
使用selenium模拟登录解决滑块验证问题 本次主要是使用selenium模拟登录网页端的TX新闻,本来最开始是模拟请求的,但是某一天突然发现,部分账号需要经过滑块验证才能正常登录,如果还是模拟 ...
- Java + Selenium + OpenCV解决自动化测试中的滑块验证
最近工作过程中,一个常用的被测网站突然增加了滑块验证环节,导致整个自动化项目失效了. 为了解决这个滑块验证问题,在网上查阅了一些资料后,总结并实现了解决方案,现记录如下. 1.滑块验证思路 被测对象的 ...
- winform 仿web 滑块验证
winform 仿web 滑块验证 效果如下: 源码下载地址: https://download.csdn.net/download/u011392711/11109687
- jQuery手机触屏拖动滑块验证跳转插件
HTML: <!DOCTYPE html> <html lang="en"> <head> <title>jQuery手机触屏拖动滑 ...
- 关于selenium实现滑块验证
关于selenium实现滑块验证 python2.7+selenium2实现淘宝滑块自动认证参考链接:https://blog.csdn.net/ldg513783697/article/detail ...
- 原生js实现拖动滑块验证
拖动滑块验证是现在的网站随处可见的,各式各样的拖动法都有. 下面实现的是某宝的拖动滑块验证: <!DOCTYPE html> <html lang="en"> ...
- js移动端滑块验证解锁组件
本文修改自PC端的js滑块验证组件,PC端使用的是onmousedown,onmouseup,nomousemove.原文找不到了,也是博客园文章,在此感谢广大网友的生产力吧. 说下对插件和组件的理解 ...
- js 拖动滑块验证
备注:拖动滑块时尽量平移,chrome浏览器上没有卡顿情况,但是搜狗极速模式和360极速模式都遇到了卡顿,拖不动情况,应是浏览器内部对事件响应速度导致吧. JS代码: ;(function ($,wi ...
- BILIBILI之滑块验证
bilibili的滑动验证码图片比较好玩,和前一篇不大一样. 采用canvas方法,分析发现只找到一个图片,不过,可以通过设置display截图方式获得2张图(完整图片,带缺口的图片),取得图片后接下 ...
随机推荐
- Clock Generator PLL with Integrated VCO_ADF4360-9
Clock Generator PLL with Integrated VCO_ADF4360-9 2和3之间需要有大于15ms的时间间隔
- HTML文档的组成和标签的规范
Html文档的组成 (1): <html></html>来明确html文档的范围 (2): <head></head>标签可以设置一个内容比如: < ...
- set serveroutput on 命令
使用set serveroutput on 命令设置环境变量serveroutput为打开状态,从而使得pl/sql程序能够在SQL*plus中输出结果 使用函数dbms_output.put_lin ...
- JAVA 基础编程练习题41 【程序 41 猴子分桃】
41 [程序 41 猴子分桃] 题目:海滩上有一堆桃子,五只猴子来分.第一只猴子把这堆桃子凭据分为五份,多了一个,这只猴子把 多的一个扔入海中,拿走了一份.第二只猴子把剩下的桃子又平均分成五份,又多了 ...
- 操作TreeView(咏南工作室)
{*******************************************************}{ ...
- JS 事件介绍
1.设置js对象属性为事件处理程序 事件处理程序属性的名字由“on”后面跟着事件名组成.这些属性名 都必须小写 事件处理程序的缺点:设计都是围绕着假设每个事件目标对于每种事件类型将最多只有一个处理程序 ...
- Spring Aop(十二)——编程式的创建Aop代理之AspectjProxyFactory
转发地址:https://www.iteye.com/blog/elim-2397922 编程式的创建Aop代理之AspectjProxyFactory 之前已经介绍了一款编程式的创建Aop代理的工厂 ...
- opengl读取灰度图生成三维地形
准备第三方库 glew.freeglut.glm.opencv 准备灰度图片和草地贴图 最终效果 代码包括主程序源文件mainApp.cpp.顶点着色器shader.vs.片元着色器shader.fs ...
- 跨服务器执行SQL
--exec sp_helpserver 可以以存储过程形式执行以下: --1.1 创建登录信息(或叫创建链接服务器登录名映射)(只需选择一种方式) --1.1.1 以windows认证的方式登录 / ...
- Reactor系列(三)创建Flux,Mono(续)
创建Mono 视频讲解:https://www.bilibili.com/video/av78944069/ FluxMonoTestCase.java package com.example.rea ...