mysql中简单安全处理和分页算法

简单分页算法

//查询总条数
$sql = "select count(*) from tablename";

分页

跳过几条(偏移量) $offset = ($page-1) * $pagesize

  • 当前页
    $page = isset($_GET['page']) ? : 1 ;

  • 每页显示数量
    $pageSize = 3;

  • 查询所有留言,并放入$messageList变量中
    //$sql = "SELECT * FROM message LIMIT {$offset}, {$pageSize}";
    1.规定每页显示几条数据 $pagesize = 3;
    2.为了计算最大页码($pageCount),需要查询总记录数($itemCount) 计算公式: $pageCount = ceil($itemCount / $pageSize);
    3.接受当前页码 $page = isset($_GET['page']) ? : 1 ;
    4.当前页码有效性处理(当页码小于1时, 让它等于1) $page = max($page, 1);
    5.计算分页的偏移量 $offset = ($page-1) * $pagesize;
    6.SQL中的limit部分 "SELECT * FROM table_name LIMIT $offset , $pagesize";

  • 分页搜索
    搜索表单用get传值(为了保持搜索条件在点击下一页时保持不变使用)
    //建立一个数组
    $condition = [];
    //如果$_GET传过来的值不为空,将其保存在数组中
    if(!empty($_GET['id'])){
    $condition[] = ''id = '{$_GET['id']}' ";
    }
    if(!empty($_GET['title'])){
    $condition[] = ''title like '%{$_GET['title']}%' ";
    }
    //如果$condition不为空,用函数jion()将其拼接,组成分页搜索where 条件
    $where = '';
    if(count($condition) > 0){
    $where = 'where' . join(' and ', $condition); //and左右需要空格
    }

$sql = "SELECT * FROM 表名 where $where LIMIT $offset , $pagesize";

  • 搜索分页条件保持

$get = $_GET;
unset($get['page']); //因为之前有一个page,所以在拼接前将之前的page删除掉,
$query = '&' . http_build_query($get); //当搜索条件传过去的时候拼接一个$query的字符串
然后将$query拼接到url中,当点击下一页,条件将通过url再次传递
<a href="admin.php?page=<?php echo $pageCount; ?>&<?php echo $query; ?>">尾页</a>

数据的安全处理

1.字符串
例如:

$title = mysqli_real_escape_string($title);

$title = mysqli_real_escape_string($link, $title);

$name = mysqli_real_escape_string($link, $name);

$email = mysqli_real_escape_string($link, $email);

$content = mysqli_real_escape_string($link, $content);

2.数字处理
$id = intval($id);
*如果不对上传的数据中特殊的字符进行转义,将会造成数据库的不安全,
例如上传的数据为 a; drop table catogory(表名); 此时将会删除掉数据中的category表

sql增删改查是否成功判断

php中有一些扩展(extension)没有打开,例如PHP_mysqli.ext,使用时需到php.ini中将extension_dir=ext写入打开
error 报错显示如果找不到哪个函数, 例如mb_strlen 此时需要到php.ini 中找到扩展并打开
*$link = mysqli_connect()/mysqli_set_charset()/mysqli_select_db/以及增/删/改返回的都是布尔值,
select查询返回的是对象,此时需要释放结果.
删除/修改 mysqli_affected_rows()来判断
新增 mysqli_inset_id()来判断
邮箱的长度需设置 varchar(225);
建表时字段的属性 text后面没有任何约束

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 196,264评论 5 462
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 82,549评论 2 373
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 143,389评论 0 325
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,616评论 1 267
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,461评论 5 358
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,351评论 1 273
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,776评论 3 387
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,414评论 0 255
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,722评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,760评论 2 314
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,537评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,381评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,787评论 3 300
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,030评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,304评论 1 252
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,734评论 2 342
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,943评论 2 336

推荐阅读更多精彩内容

  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,514评论 18 399
  • 转 # https://www.cnblogs.com/easypass/archive/2010/12/ 08/...
    吕品㗊阅读 9,682评论 0 44
  • 一. Java基础部分.................................................
    wy_sure阅读 3,778评论 0 11
  • Mybatis 分页插件实现 有数据的地方就有分页,分页的sql基本大加都会写,MySQL可以用limit,Ora...
    思无涯1993阅读 1,177评论 0 3
  • 去年开始在微信里卖老家亲戚做的牛肉干,后来又陆陆续续卖点零食,化妆品。开始还卖的挺好,一个月几十斤牛肉干,最近几个...
    我叫马三阅读 279评论 2 0