CodeIgniter学习笔记五:分页,文件上传,session,验证码
一、分页
示例代码:
//装载类文件
$this -> load -> library('pagination'); $controller = $this->router->fetch_class();
$action = $this->router->fetch_method(); //每页显示10条数据,共有101条数据
$config['base_url'] = site_url("$controller/$action");
$config['total_rows'] = 101;
$config['per_page'] = 10;
$config['first_link'] = "首页";
$config['prev_link'] = "上一页";
$config['next_link'] = "下一页";
$config['last_link'] = "最后一页"; //如果setment不是3需要设置,默认为3
$config['uri_segment'] = 3; $this -> pagination -> initialize($config); //偏移量
$offset = intval($this -> uri -> segment(3)); $sql = "SELECT * FROM `TEST` LIMIT $offset," . $config['per_page']; $pager = $this -> pagination -> create_links(); $this -> load -> view('article/index', array('pager' => $pager, 'sql' => $sql));
需要注意的是,如果配置了url中隐藏index.php,在site_url中生成的路径中默认还是有index.php,需要在application/config/config.php中改成如下配置:
$config['index_page'] = '';
即可。
二、文件上传
示例代码:
//目录需要手动创建
$config['upload_path'] = './uploads/';
$config['allowed_types'] = "gif|png|jpg|jpeg";
$config['max_size'] = 512;
$config['file_name'] = uniqid(); $this -> load -> library('upload', $config);
//pic为input type=file的name
$this -> upload ->do_upload('pic'); //上传文件信息
$uploadInfo = $this -> upload -> data();
var_dump($uploadInfo);
/*
array (size=14)
'file_name' => string '55a61d04e96f4.jpg' (length=17)
'file_type' => string 'image/jpeg' (length=10)
'file_path' => string 'E:/wamp/www/citest/uploads/' (length=27)
'full_path' => string 'E:/wamp/www/citest/uploads/55a61d04e96f4.jpg' (length=44)
'raw_name' => string '55a61d04e96f4' (length=13)
'orig_name' => string '55a61d04e96f4.jpg' (length=17)
'client_name' => string 'hk.jpg' (length=6)
'file_ext' => string '.jpg' (length=4)
'file_size' => float 125.09
'is_image' => boolean true
'image_width' => int 675
'image_height' => int 900
'image_type' => string 'jpeg' (length=4)
'image_size_str' => string 'width="675" height="900"' (length=24)
*/
即可。
三、session
1、开启
$this -> load -> library('session');
默认已经开启,用上面的代码加载session库。
2、写入
$user = array(
'id' => 3,
'name' => 'jim'
);
$this -> session -> set_userdata("user", $user);
3、读取
$this -> session -> userdata('user')
注:建议在 application/config/config.php 中配置加密key:
$config['encryption_key'] = 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxx';
四、验证码
示例:
$this->load->helper('captcha');
$vals = array(
//'word' => 'Random word',
'img_path' => './captcha/',
'img_url' => base_url() . 'captcha/',
//'font_path' => './path/to/fonts/texb.ttf',
'img_width' => '200',
'img_height' => 80,
'expiration' => 60,
'word_length' => 10,
'font_size' => 26,
'img_id' => 'Imageid',
'pool' => '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ',
// White background and border, black text and red grid
'colors' => array(
'background' => array(255, 255, 255),
'border' => array(255, 255, 255),
'text' => array(0, 0, 0),
'grid' => array(255, 40, 40)
)
);
$cap = create_captcha($vals);
var_dump($cap);
/*
array (size=4)
'word' => string 'hFan3NM4xB' (length=10)
'time' => float 1436954914.3053
'image' => string '<img id="Imageid" src="http://localhost/citest/captcha/1436954914.3053.jpg" style="width: 200; height: 80; border: 0;" alt=" " />' (length=129)
'filename' => string '1436954914.3053.jpg' (length=19)
*/
echo $cap['image'];
注意:需要手动创建存放验证码的文件夹,验证码图片会在超时后自动删除。
CodeIgniter学习笔记五:分页,文件上传,session,验证码的更多相关文章
- [原创]java WEB学习笔记49:文件上传基础,基于表单的文件上传,使用fileuoload 组件
本博客为原创:综合 尚硅谷(http://www.atguigu.com)的系统教程(深表感谢)和 网络上的现有资源(博客,文档,图书等),资源的出处我会标明 本博客的目的:①总结自己的学习过程,相当 ...
- PHP学习笔记--文件目录操作(文件上传实例)
文件操作是每个语言必须有的,不仅仅局限于PHP,这里我们就仅用PHP进行讲解 php的文件高级操作和文件上传实例我放在文章的最后部分.--以后我还会给大家写一个PHP类似于网盘操作的例子 注意:阅读此 ...
- PHP学习笔记 02 之文件上传
我们了解了表单传值后,这些我就可以完成PHP的文件上传了.我们了解PHP文件上传前,先了解PHP文件上传的原理. 一.PHP上传文件原理 第一步:将本地的文件通过form表单上传到服务器的临时目录中, ...
- (转载)JavaWeb学习总结(五十)——文件上传和下载
源地址:http://www.cnblogs.com/xdp-gacl/p/4200090.html 在Web应用系统开发中,文件上传和下载功能是非常常用的功能,今天来讲一下JavaWeb中的文件上传 ...
- struts2学习笔记之十:文件上传
Struts2的上传 1.Struts2默认采用了apache commons-fileupload 2.Struts2支持三种类型的上传组件 3.需要引入commons-fileupload相关依赖 ...
- JavaWeb学习总结(五十)——文件上传和下载
在Web应用系统开发中,文件上传和下载功能是非常常用的功能,今天来讲一下JavaWeb中的文件上传和下载功能的实现. 对于文件上传,浏览器在上传的过程中是将文件以流的形式提交到服务器端的,如果直接使用 ...
- SpringMVC学习总结(五)——SpringMVC文件上传例子
这是用的是SpringMVC-3.1.1.commons-fileupload-1.2.2和io-2.0.1 首先是web.xml <?xml version="1.0" e ...
- Kali学习笔记38:文件上传漏洞
早些年,提到Web渗透,或者搜索一些黑客教程 基本都会看到文件上传漏洞. 它是一个很经典的漏洞 但它本质其实不是一个漏洞,而是网站本身的上传文件功能 不过如果我们上传了Webshell,那么就成为了文 ...
- SpringMVC学习笔记八:文件上传下载(转)
转自:http://www.cnblogs.com/WJ-163/p/6269409.html 一.关键步骤 ①引入核心JAR文件 SpringMVC实现文件上传,需要再添加两个jar包.一个是文件上 ...
- SpringBoot学习笔记(8)-----SpringBoot文件上传
直接上代码,上传文件的前端页面: <body> <form action="/index/upload" enctype="multipart/form ...
随机推荐
- 如何使用ABAP代码反序列化JSON字符串成ABAP结构
假设我有这个JSON字符串如下图所示: 我的任务是解析出上图黑色方框里的几个字段,比如ObjectID, ETag, BuyerID, DateTime, ID, Name等等,把它们的值存储到对应A ...
- python 爬糗事百科
糗事百科网站段子爬取,糗事百科是我见过的最简单的网站了!!! #-*-coding:utf8-*- import requests import re import sys reload(sys) s ...
- 【转】WebSocket 是什么原理?为什么可以实现持久连接?
WebSocket是HTML5出的东西 也就是说HTTP协议没有变化 但HTTP是不支持持久连接的(长连接,循环连接的不算)或者说WebSocket干脆就不是基于HTTP来执行的.但是...说不通啊. ...
- Ext4.2 select 和 query 区别与联系
Ext.query和Ext.select的作用是一致的,同是根据CSS选择符查找出一个或多个元素.区别在于返回类型上.分别是:query方法返回的是JavaScript标准的数组类型:select方法 ...
- 前端css样式及选择器
标题: 1.scc概述 2.行内样式 3.内接样式 4.外接样式(链接式) 推荐使用 5.外接样式(导入式) 6.嵌套规则 7.css选择器 1.scc(Cascading Style Shee ...
- 前端面试整理(HTML&CSS)
1.行内元素和块级元素?img算什么?行内元素怎么转化为块级元素? 行内元素:和有他元素都在一行上,高度.行高及外边距和内边距都不可改变,文字图片的宽度不可改变,只能容纳文本或者其他行内元素:其中im ...
- Oracle 启动 停止JOB
转自:https://www.cnblogs.com/qianbing/p/6971633.html --查看job下次执行时间以及间隔时间 '; --启动job ); --停用job EXEC DB ...
- noip2018 洛谷 P5020 货币系统
关键: 要使m最小,(m,b)中的数不能用(n,a)中的数表示出来 对于 3 19 10 6 19=10+3+3+3 6=3+3 只有3 和 10 不能被(n,a)中的数表示 所以m=2 只需要 ...
- Maven_项目管理工具
Maven 一.Maven是apache下的一个开源项目,是纯java开发,并且只是用来管理java项目的 二.Maven的好处: 0.节省空间:对jar包做了统一管理 依赖管理,项目里无需放jar包 ...
- 如何在maven中的项目使用tomcat插件
在pom.xml中引入tomcat7插件,具体示例代码如下: <project> <build> <plugins> <plugin> <grou ...