登录:

login.html

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<script src="__PUBLIC__/js/jquery-1.11.2.min.js"></script>
<title>登录页面</title>
<style type="text/css">
*{ margin:0px auto; padding:0px}
</style>
</head>

<body>
<div>用户名:<input type="text" id="user" /></div>
<div>密码:<input type="password" id="pass" /></div>
<div><input type="button" value="登录" id="btn" /></div>
</body>
<script type="text/javascript">
$("#btn").click(function(){
    var user = $("#user").val();
    var pass = $("#pass").val();
    $.ajax({
    url:"__CONTROLLER__/yanzheng",
    data:{User:user,Pass:pass},
    type:"POST",
    dataType:"TEXT",
    success: function(data)
    {
        if(data == "ok")
        {
            window.location.href= "__MODULE__/Main/xianshi";//__MODULE__:获取模块所在的路径
        }
    }
    });
});
</script>
</html>

LoginController.class.php

<?php
namespace Liuyan\Controller;
use Think\Controller;
class LoginController extends Controller
{
    public function login()
    {
        $this->show();
    }
    public function yanzheng()
    {    /*echo "<script type='text/javascript'>alert('aaa');</script>";*/
        $n = D("Yuangong");
        $uid = $_POST["User"];
        $pwd = $_POST["Pass"];
        $sql = "select pass from yuangong where user='{$uid}'";
        $r = $n->query($sql);
        //var_dump($r[0][pass]);
        if(!empty($r[0][pass]) && $r[0][pass]==$pwd)    //$r是一个二维数组,$r[0][pass]取出密码(string类型)
        {
            session("user",$uid);                //登录之后,存session
            $this->ajaxReturn("ok","eval");        //登录成功,ajax返回ok到login.html页面,进行下一步操作
        }
        else if(empty($r[0][pass]) || $r[0][pass] != $pwd)//如果密码为空或者输入的密码和数据库中此用户名的密码不匹配,返回登录页面
        {
            $this->redirect("Liuyan/Login/login","array()",3,"请登录...");
        }
    }
}

ParentController.class.php:中间过渡控制器;parent::__construct(); //在构造函数里面加这一句,防止报错

<?php
namespace Liuyan\Controller;
use Think\Controller;
class ParentController extends Controller
{
    public function __construct()
    {
        parent::__construct();        //在构造函数里面加这一句,防止报错
        if(session('?user'))
        {
        }
        else
        {
            $this->redirect('Liuyan/Login/login',array(),3,'请登录...');
        }
    }
}

主页面:xianshi.html

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<script src="__PUBLIC__/js/jquery-1.11.2.min.js"></script><!--引入jQuery文件-->
<title>主页面    </title>
<style type="text/css">
*{ margin:0px auto; padding:0px}
</style>
</head>

<body>
<div>
    <div style="float:left">
        <a href="__CONTROLLER__/xiugai"><h1>发布信息</h1></a>
    </div>
    <div style="float:left; margin-left:30px">
        <a href="__CONTROLLER__/qing" id="aa"><h1>退出系统</h1></a>
    </div>
</div><br /><br /><br />

<div>
<span><h3>留言信息</h3></span>
<table width="60%" border="1" cellpadding="0" cellspacing="0" id="tb">
</table>
</div>
<div style="height:20px;">{$btn}</div>
<script type="text/javascript">
$(document).ready(function(e) {
$.ajax({
url:"__CONTROLLER__/yemian",
data:{},
type:"POST",
dataType:"JSON",
success: function(data)
{
    var str = "<tr><td>发送人</td><td>发送时间</td><td>接收人</td><td>信息内容</td></tr>";
    for(a in data)    //JSON接受循环显示数据方法
    {
        str+="<tr><td>"+data[a].sender+"</td><td>"+data[a].times+"</td><td>"+data[a].recever+"</td><td>"+data[a].comment+"</td></tr>";
    }
    $("#tb").append(str);
}
});
});
</script>
</body>
</html>

修改页面:xiugai.html

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<script src="__PUBLIC__/js/jquery-1.11.2.min.js"></script><!--引入jQuery文件-->
<title>发布信息</title>
<style type="text/css">
*{ margin:0px auto; padding:0px}
</style>
</head>

<body>
<div>
<div style="float:left">
<a href="__CONTROLLER__/xianshi"><h1>查看信息</h1></a>
</div>
<div style="float:left; margin-left:30px">
<a href="__CONTROLLER__/qing" id="aa"><h1>退出系统</h1></a>
</div>
</div><br /><br /><br />

<div>
    <div>
        信息发送:
    </div>
    <div>
        <div>
        <span>接收人:</span>
       <select id="inp">
       <foreach name="a" item="v" >
       <option>{$v.firend}</option>
        </foreach>
       </select>
        </div>

        <div>
        <span>信息内容:</span><textarea name="comment" id="tx"></textarea>
        </div>

    </div>
    <div><input type="button" value="发送" id="btn" /><input type="reset" value="复位" /></div>
</div>
<script type="text/javascript">
$("#btn").click(function(){
var inp = $("#inp").val();
var tx = $("#tx").val();
$.ajax({
url:"__CONTROLLER__/addxian",
data:{inp:inp,tx:tx},
type:"POST",
dataType:"TEXT",
success: function(data)
{
    if(data == 'ok')
    {
        window.location.href="__CONTROLLER__/xianshi";
    }
    else if(data=="no")
    {
        alert("您输入的内容不能为空");
    }
    else
    {
        window.location.href="__CONTROLLER__/xiugai";
    }
}
});
});
</script>
</body>
</html>

主控制器(显示和修改):MainController.class.php

<?php
namespace Liuyan\Controller;
use Liuyan\Controller\ParentController;
class MainController extends ParentController
{
    public function xianshi()
    {
        $this->show();
    }

    /*public function yemian()//按钮注册不到html页面,若要实现分页,需要注册页面再显示($this->show();)
    {
        $n = D("liuyan");
        $zs = $n->count();    //求数据总数
        $p = new \Liuyan\fzl\Page($zs,3);
        $attr = $n->limit($p->limit)->select();    //echo $p->limit;输出为0,2,直接放到$n->limit()中
        $btndiv = $p->fpage();    //翻页按钮
        $this->assign("btn",$btndiv);//翻页按钮注册到前台显示
        $this->ajaxReturn($attr);
    } */

    public function yemian()//模糊查询
    {
        $km = $_POST["km"];
        $kt = $_POST["kt"];
        $n = D("liuyan");
        $sql = "select * from liuyan where recever like '%{$km}%' and comment like '%{$kt}%'";
        $attr = $n->query($sql);
        $this->ajaxReturn($attr);
    }
    public function xiugai()    //发布信息页面收件人下拉列表显示
    {
        $n = D("Firend");
        $a = $n->select();
        $this->assign("a",$a);
        $this->show();
    }
    public function addxian()    //$data["ids"]:添加到数据库的列数据
    {
        $data["Ids"]="";
        $data["Sender"] = session("user");
        $data["Recever"] = $_POST["inp"];
        $data["Times"] = date("Y-m-d H:i:s");
        $data["Comment"] = $_POST["tx"];
        $data["States"]="";
        $n = D("Liuyan");
        if(empty($_POST["inp"]) || empty($_POST["tx"]))
        {
            echo "no";
        }
        else
        {
            $r = $n->add($data);    //添加数据库
            if($r)
            {
                echo "ok";
            }
        }
    }
    public function qing()        //点击退出系统,清session,跳转到登录页面,
    {
        session(null);
        $this->redirect("Liuyan/Login/login",array(),0);
    }
}

__________

thinkphp留言板例子(多条件查询)的更多相关文章

  1. PHP基础知识总结(四) 留言板例子 知识应用

    1.留言板显示页面:note.php <?php $host = "127.0.0.1"; $user = "root"; $pwd = "zs ...

  2. thinkphp留言板开发笔记 1 - 新的

    关于php数组的排序函数的总结: 有很多种排序方式和排序规则: 正常排序和反向排序, 使用 -r来表示 排序时是否考虑索引/下标, 如果考虑则加上-a, a=associate. sort是按值来排序 ...

  3. thinkphp where()条件查询

    今天来给大家讲下查询最常用但也是最复杂的where方法,where方法也属于模型类的连贯操作方法之一,主要用于查询和操作条件的设置.where方法的用法是ThinkPHP查询语言的精髓,也是Think ...

  4. ThinkPHP中 按条件查询后列表显示

    最近在项目中遇到了需要根据下拉框的条件筛选出符合条件的数据,然后进行列表显示的问题. 在ThinkPHP中进行列表显示的传统过程:通过在后台控制器中查询出数据,然后通过$this->assign ...

  5. JavaWeb 例子 JDBC+JSP登陆注册留言板

    注册页面: <%@ page language="java" contentType="text/html; charset=UTF-8" pageEnc ...

  6. thinkphp分页+条件查询

    最近项目上面有一个带条件查询的分页列表,一开始form用的post,点击第二页就没有跳转成功,原因是分页是get请求,post数据链接到其他页面就会被清除. 解决办法: 1.form表单method= ...

  7. 【weiphp微信开发教程】留言板插件开发详解

    基于weiphp框架的留言板插件教程: 1.功能分析 传统的留言板应该具有发布留言.查看留言.回复留言.管理留言等功能,本教程开发的是最基本的留言板,仅包含发布留言和查看留言两个功能,根据功能用boo ...

  8. 动态多条件查询分页以及排序(一)--MVC与Entity Framework版url分页版

    一.前言 多条件查询分页以及排序  每个系统里都会有这个的代码 做好这块 可以大大提高开发效率  所以博主分享下自己的6个版本的 多条件查询分页以及排序 二.目前状况 不论是ado.net 还是EF ...

  9. flask实战-留言板-Web程序开发流程

    Web程序开发流程 在实际的开发中,一个Web程序的开发过程要设计多个角色,比如客户(提出需求).项目经理(决定需求的实现方式).开发者(实现需求)等,在这里我们假设自己是一个人全职开发.一般来说一个 ...

随机推荐

  1. Java的native方法

    一. 什么是Native Method   简单地讲,一个Native Method就是一个java调用非java代码的接口.一个Native Method是这样一个java的方法:该方法的实现由非j ...

  2. Angular2 入门

    1. 说明 该文档为Angular2的入门文档,可以根据该文档的内如做出一个“helloworld”类型的Angualr2入门程序,通过该文档可以初步了解Angular2的相关知识以及开发流程,同时搭 ...

  3. Git命令之资源

    https://git-scm.com/book/zh/v2/Git-%E5%88%86%E6%94%AF-%E5%88%86%E6%94%AF%E7%9A%84%E6%96%B0%E5%BB%BA% ...

  4. (转)Nginx SSL+tomcat集群,request.getScheme() 取到https正确的协议

    转自http://www.cnblogs.com/interdrp/p/4881785.html 最近在做一个项目, 架构上使用了 Nginx +tomcat 集群, 且nginx下配置了SSL,to ...

  5. ASP.NET知识总结(3.HTTP协议详解)

    引言 HTTP是一个属于应用层的面向对象的协议,由于其简捷.快速的方式,适用于分布式超媒体信息系统.它于1990年提出,经过几年的使用与发展,得到不断地完善和扩展.目前在WWW中使用的是HTTP/1. ...

  6. 以前用SQL实现的机构职能树,再看看

    DECLARE CNT NUMBER; TMP ); vtmp ); ltmp1 ); ltmp2 ); ltmp3 ); ltmp4 ); NTMP NUMBER; CURSOR CSR_TEST ...

  7. 第二十九篇:使用SOUI的SMCListView控件

    列表控件是客户端应用最常用的控件之一.列表控件通常只负责显示数据,最多通知一下APP列表行的选中状态变化. 现在的UI经常要求程序猿在列表控件里不光显示内容,还要能和用户交互,显示动画等等,传统的列表 ...

  8. UDP协议开发

    UDP是用户数据报协议(User Datagram Protocol,UDP)的简称,其主要作用是将网络数据流量压缩成数据报形式,提供面向事务的简单信息传送服务.与TCP协议不同,UDP协议直接利用I ...

  9. Python爬虫学习(6): 爬取MM图片

    为了有趣我们今天就主要去爬取以下MM的图片,并将其按名保存在本地.要爬取的网站为: 大秀台模特网 1. 分析网站 进入官网后我们发现有很多分类: 而我们要爬取的模特中的女模内容,点进入之后其网址为:h ...

  10. Android 自动化测试—robotium(十一) robotium实现微博绑定

    利用robotium实现微博的自动绑定 android应用进行微博绑定主要有两种方式,一种客户端实现个webView,请求微博默认的授权页,另一种则是直接调用微博客户端,这里实现的为前一种,即进和微博 ...