PHP之ThinkPHP框架(验证码、文件上传、图片处理)
验证码
验证码是框架自带有的,比之前使用GD库简单方便许多,其实现原理基本相似,都是生成图片,保存验证码值到Session中,表单提交验证码,然后进行值的对比验证。
简单的显示:

<form action="{:url('index/ii')}" method="post">
<!--验证码显示方法1-->
<img src="{:captcha_src()}" alt="captcha" style="height: 80px ;width: 200px" />
<br/>
<!--验证码显示方法2-->
<div>{:captcha_img()}</div>
<br/>
请输入验证码:<input type="text" name="check">
<br/>
<input type="submit" value="提交">
</form>
实现点击验证码进行切换:

<form action="{:url('index/ii')}" method="post">
<input type="text" name="check" style="height: 36px;padding-top: 0px;" autocomplete="off">
<img src="{:captcha_src()}" onClick="this.src='{:captcha_src()}'" alt="captcha" style="height: 36px ;width: 110px;border: 1px solid #584C4D;vertical-align:middle" />
<br/><br/>
<input type="submit" value="提交">
</form>
控制器里处理验证码:
//获取到post传递的验证码
//不区分大小写
$checks=Request::instance()->post("check"); if(!captcha_check($checks)){
//验证失败
echo "验证码输入错误"; }else{ echo "验证码输入成功";
}
文件上传
文件上传,支持单文件和多文件,上传的文件会自动保存在public下自动创建的目录中,并返回一系列结果。
单文件:
<form action="{:url('xiao/xiao2')}" method="post" enctype="multipart/form-data">
<input type="file" name="filex1">
<input type="submit" value="东小东上传">
</form>
<?php
namespace app\index\controller; class Xiao
{
public function xiao2(){ // 获取表单上传文件 ,filex1为表单填写的名字
$filex = request()->file("filex1"); if($filex){ //获取到上传原文件的名字
echo $filex->getInfo()["name"];
echo "--<br/>"; //移动到/public/uploads/目录下,DS表示根据系统确定的目录分隔符"/"或“\”
$info = $filex->move(ROOT_PATH . 'public' . DS . 'uploads');
if($info){ // 成功上传后 获取上传信息
//文件的后缀
// 如输出 jpg
echo $info->getExtension()."<br>"; //保存后的路径
// 如输出 20160820/42a79759f284b767dfcb2a0197904287.jpg
echo $info->getSaveName()."<br>"; //保存后的文件名
// 如输出 42a79759f284b767dfcb2a0197904287.jpg
echo $info->getFilename()."<br>"; 35 }else{ // 上传失败获取错误信息
echo $filex->getError(); }
}}}
多文件:
实现是利用了数组的原理进行的,上传时将文件内容保存到数组中,处理是通过数组的遍历进行取存。利用数组进行多文件上传,更具扩展性
<form action="http://localhost:8080/ATP5/public/index/xiao/xiao2" method="post" enctype="multipart/form-data">
<input type="file" name="filex1[]">
<br/>
<input type="file" name="filex1[]">
<br/>
<input type="file" name="filex1[]">
<br/>
<input type="submit" value="东小东上传">
</form>
<?php
namespace app\index\controller; class Xiao
{
public function xiao2(){
// 获取表单上传文件 ,filex1为表单填写的名字
$filess = request()->file("filex1"); //文件数组的遍历
foreach($filess as $filex){ //移动方法1:按照系统规则实现文件保存
//$info = $filex->move(ROOT_PATH . 'public' . DS . 'uploads'); //移动方法2:保留原文件名,如果重名会覆盖
$info=$filex->move(ROOT_PATH . 'public' . DS . 'uploads',iconv("utf-8","gbk",$filex->getInfo()["name"]));
if($info){ //保存后的路径
// 如输出 20160820/42a79759f284b767dfcb2a0197904287.jpg
echo $info->getSaveName()."<br>"; }else{ // 上传失败获取错误信息
echo $filex->getError();
}
}
}}
图片处理
图片处理集成方法可以实现图片信息的获取、图片的裁剪、图片的压缩、图片上水印等,其操作的图片目录均为public目录下,必须加载 use think\Image;模块
<?php
namespace app\index\controller;
use think\Request;
use think\Image;
class Xiao
{
public function xiao2(){ //打开public目录下的图片
$image =Image::open('./rr.jpg'); //直接获取到上传的图片文件内容
//$image =Image::open(request()->file('上传的文件表单名')); //-----------------获取图片信息------------ // 返回图片的宽度
$width = $image->width(); // 返回图片的高度
$height = $image->height(); // 返回图片的类型,如jpeg
$type = $image->type(); // 返回图片的mime类型,如:image/jpeg
$mime = $image->mime(); // 返回图片的尺寸数组 0 图片宽度 1 图片高度
$size = $image->size();
dump($size) ; //---------------------------------------- //--------------图片处理------------------- //裁剪
//更改的是原,无需赋值,且会迭代操作,如第二次裁剪会在第一次的基础上进行 //从位置(0,0)裁剪(宽度,高度)并保存到public中
//$image->crop(100, 200)->save('./crop1.png'); //从位置(0,20)裁剪(宽度,高度)并保存到public中
//$image->crop(200, 100,0,20)->save('./crop2.png'); //压缩
//等比例压缩,如最大为150*150
//$image->thumb(150, 150)->save('./thumb1.png'); //等比例裁剪,如果不能到达标准150*150时,将进行图片裁剪
/*
//常量,标识缩略图居中裁剪类型
const THUMB_CENTER = 3;
//常量,标识缩略图左上角裁剪类型
const THUMB_NORTHWEST = 4;
//常量,标识缩略图右下角裁剪类型
const THUMB_SOUTHEAST = 5;
*/
//$image->thumb(150,150,Image::THUMB_CENTER)->save('./thumb.png'); //为图片上水印
/*
//常量,标识左上角水印
const WATER_NORTHWEST = 1;
//常量,标识上居中水印
const WATER_NORTH = 2;
//常量,标识右上角水印
const WATER_NORTHEAST = 3;
//常量,标识左居中水印
const WATER_WEST = 4;
//常量,标识居中水印
const WATER_CENTER = 5;
//常量,标识右居中水印
const WATER_EAST = 6;
//常量,标识左下角水印
const WATER_SOUTHWEST = 7;
//常量,标识下居中水印
const WATER_SOUTH = 8;
//常量,标识右下角水印
const WATER_SOUTHEAST = 9;
*/
//图片水印
//参数1为水印图片地址,参数2为水印位置,参数3为透明度[0,100],100为原图
$image->water('./thumb.png',Image::WATER_NORTHWEST,10)->save('img/water_image.png'); //文字水印
//参数(文字内容,文字字体,大小,RGB,位置,相对位置偏移量,旋转)
$image->text('东小东','font/tt.ttf',30,'#ff00ff',Image::WATER_SOUTHEAST,-20)->save('img/text_image1.png'); }
}
PHP之ThinkPHP框架(验证码、文件上传、图片处理)的更多相关文章
- jersey框架实现文件上传
jersey框架是一个开源的RESTful的框架,实现了实现了JAX-RS规范,进一步地简化 RESTful service 和 client 开发.当然而且是必须的,jersey对文件的上传和下载也 ...
- layUI框架中文件上传前后端交互及遇到的相关问题
下面我将讲述一下我在使用layUI框架中文件上传所遇到的问题: 前端jsp页面: <div class="layui-form-item"> <label cla ...
- 使用SpringMVC框架实现文件上传和下载功能
使用SpringMVC框架实现文件上传和下载功能 (一)单个文件上传 ①配置文件上传解释器 <!—配置文件上传解释器 --> <mvc:annotation-driven>&l ...
- node.js使用express框架进行文件上传
关于node.js使用express框架进行文件上传,主要来自于最近对Settings-Sync插件做的研究.目前的研究算是取得的比较好的进展.Settings-Sync中通过快捷键上传文件,其实主要 ...
- 关于我使用spring mvc框架做文件上传时遇到的问题
非常感谢作者 原文:https://blog.csdn.net/lingirl/article/details/1714806 昨天尝试着用spring mvc框架做文件上传,犯了挺多不该犯的毛病问题 ...
- SpringMVC框架06——文件上传与下载
1.文件上传 Spring MVC框架的文件上传是基于commons-fileupload组件的文件上传,只不过Spring MVC框架在原有文件上传组件上做了进一步封装,简化了文件上传的代码实现. ...
- 笨鸟先飞之Java(一)--使用struts2框架实现文件上传
无论是.net还是Java,我们最常接触到的就是文件的上传和下载功能,在Java里要实现这两个经常使用功能会有非常多种解决方案,可是struts2的框架却能给我们一个比較简单的方式,以下就一起来看吧: ...
- 第三百一十九节,Django框架,文件上传
第三百一十九节,Django框架,文件上传 1.自定义上传[推荐] 请求对象.FILES.get()获取上传文件的对象上传对象.name获取上传文件名称上传对象.chunks()获取上传数据包,字节码 ...
- Android(java)学习笔记214:开源框架的文件上传(只能使用Post)
1.文件上传给服务器,服务器端必然要写代码进行支持,如下: 我们新建一个FileUpload.jsp的动态网页,同时我们上传文件只能使用post方式(不可能将上传数据拼凑在url路径下),上传数据Ap ...
- Struts 框架 之 文件上传下载案例
Struts 框架 文件上传 1. 先准备 Struts 环境 (我使用的是struts 2.3.4版本) 导jar包:
随机推荐
- python11 装饰器与闭包
一.装饰器定义 本质:一种函数,为其他函数增加新功能 原则: 1.不修改被修饰函数的源代码 2.不修改被修饰函数的调用方式 需要技能:装饰器=高阶函数+函数嵌套+闭包 二.高阶函数 定义:函数接收的参 ...
- oracle 查询clob 列时 很慢 , 未解决
今天查询一张表 ,这张表有一个clob 列 select * from tableName : 很卡.. 难道是查询的太多? select * from tableName where rowN ...
- Mysql常用命令 详细整理版
Mysql常用命令 show databases; 显示数据库 create database name; 创建数据库 use databasename; 选择数据库 drop database na ...
- JS阻止事件冒泡的3种方法之间的不同
什么是JS事件冒泡?: 在一个对象上触发某类事件(比如单击onclick事件),如果此对象定义了此事件的处理程序,那么此事件就会调用这个处理程序,如果没有定义此事件处理程序或者事件返回true,那么这 ...
- day32 进程
上午: # 1 开启子进程 #target #args # if __name__ == '__main__' #start() # 2.其它的方法: #方法: #terminate() #is_al ...
- gulp打包工具
首先安装全局gulp $ npm install --global gulp 下载成功后 新建一个项目或者一个文件夹(做测试) mkdir testgulp 在该文件或者项目下下载gulp工具 $ n ...
- JavaScript -DOM 编程艺术 2nd 完
今日看完了这本书,做完了最后一个综合性例子.说实话收获良多,终于明白前端-h5 具体做什么 越学习越无知,这个看来真是一个真理. 后期计划: 1.CSS + DIV 布局深入了解,重点实战 2.Jav ...
- Codeforces Educational Codeforces Round 44 (Rated for Div. 2) E. Pencils and Boxes
Codeforces Educational Codeforces Round 44 (Rated for Div. 2) E. Pencils and Boxes 题目连接: http://code ...
- jquery复制值到剪切板(clipboard.js)
引入一个clipboard.js文件即可使用,下载地址:https://github.com/zenorocha/clipboard.js <script type="text/jav ...
- python视频地址和链接
算法 链接:http://pan.baidu.com/s/1nvHmcZJ 密码:fwjg常用库 链接:http://pan.baidu.com/s/1o8uPvPg 密码:yp3w进阶-高级代码 链 ...