PHP关于表单提交 后 post get分页

PHP关于表单提交后分页函数的那点事--POST表单分页实现

phpfunctionclass加密inputjavascript

说到分页,其实你在Google一搜一大把.大部是通过GET实现,还有的是利用数据库查询的Limit来实现分页.当然表单也可以通过GET方式来提交,实现分页,就得把实现分页需用到参数用GET方式附在URL后面如这样:

http://127.0.0.1/search.php?page=1&参数1=参数1值

当然我们有的时候并不想让别人知道我们要提交什么东东,要解决这一问题最简单的方法就是加密要提交内容的值或者改用POST方式提交表单.这里先说一下加密参数值.加密的方法花样百出,就看你发挥了,没有做不到,只有想不到.我最爱用的方法就是最简单的pack()和unpack()来实现加解密字符串,这样不是最好的,但是够简单,提交的内容不再是赤裸裸的,提交时将字符串加密一下,处理时将收到的加密后的字符串解一下密,就OK了.函数如下:

[php] view plaincopy

  1. //简单加密字符串函数
  2. function str_encode($str){
  3. $t = implode("",unpack("H*",$str));
  4. return base64_encode($t);
  5. }
  6. //简单解密字符串函数
  7. function str_decrypt($str){
  8. $t = base64_decode($str);
  9. $s = "";
  10. for($i=0;$i <strlen($t);$i+=4)
  11. $s .= @pack("H4",substr($t,$i,4));
  12. return $s;
  13. }

上面简单的说明了一下GET提交表单,要分页就用下面的分页函数来实现.很简单,不用改什么.重点我来说说当POST提交表单,并分页显示的问题,重点在于当我们POST提交表单后处理,点击第几页怎样才能保存我们原表单的值,不然,可能第一页正常,分页也正常,点第二页结果就什么也没有了,这肯定不是我们想要的结果,怎样才能达到我们所想要的呢,就是增加一个单击事件函数来处理表单的提交.

分页函数,没什么好说,在网上找个现成的(这函数真是牛人写的写得太牛了),原函数如下:

[php] view plaincopy

  1. //分页函数
  2. function multi($num, $perpage, $curpage, $mpurl, $maxpages = 0, $page = 10, $autogoto = true, $simple = false) {
  3. $multipage = ‘‘;
  4. $mpurl .= strpos($mpurl, ‘?‘) ? ‘&amp;‘ : ‘?‘;
  5. $realpages = 1;
  6. if ($num > $perpage) {
  7. $offset = 2;
  8. $realpages = @ceil($num / $perpage);
  9. $pages = $maxpages && $maxpages < $realpages ? $maxpages : $realpages;
  10. if ($page > $pages) {
  11. $from = 1;
  12. $to = $pages;
  13. } else {
  14. $from = $curpage - $offset;
  15. $to = $from + $page - 1;
  16. if ($from < 1) {
  17. $to = $curpage + 1 - $from;
  18. $from = 1;
  19. if ($to - $from < $page) {
  20. $to = $page;
  21. }
  22. } elseif ($to > $pages) {
  23. $from = $pages - $page + 1;
  24. $to = $pages;
  25. }
  26. }
  27. $multipage = ($curpage - $offset > 1 && $pages > $page ? ‘<a href="‘ . $mpurl . ‘page=1" class="first"‘ . $ajaxtarget . ‘>1 ...</a>‘ : ‘‘) .
  28. ($curpage > 1 && !$simple ? ‘<a href="‘ . $mpurl . ‘page=‘ . ($curpage - 1) . ‘" class="prev"‘ . $ajaxtarget . ‘>&lsaquo;&lsaquo;</a>‘ : ‘‘);
  29. for($i = $from; $i <= $to; $i++) {
  30. $multipage .= $i == $curpage ? ‘<strong>‘ . $i . ‘</strong>‘ :
  31. ‘<a href="‘ . $mpurl . ‘page=‘ . $i . ($ajaxtarget && $i == $pages && $autogoto ? ‘#‘ : ‘‘) . ‘"‘ . $ajaxtarget . ‘>‘ . $i . ‘</a>‘;
  32. }
  33. $multipage .= ($curpage < $pages && !$simple ? ‘<a href="‘ . $mpurl . ‘page=‘ . ($curpage + 1) . ‘" class="next"‘ . $ajaxtarget . ‘>&rsaquo;&rsaquo;</a>‘ : ‘‘) .
  34. ($to < $pages ? ‘<a href="‘ . $mpurl . ‘page=‘ . $pages . ‘" class="last"‘ . $ajaxtarget . ‘>... ‘ . $realpages . ‘</a>‘ : ‘‘) .
  35. (!$simple && $pages > $page && !$ajaxtarget ? ‘<kbd><input type="text" name="custompage" size="3" onkeydown="if(event.keyCode==13) {window.location=\‘‘ . $mpurl . ‘page=\‘+this.value; return false;}" /></kbd>‘ : ‘‘);
  36. $multipage = $multipage ? ‘</div><DIV id="quicklinks">‘ . (!$simple ? ‘<em>&nbsp;‘ . $num . ‘&nbsp;</em>‘ : ‘‘) . $multipage . ‘</div>‘ : ‘‘;
  37. }
  38. $maxpage = $realpages;
  39. return $multipage;
  40. }

上面的函数是在网上找的原分页函数,此函数用于GET方法的页面直接使用就OK了,用于POST页面,只需要在函数内的页面链接<A>标签里增加一个onclick事件函数,如下:<A href="#" onclick="gotoPage(1);">第一页</A>,然后在页面里增加一个javascript方法见下:

[php] view plaincopy

  1. <script language="javascript">
  2. //函数跳转到指定页面
  3. function gotoPage(page)
  4. {
  5. document.getElementById("page").value = page;  //隐藏表单的页控件
  6. document.getElementById("searchForm").submit();
  7. }
  8. //函数:回来第1页
  9. function gotoFirstPage()
  10. {
  11. document.getElementById("page").value = 1;  //隐藏表单的页控件
  12. }
  13. </script>
  14. <!-- 表单参考如下 -->
  15. <form name="searchForm" id="searchForm" method="post" action="<?php echo $_SERVER[‘PHP_SELF‘]; ?>">
  16. <!-- 下面是个隐藏页面号码值控件 -->
  17. <input type="hidden" name="page" id="page" size=30 value="<?php echo $page;?>"   />
  18. <!-- 下面是个查找条件值控件 -->
  19. <input type="text" name="photoname" id="photoname" size=30 value="<?php echo $photoname;?>"   />
  20. <!-- 提交控钮,注意id和name不要把值设成"submit",我将其改为"submit1" -->
  21. <!-- 不然在gotoPage()函数里与表单的提交事件submit()有冲突,导至函数不运行 -->
  22. <!-- 这个提交按钮还增加了一个单击事件gotoFirstPage() -->
  23. <!-- 作用就是无论何时当你点击查找按钮后页面都会是第1页,其实就是将隐藏的页面控制值设为1 -->
  24. <input name="submit1" id="submit1" onclick="gotoFirstPage()" type="submit" value="查  找" size=30 />
  25. </form>
  26. <!-- 当然这样改了后,还应该改改原来的分页函数,1.增页分页码链接的单击事件 -->
  27. <!-- 2.让<A>标签href的值为"#",作用当然就是不要<A>标签点击后,页面跳转,只让单击事件来提交表单取得指定页面 -->
  28. <!-- 我尽量在少改动原函数的情况下,只在href后面增加"#?",因为这个原函数在href后面带有"?"号,实际我只要在在最前面增加一个#号就OK,原函数修改如下 -->
  29. <?php
  30. //分页函数
  31. function multi($num, $perpage, $curpage, $mpurl, $maxpages = 0, $page = 10, $autogoto = true, $simple = false) {
  32. $multipage = ‘‘;
  33. $mpurl .= strpos($mpurl, ‘?‘) ? ‘&‘ : ‘?‘;
  34. $realpages = 1;
  35. if ($num > $perpage) {
  36. $offset = 2;
  37. $realpages = @ceil($num / $perpage);
  38. $pages = $maxpages && $maxpages < $realpages ? $maxpages : $realpages;
  39. if ($page > $pages) {
  40. $from = 1;
  41. $to = $pages;
  42. } else {
  43. $from = $curpage - $offset;
  44. $to = $from + $page - 1;
  45. if ($from < 1) {
  46. $to = $curpage + 1 - $from;
  47. $from = 1;
  48. if ($to - $from < $page) {
  49. $to = $page;
  50. }
  51. } elseif ($to > $pages) {
  52. $from = $pages - $page + 1;
  53. $to = $pages;
  54. }
  55. }
  56. //注意下面href后面我增加了一个#号,让链接失效,在后面增加onclick函数
  57. $multipage = ($curpage - $offset > 1 && $pages > $page ? ‘<a href="#‘ . $mpurl . ‘page=1"  onclick="gotoPage(1);" class="first"‘ . $ajaxtarget . ‘>1 ...</a>‘ : ‘‘) .
  58. ($curpage > 1 && !$simple ? ‘<a href="#‘ . $mpurl . ‘page=‘ . ($curpage - 1) . ‘"  onclick="gotoPage(‘ . ($curpage - 1) . ‘);" class="prev"‘ . $ajaxtarget . ‘>‹‹</a>‘ : ‘‘);
  59. for($i = $from; $i <= $to; $i++) {
  60. $multipage .= $i == $curpage ? ‘<strong>‘ . $i . ‘</strong>‘ :
  61. ‘<a href="#‘ . $mpurl . ‘page=‘ . $i . ($ajaxtarget && $i == $pages && $autogoto ? ‘#‘ : ‘‘) . ‘"‘ . $ajaxtarget . ‘  onclick="gotoPage(‘ . $i .‘);" target="_blank" target="_blank">‘ . $i . ‘</a>‘;
  62. }
  63. $multipage .= ($curpage < $pages && !$simple ? ‘<a href="#‘ . $mpurl . ‘page=‘ . ($curpage + 1) . ‘"  onclick="gotoPage(‘ . ($curpage + 1) . ‘);" class="next"‘ . $ajaxtarget . ‘>››</a>‘ : ‘‘) .
  64. ($to < $pages ? ‘<a href="#‘ . $mpurl . ‘page=‘ . $pages . ‘"  onclick="gotoPage(${pages});" class="last"‘ . $ajaxtarget . ‘>... ‘ . $realpages . ‘</a>‘ : ‘‘) .
  65. //下面这一行注释掉,改了一下超过10页,可以手动输入页码跳转到指定页面函数
  66. //      (!$simple && $pages > $page && !$ajaxtarget ? ‘<kbd><input type="text" name="custompage" size="3" onkeydown="if(event.keyCode==13) {window.location=\‘‘ . $mpurl . ‘page=\‘+this.value; return false;}" /></kbd>‘ : ‘‘);
  67. (!$simple && $pages > $page && !$ajaxtarget ? ‘<kbd><input type="text" name="custompage" size="3" onkeydown="if(event.keyCode==13) {gotoPage(this.value);}" /></kbd>‘ : ‘‘);
  68. $multipage = $multipage ? ‘</div><DIV id="quicklinks">‘ . (!$simple ? ‘<em> ‘ . $num . ‘ </em>‘ : ‘‘) . $multipage . ‘</div>‘ : ‘‘;
  69. }
  70. $maxpage = $realpages;
  71. return $multipage;
  72. }
  73. ?>

上面的方法就实现了POST表单分页,这是我个人笔记,这里仅贴出了部份代码,仅供参考,有不对的地方还望指正.....

时间: 2024-11-02 21:57:13

PHP关于表单提交 后 post get分页的相关文章

struts2 jsp表单提交后保留表单中输入框中的值 下拉框select与input

原文地址:struts2 jsp表单提交后保留表单中输入框中的值 下拉框select与input jsp页面 1     function dosearch() {2         if ($("#textValue").val() == "") {3                 $("#errortip").html("<font color='#FF0000'>请输入查询内容</font>")

怎么实现form表单提交后不重新刷新当前页面

怎么实现表单提交后不重新刷新当前页面 如何实现表单提交后不重新刷新当前页面 <form name='form1' id='form1' action='/xbcw/cw/xx_xx.action' method='post'> <input type="button" id="btnSubmit" name="btnSubmit" value="保存" onclick="addKp()"

form表单提交后保持输入的值

1.form表单提交后,继续保持原来输入的值 <html xmlns="http://www.w3.org/1999/xhtml"> <head runat="server"> <meta charset="UTF-8"> <title>form表单提交后保持输入的值</title> </head> <body> <form class="form

iframe+javascript实现一个表单提交后多个处理文件按序处理

最近在弄一个网页的问题,总结如下. [问题描述] 页面中包括以下几个部分:1)表单form,供用户输入图片文件:2)iframe1,显示a.php文件的内容,a.php接收客户端图片并保存,后台程序处理图片,生成相关数据文件:3)iframe2,显示b.php文件的内容,b.php读取结果文件对其进行分页显示: [实现思路] 以上功能主要在于两个问题: 1,form表单提交的形式一般是:input type="sumit"的表单元素配合form的action地址完成提交.此处要求先用a

Jquery表单提交后获取返回Json值

1.给form添加id值: <form action="/News/SaveMessage" method="post" accept-charset="utf-8" class="form" id="frm-reg" name="frm-reg"> 设置所有input标签的name属性值为数据库的字段值,即可以传值到后台 2.给提交按钮添加id值: <input cl

form表单提交后结果乱码的解决方法

1.产生乱码原因:表单提交使用的method="get",get方式数据都是通过地址栏传输,数据会以iso-8859-1方式传输,因此产生乱码 2.概念:URI: Uniform ResourceIdentifiers,通用资源标识符,有效的URI中不能包含某些字符,例如空格 3.解决编码和解码的方法: (1)js中decodeURIComponent() 函数的定义与用法: 定义:decodeURIComponent() 函数编码的URI进行解码[encodeURIComponent

Jquery 表单提交后3s禁用

<form action="${pageContext.servletContext.contextPath}/XXX/###" method="post" id="messageForm"> 姓名:<input name = "name" type="text" /> <button type="button" id="submit"&

layui弹出表单提交后,界面model验证部分起作用

情况1----input属性中type=submit时验证都可以起作用,但是弹出层表单的返回值不能获取,所以用ajax二次提交后会出现重复添加数据的问题 情况2----input属性中type=button时验证部分起作用,其他正常,暂时看到的不起作用是required属性不起作用,正则表达式可以完美提醒 初步判断原因可能是用ajax+button表单并未完成提交,model的required属性验证必须在提交后台控制器后刷新提交页面才会出现,但是button方式并刷新界面,正则表达式的就算不刷

weui-switch开关控件,表单提交后如何取值

最近在学习weui这个框架,做了一些小的试验,发现weui-switch控件直接提交不能获取到表单信息,在segmentfault上发现也有人提了这个问题,有人说可以设置一个隐含标签来捕获开关的状态,试了一下,确实可以,把我自己的解决方法写下来如下: weui这个switch开关控件好像确实只能用来显示开关状态,无法提交数据,我根据楼上的思路,建了一个隐藏的radio标签,然后通过这个开关控件来设置radio标签的value属性,这样提交,后台php就能获取到正确的表单信息了: <!--隐含元素