站三界导航
首页 TP代码tp5文章评论系统

tp5文章评论系统

  • TP代码
  • 来源:站三界导航
  • 56阅读
  • 2022-10-06

前言
ThinkPHP是一个免费开源的,快速、简单的面向对象的轻量级PHP开发框架,是为了敏捷WEB应用开发和简化企业应用开发而诞生的。ThinkPHP从诞生以来一直秉承简洁实用的设计原则,在保持出色的性能和至简的代码的同时,也注重易用性。遵循Apache2开源许可协议发布,意味着你可以免费使用ThinkPHP,甚至允许把你基于ThinkPHP开发的应用开源或商业产品发布/销售。

一、ThinkPHP5实现用户登录,文章评论。
登录验证,文章评论关联,

二、使用步骤
1.创建数据表
CREATE TABLE `user` (
  `id` int(10) NOT NULL AUTO_INCREMENT,
  `t_id` int(10) DEFAULT NULL,
  `name` varchar(30) COLLATE utf8_unicode_ci DEFAULT NULL,
  `pwd` varchar(50) COLLATE utf8_unicode_ci DEFAULT NULL,
  `nikename` varchar(30) COLLATE utf8_unicode_ci DEFAULT NULL,
  `status` enum('0','1') COLLATE utf8_unicode_ci DEFAULT NULL COMMENT '0异常 1正常',
  `created_at` timestamp NULL DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP,
  `updated_at` timestamp NULL DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP,
  PRIMARY KEY (`id`)
) ENGINE=MyISAM AUTO_INCREMENT=9 DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
CREATE TABLE `comment` (
  `id` int(10) NOT NULL AUTO_INCREMENT,
  `u_id` int(10) DEFAULT NULL,
  `t_id` int(10) DEFAULT NULL,
  `comment_content` varchar(200) COLLATE utf8_unicode_ci DEFAULT NULL,
  `created_at` timestamp NULL DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP,
  `updated_at` timestamp NULL DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP,
  PRIMARY KEY (`id`)
) ENGINE=MyISAM AUTO_INCREMENT=3 DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
CREATE TABLE `theme` (
  `id` int(10) NOT NULL AUTO_INCREMENT,
  `u_id` int(10) DEFAULT NULL,
  `c_id` int(10) DEFAULT NULL,
  `classify` varchar(10) COLLATE utf8_unicode_ci DEFAULT NULL,
  `title` varchar(50) COLLATE utf8_unicode_ci DEFAULT NULL,
  `content` text COLLATE utf8_unicode_ci,
  `image_url` varchar(100) COLLATE utf8_unicode_ci DEFAULT NULL,
  `comment_count` int(6) DEFAULT NULL,
  `created_at` timestamp NULL DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP,
  `updated_at` timestamp NULL DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP,
  PRIMARY KEY (`id`)
) ENGINE=MyISAM AUTO_INCREMENT=3 DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
2.视图层
login:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>站三界导航www.zhansanjie.com</title>
    <!-- 最新版本的 Bootstrap 核心 CSS 文件 -->
    <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@3.3.7/dist/css/bootstrap.min.css" integrity="sha384-BVYiiSIFeK1dGmJRAkycuHAHRg32OmUcww7on3RYdg4Va+PmSTsz/K68vbdEjh4u" crossorigin="anonymous">
    <!-- 可选的 Bootstrap 主题文件(一般不用引入) -->
    <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@3.3.7/dist/css/bootstrap-theme.min.css" integrity="sha384-rHyoN1iRsVXV4nD0JutlnGaslCJuC7uwjduW9SVrLvRYooPp2bWYgmgJQIXwl/Sp" crossorigin="anonymous">
    <!-- 最新的 Bootstrap 核心 JavaScript 文件 -->
    <script src="https://cdn.jsdelivr.net/npm/bootstrap@3.3.7/dist/js/bootstrap.min.js" integrity="sha384-Tc5IQib027qvyjSMfHjOMaLkfuWVxZxUPnCJA7l2mCWNIpG9mGCD8wGNIcPD7Txa" crossorigin="anonymous"></script>
</head>
<body>
<form action="get-info" method="post">
    {:token()}
    用户名: <input type="text" name="name">
    <br>
    密码: <input type="password" name="pwd">
    <br>
    验证码 <input type="text" name="yzm">
    <div><img src="{:captcha_src()}" alt="captcha" onclick="this.src='{:captcha_src()}'" /></div>
    <input type="submit" value="登录">
</form>
</body>
</html>
list:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>站三界导航www.zhansanjie.com</title> <!-- 最新版本的 Bootstrap 核心 CSS 文件 -->
    <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@3.3.7/dist/css/bootstrap.min.css" integrity="sha384-BVYiiSIFeK1dGmJRAkycuHAHRg32OmUcww7on3RYdg4Va+PmSTsz/K68vbdEjh4u" crossorigin="anonymous">
    <!-- 可选的 Bootstrap 主题文件(一般不用引入) -->
    <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@3.3.7/dist/css/bootstrap-theme.min.css" integrity="sha384-rHyoN1iRsVXV4nD0JutlnGaslCJuC7uwjduW9SVrLvRYooPp2bWYgmgJQIXwl/Sp" crossorigin="anonymous">
    <!-- 最新的 Bootstrap 核心 JavaScript 文件 -->
    <script src="https://cdn.jsdelivr.net/npm/bootstrap@3.3.7/dist/js/bootstrap.min.js" integrity="sha384-Tc5IQib027qvyjSMfHjOMaLkfuWVxZxUPnCJA7l2mCWNIpG9mGCD8wGNIcPD7Txa" crossorigin="anonymous"></script>
</head>
<body>
<h2>今日头条 <a href="/Wx/Users/logout" style="float: right;font-size: 14px;margin-top: 10px">退出登录</a></h2>

<div>
    <table class="table table-hover">
        <tr>
            <th>标题</th>
            <th></th>
            <th>操作</th>
        </tr>
        {volist name='list' id='user'}
        {volist name="user['comment']" id="sub"}
        <tr>
            <td>
                {$user.title}
                <div style="font-size: 10px;margin-top: 10px;color: #9F9F9F">发布时间:{$user.created_at} &nbsp;&nbsp;&nbsp; 类型:{$user.classify} &nbsp;&nbsp;&nbsp; 评论数:{$user.comment_count}</div>
            </td>
            <td><img src="/uploads/{$user.image_url}" alt="" width="60px" height="60px" class="img-circle"></td>
            <td><a href="\theme\detail?id={$user.id}" style="line-height: 50px">详情</a></td>
        </tr>
        {/volist}
        {/volist}
    </table>
    <div style="font-size: 12px;margin-top: 50px; margin-left: 10px">共有 {$total} 条</div>
</div>
{$page|raw}
</body>
</html>
detail:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>站三界导航www.zhansanjie.com</title> <!-- 最新版本的 Bootstrap 核心 CSS 文件 -->
    <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@3.3.7/dist/css/bootstrap.min.css" integrity="sha384-BVYiiSIFeK1dGmJRAkycuHAHRg32OmUcww7on3RYdg4Va+PmSTsz/K68vbdEjh4u" crossorigin="anonymous">
    <!-- 可选的 Bootstrap 主题文件(一般不用引入) -->
    <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@3.3.7/dist/css/bootstrap-theme.min.css" integrity="sha384-rHyoN1iRsVXV4nD0JutlnGaslCJuC7uwjduW9SVrLvRYooPp2bWYgmgJQIXwl/Sp" crossorigin="anonymous">
    <!-- 最新的 Bootstrap 核心 JavaScript 文件 -->
    <script src="https://cdn.jsdelivr.net/npm/bootstrap@3.3.7/dist/js/bootstrap.min.js" integrity="sha384-Tc5IQib027qvyjSMfHjOMaLkfuWVxZxUPnCJA7l2mCWNIpG9mGCD8wGNIcPD7Txa" crossorigin="anonymous"></script>
</head>
<body>
<h2>详情</h2>
<div>
    <table class="table table-hover">
        {volist name='lists' id='data'}
        {volist name="data['comment']" id="su"}
        {volist name="data['user']" id="s"}
        <tr>
            <td style="text-align: center">{$data.title}</td>
        </tr>
        <tr>
            <td>{$data.content}</td>
        </tr>
        <tr>
            <td><input type="button" onclick="createInput()" value="评论 :"/></td>
        </tr>
        <tr>
            <td>{$s.name}:{$su.comment_content}</td>
        </tr>
        {/volist}
        {/volist}
        {/volist}
    </table>
</div>

<div id="test">
</div>

</body>
</html>
<script>
    function createInput()
    {
        document.getElementById("test").innerHTML = "<form action='get-info' method='post' > 评论:<input type='text' name='comment_content' /> <input type='submit' value='提交' /> </form>";

    }
</script>
3.验证器
validate:
<?php

namespace app\wx\validate;

use think\Validate;

class Wxs extends Validate
{
    /**
     * 定义验证规则
     * 格式:'字段名'	=>	['规则1','规则2'...]
     *
     * @var array
     */	
	protected $rule = [
        'name' => 'require|max:25|token',
        'pwd' => 'require',
        'yzm' => 'require|captcha',
    ];
    
    /**
     * 定义错误信息
     * 格式:'字段名.规则名'	=>	'错误信息'
     *
     * @var array
     */	
    protected $message = [
        'name.require'        => '姓名必填',
        'name.max'        => '姓名最多不能超过25个字符',
        'name.token'        => 'token验证',
        'pwd.require'        => '密码必填',
        'yzm.require'        => '验证码必填',
        'yzm.captcha'        => '验证码错误',
    ];
}
3.模型层
User:
<?php
namespace app\wx\model;

use think\facade\Session;
use think\Model;

class User extends Model
{
    // 自动写入时间戳字段
    protected $autoWriteTimestamp = 'timestamp';// true 开启;false 关闭
// 创建时间字段自定义
    protected $createTime = 'created_at';// 默认create_time
// 更新时间字段自定义
    protected $updateTime = 'updated_at';// 默认update_time

    // 设置当前模型对应的完整数据表名称
    protected $table = 'user';

    //用户表多对多关联
    public function theme()
    {
        return $this->belongsTo('Theme');
    }
    //用户登录
    public static function login($data)
    {
        $user = self::where('status',1)->where('name',$data['name'])->find();
        if($user){
            if($user['pwd'] == md5($data['pwd'])){
                session('name',$user['name']);
                session('id',$user['id']);
                return 3; //信息正确
            }else{
                return 2; //密码 错误
            }
        }else{
            return 1; //用户不存在
        }
    }

    //退出登录
    public static function logout()
    {
        Session::delete('name');
        Session::delete(('id'));
        Session::clear();
    }

}
Theme:

<?php
namespace app\wx\model;

use think\facade\Cache;
use think\facade\Debug;
use think\Model;
class Theme extends Model
{
// 自动写入时间戳字段
    protected $autoWriteTimestamp = 'timestamp';// true 开启;false 关闭
// 创建时间字段自定义
    protected $createTime = 'created_at';// 默认create_time
// 更新时间字段自定义
    protected $updateTime = 'updated_at';// 默认update_time

    // 设置当前模型对应的完整数据表名称
    protected $table = 'theme';

    //建立和comment的关联
    public function comment()
    {
        return $this->hasMany('Comment','t_id');//hasOne是一对一
    }
    //建立和user的关联
    public function user()
    {
        return $this->hasMany('User','t_id');//hasMany是一对多
    }

    const CACHE_KEY_PREFIX = __CLASS__.'-'.__FILE__.'-id:';

    public static function getUserById($id)
    {
        $cacheKey = self::CACHE_KEY_PREFIX.$id;
        //Debug::remark('cache key',$cacheKey);

        if(Cache::has($cacheKey)){
            $info = Cache::get($cacheKey);
        }else{
            $info = self::with('user,comment')->where('id','=',$id)->all();
            Cache::set($cacheKey,$info,3600);
        }
        return $info;
    }

    public static function delUserById($id)
    {
        $cacheKey = self::CACHE_KEY_PREFIX.$id;
        if(self::where('id',$id)->delete()){
            Cache::rm($cacheKey);
            return true;
        }else{
            return false;
        }
    }
}
Comment:

<?php
namespace app\wx\model;

use think\Model;
class Comment extends Model
{
// 自动写入时间戳字段
    protected $autoWriteTimestamp = 'timestamp';// true 开启;false 关闭
// 创建时间字段自定义
    protected $createTime = 'created_at';// 默认create_time
// 更新时间字段自定义
    protected $updateTime = 'updated_at';// 默认update_time

    // 设置当前模型对应的完整数据表名称
    protected $table = 'comment';

    public function theme()
    {
        return $this->belongsTo('Theme');
    }
}
4.控制器
Users:
<?php
namespace app\wx\controller;

use app\wx\model\User;
use think\Controller;
use think\Request;

class Users extends Controller
{
    public function login()
    {
        return view('user/login');
    }

    public function getInfo(Request $request)
    {
        $data = $request->param();

        $result = $this->validate($data,'\app\wx\validate\Wxs',[],false);
        if(true !== $result){
            dump($result);
            exit();
        }
        if($request->isPost()){
            $user = new User();
            $data = input('post.');
            $num = $user->login($data);
            if($num==3){
                $this->success('信息正确,正在为您跳转','Wx/Themes/themeList');
            }else{
                $this->error('用户名或密码有误');
            }
        }
        return $this->fetch('login');
    }

    public function logout()
    {
        User::logout();
        $this->success('退出成功,正在为您跳转','Wx/Users/login');
    }
}
Themes:

<?php
namespace app\wx\controller;

use app\wx\model\Comment;
use app\wx\model\User;
use app\wx\model\Theme;
use think\Controller;

class Themes extends Controller
{

//    protected $users;
//    protected $comment;
//
//    public function __construct(User $user, Comment $comment)
//    {
//        $this->users = $user;
//        $this->comment = $comment;
//    }


    //列表
    public function themeList()
    {
        // 查询状态为1的用户数据 并且每页显示10条数据
        $list = Theme::paginate(5);

        // 获取总记录数
        $total = $list->total();
// 获取分页显示
        $page = $list->render();
// 模板变量赋值

        $this->assign('total', $total);
        $this->assign('list', $list);
        $this->assign('page', $page);

// 渲染模板输出
        return $this->fetch('theme/list');

    }

    //详情
    public function detail($id)
    {
        $lists = Theme::getUserById($id);

//        $a = $lists['content'];

// 渲染模板输出
        $this->assign('lists',$lists);
        return $this->fetch('theme/detail');
    }

    public function lists()
    {
        $member=new Theme();
        $list=$member->with('user,comment')->find()->toArray();//查询一条ID为15的用户数据;toArray()是将结果转为数组。
        $a = [];
        foreach($list as $k=>$v){

        }
        dump($list['comment']);
        exit();
    }

    /**
     * 删除指定资源
     *
     * @param  int  $id
     * @return \think\Response
     */
    public function delete(Theme $theme,$id)
    {
        if($theme->delUserById($id)){
            $msg = '删除成功';
        }else{
            $msg = '删除失败';
        }
        return $msg;
    }
}
Comments:

<?php
namespace app\wx\controller;

use think\Controller;

class Comments extends Controller
{

}
   /**
     * 显示资源列表
     *
     * @return \think\Response
     */
    public function index($kw='')
    {
        if($kw !== ''){
            $list = \app\demo\model\Login::where('name','like',"%$kw%")->paginate(1,false,['query'=>request()->param()]);
        }else{
            $list = \app\demo\model\Login::where('id' ,'>' , 1)->paginate(3,false);
        }
        // 获取分页显示
        $page = $list->render();
        // 获取总记录数
        $total = $list->total();
// 模板变量赋值
        $this->assign('kw',$kw);
        $this->assign('list', $list);
        $this->assign('total', $total);
        $this->assign('page', $page);
// 渲染模板输出
        return $this->fetch('list/list');
    }

    public function add()
    {

        return $this->fetch('login/add');
    }
    /**
     * 显示创建资源表单页.
     *
     * @return \think\Response
     */
    public function addImage(Request $request)
    {
        $a = new \app\demo\model\Login();

        $data['name'] = $request->param('name');
        $data['pwd'] = $request->param('pwd');

        // 获取表单上传文件 例如上传了001.jpg
        $file = $request->file('image');
        // 移动到框架应用根目录/uploads/ 目录下
        $info = $file->move(Config::get('upload.upload_path'));
        if($info){
            // 成功上传后 获取上传信息
            // 输出 jpg
            echo "文件类型:".$info->getExtension();
            echo "<br><br>";
            // 输出 20160820/42a79759f284b767dfcb2a0197904287.jpg
            echo "上传文件路径:".$info->getSaveName();
            echo "<br><br>";
            // 输出 42a79759f284b767dfcb2a0197904287.jpg
            echo "文件名:".$info->getFilename();
            echo "<br><br>";
            echo $info->getPathname();
        }else{
            // 上传失败获取错误信息
            echo $file->getError();
        }

        $data['image'] = $info->getSaveName();

        $b = $a->save($data);
        if($b){
            $this->success('添加成功,跳转到','demo\Login\index');
        }else{
            $this->error('添加失败');
        }
    }

本文结束
本文来自投稿,不代表站三界导航立场,如若转载,请注明出处:https://www.zhansanjie.com/article/details/10960.html

版权声明:

1、本文系转载,版权归原作者所有,旨在传递信息,不代表看本站的观点和立场。

2、本站仅提供信息发布平台,不承担相关法律责任。

3、若侵犯您的版权或隐私,请联系本站管理员删除。

4、本文由会员转载自互联网,如果您是文章原创作者,请联系本站注明您的版权信息。

分享
站三界导航
本站声明:本站严格遵守国家相关法律规定,非正规网站一概不予收录。本站所有资料取之于互联网,任何公司或个人参考使用本资料请自辨真伪、后果自负,站三界导航不承担任何责任。在此特别感谢您对站三界导航的支持与厚爱。