基于ThinkPHP8 + Vue3 + element-ui-plus + 微信小程序(原生) + Vant2 的 BBS论坛系统设计【PHP课设】

一、BBS论坛功能描述

我做的是一个论坛类的网页项目,每个用户可以登录注册查看并发布文章,以及对文章的点赞和评论,还有文件上传和个人签名发布和基础信息修改,管理员对网站的数据进行统计,对文章和文件的上传以及评论进行审核,以及对普通的用户的权限提升账号封停等等,以及对应的crud。

然后做的是三端(PC端,小程序端)并且采用前后端分离以及JWT技术和RestFull风格API,后端使用ThinkPHP8,PC端使用vue3+element-ui-plus,Axios异步通信以及诸多扩展,微信小程序端使用原生的微信小程序技术+vant2 UI组件库,数据库使用mysql8.0.3.

功能分为以下几个模块

  1. 用户端
    (1) 用户的登录注册模块(均使用token鉴权的技术,后续的每个操作都是建立在token上面,密码使用md5加密)
    (2) 用户的个人基础信息修改保存,以及头像上传(采用的是上传到本地服务器中,然后返回对应的域名Url并且更新到数据库表中)
    (3) 用户的签名信息发布及历史签名查看
    (4) 不同用户的文章发布,文章发布大致包括标题,封面插图,摘要信息,以及内容(内容部分使用了markdown的渲染及保存
    (5) 文章的评论(可以一级评论和二级评论)
    (6) 文章的点赞和文章的访问量模块(访问量做的是每次点击进入对应的文章时,访问量加一)
    (7) 所有文章的概览,分页以及多条件查询
    (8) 文件上传(支持任意格式的文件,文件上传后需要管理员进行审核才能看到)
    (9) 文件下载及浏览
    (10) 天气组件(使用高德天气,实时的查询当天的天气并且进行渲染)
    (11) 看板娘扩展(使用Live2d)制作了一个看板娘,点击时会触发语音及文字通知
    (12) 鼠标点击特效(使用原生的js完成,原理就是一个大的canvas进行绘制)
    (13) 页面整体颜色的切换(使用vue操控dom元素完成)
    (14) 网易云音乐组件(使用网易云外链工具,然后添加了切换歌曲上下首)
    (15) 聊天机器人(基于青云客接口,并且自行封装了chat界面)
    (16) 友链

  2. 管理员端
    (1) 用户的增删改查,及用户账号的注销封停和启用
    (2) 评论的增删改查,及不当评论的过滤删除
    (3) 文章的审核,增删改查
    (4) 文件的审核,以及增删改查
    (5) 网站的统计信息部分(注册统计图表,不同模块的文章数统计图表,每天的top5文章访问量统计图表)
    (6) 天气组件(使用高德天气,实时的查询当天的天气并且进行渲染)
    (7) 看板娘扩展(使用Live2d)制作了一个看板娘,点击时会触发语音及文字通知
    (8) 鼠标点击特效(使用原生的js完成,原理就是一个大的canvas进行绘制)
    (9) 页面整体颜色的切换(使用vue操控dom元素完成)

  3. 小程序端
    (1) 文章模块的概览
    (2) 文章的查询和浏览
    (3) 文章的评论及点赞
    (4) 用户的登录和注册
    (5) 用户的头像上传
    (6) 用户的基本信息修改
    (7) 用户的签名信息发布

二、系统效果图

(一)PC端部分(展示一些部分图)

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

|

在这里插入图片描述

|

在这里插入图片描述


在这里插入图片描述

|

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述


在这里插入图片描述


在这里插入图片描述


在这里插入图片描述


在这里插入图片描述

在这里插入图片描述


在这里插入图片描述

(二)小程序端 (展示一些部分图)

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述


在这里插入图片描述

在这里插入图片描述

在这里插入图片描述


在这里插入图片描述

三、技术说明

(一)后端部分

后端的技术使用了PHP语言的ThinkPHP8框架,并且采用了前后端分离的技术(前端负责处理页面的展示和用户交互,后端则负责提供数据和业务逻辑处理。前端通过发送请求获取数据,后端接收到请求后处理数据并返回JSON格式的响应)通过JSON接口的方式与前端进行交互,RestFull风格API以及JWT token鉴权和Cores跨域配置,多种类型文件的上传与处理

后端项目中,使用到了多模块设计,分为index和admin两个模块(但是尚未使用另一个模块)。前端发送的请求通过基础的mvc架构去处理,自定义了状态码枚举类和restfull API通用JSON返回格式。

(二)PC端前端部分

PC端使用了Vue3,和element-ui-plus UI 框架,通过手动封装的axios异步网络请求库进行请求的发送和响应处理,通过vite配置反向代理服务器,实现前端的跨域配置

自定义了一个基于element-ui-plus container布局容器的布局组件,可以实现页面布局的自适应。

使用了particles3 粒子背景插件,实现登录页面的粒子背景和交互点击特效。

集成了vue-md-editor markdown编辑器,实现了论坛中markdown格式文章的发布以及markdown格式文章的渲染

以及高德地图天气API接口和青云客聊天机器人接口,从而实现论坛中天气组件的天气的实时获取以及聊天机器人功能的实现。

最后还使用了基于live2d的看板娘插件,实现论坛中看板娘的交互点击特效。

(三)移动端-纯原生微信小程序

微信小程序端,使用了原生的微信小程序技术,UI 框架使用的是Vant Weapp2同时集成了iconfont中的图标组件,通过原生的wx.request去发送请求。自定义了页面中的tabbar组件,实现微信小程序点击tabbar进行页面的切换;集成了towxml第三方插件,实现微信小程序页面中去渲染markdown格式的文本(即将其转换为富文本格式再进行渲染)。

四、代码部分

代码很多,我直接放我的git仓库的地址了

(一)后端

在这里插入图片描述

PS :仓库地址 https://gitee.com/zhweb2022/bbs-course-thinkphp

(二)vue端

在这里插入图片描述


在这里插入图片描述


在这里插入图片描述

PS :仓库地址 https://gitee.com/zhweb2022/bbs-course-vue

(三)微信小程序部分

在这里插入图片描述

在这里插入图片描述

PS :仓库地址 https://gitee.com/zhweb2022/bbs-course-wechatapp

五、数据库部分

/*
 Navicat Premium Data Transfer

 Source Server         : mysql
 Source Server Type    : MySQL
 Source Server Version : 80031
 Source Host           : localhost:3306
 Source Schema         : bbs

 Target Server Type    : MySQL
 Target Server Version : 80031
 File Encoding         : 65001

 Date: 24/11/2023 10:35:34
*/

SET NAMES utf8mb4;
SET FOREIGN_KEY_CHECKS = 0;

-- ----------------------------
-- Table structure for articles
-- ----------------------------
DROP TABLE IF EXISTS `articles`;
CREATE TABLE `articles`  (
  `id` int(0) NOT NULL AUTO_INCREMENT COMMENT '文章id',
  `uid` int(0) NOT NULL COMMENT '用户id',
  `author` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL COMMENT '发布人',
  `avatar` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL COMMENT '用户头像',
  `blockid` int(0) NOT NULL COMMENT '文章属于哪个板块id',
  `blockpath` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL COMMENT '板块路径',
  `img` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL COMMENT '文章封面',
  `content` text CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL COMMENT '文章内容',
  `like` int(0) NOT NULL COMMENT '点赞数',
  `ctime` datetime(0) NOT NULL COMMENT '文章发布时间',
  `title` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL COMMENT '文章标题',
  `count` int(0) NULL DEFAULT NULL COMMENT '文章浏览量',
  `comment` int(0) NULL DEFAULT NULL COMMENT '文章评论数',
  `status` int(0) NOT NULL DEFAULT 0 COMMENT '状态码',
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 27 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_0900_ai_ci ROW_FORMAT = Dynamic;

-- ----------------------------
-- Records of articles
-- ----------------------------
INSERT INTO `articles` VALUES (1, 2, 'robin', 'http://robin.com/storage/index/20231030/43102dd204b968857792020b38d70bcf.jpeg', 5, '日常模块/天道酬勤', 'http://robin.com/storage/index/20230910/fd5c75163b09b766248fddd51f2caeb7.jpg', '# 嗯~ o(* ̄▽ ̄*)o,阿良不猛!\n>簪子上有八个字,便是仅算粗通文墨的少女,也觉得极为动人。 言念君子,温其如玉。\n\n白泽转头,伸手指向那座只说规模、不太起眼的雄镇楼,“屋舍就牢固了,世上家家相亲,孝如卯榫,在家中遮风避雨不难了,推开门去,读书越多,琢磨越多,忠义礼仪就自然而然跟上了。要我说啊,以后哪天门内世道变得亲情疏离,夫妻离散无负担,门外世道人人为己,傻子太少,聪明人太多,那个世道才是真正在往下走,因为世道这个屋舍的细微处,越来越失去黏性了。所以这也是老秀才当年不愿首徒崔瀺太早推出“事功学问”的原因所在,不是那头绣虎的学问不好,而是一个不慎,就会弊端太大,到时候至圣先师、礼圣亲自出手补救,都难有成效。父子之间,夫妻之间,若是都要斤斤计较利益得失,那就会比释道两家更早进入人心上的末法时代。\n\n\n\n![外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传](https://img-home.csdnimg.cn/images/20230724024159.png"token punctuation">, 1, '2023-09-08 15:36:28', '言念君子,温其如玉。', 82, 22, 1);
INSERT INTO `articles` VALUES (2, 8, '技术模块/JAVA技术', 'http://robin.com/storage/index/20231002/bc509b0b5fc1a695ce08940957410a59.jpg', 'JVM作为Java运行的基础,很难相信对于JVM一点都不了解的人可以把Java语言吃得很透。我在面试有超过3年Java经验的开发者的时候, JVM几乎就是一个必问的问题了。当然JVM不是唯一决定技术能力好坏的面试问题,但是可以佐证Java开发能力的高低。\r\n\r\n\r\n\r\n在JVM这个大类中,我认为需要掌握的知识有:\r\n\r\nJVM内存模型和结构\r\n\r\nGC原理,性能调优\r\n\r\n调优:Thread Dump, 分析内存结构\r\n\r\nclass 二进制字节码结构, class loader 体系 , class加载过程 , 实例创建过程\r\n\r\n方法执行过程\r\n\r\nJava各个大版本更新提供的新特性(需要简单了解)', '2023-09-09 22:18:32', 'JVM', 24, 4, 1);
INSERT INTO `articles` VALUES (3, 'http://robin.com/storage/index/20231002/cf3c770a1490c727d64b4c32de0979c6.jpg', '多线程是Java中普遍认为比较难的一块。多线程用好了可以有效提高cpu使用率, 提升整体系统效率, 特别是在有大量IO操作阻塞的情况下;但是它也是一柄双刃剑, 如果用不好,系统非但提升不大,或者没有提升,而且还会带来多线程之间的调试时等问题。\n\n在多线程中内容有很多,只是简单说明一下Java中初步使用多线程需要掌握的知识点,以后有机会单独再详细介绍一些高级特性的使用场景。\n\n# 多线程的实现和启动\n\n## callable 与 runable 区别\n\nsyncrhoized ,reentrantLock 各自特点和比对\n![外链图片转存失败, '2023-09-09 22:21:15', '多线程并发', 27, 0, 1);
INSERT INTO `articles` VALUES (4, 'http://robin.com/storage/index/20230910/5ffc4c42c1e9059e060c640c661c41b7.jpg', '>其实这两块内容都不是J2SE里面的内容,但是在日常开发中,和其他程序交互,和配置文件交互,越来越离不开这两种格式的解析。\n\n>不过对于一个开发者来说,能够了解一些XML/JSON具体解析的原理和方法,有助于你在各个具体的场景中更好的选择合适你的方式来使得你的程序更有效率和更加健壮。\nXML: 需要了解 DOM解析和 SAX解析的基本原理和各自的适用场景\nJSON: 需要了解一些常用JSON框架的用法, 如 Jackson, FastJson, Gson 等。。\n\n\n# xml(Extensible Markup Language)可拓展标记语言\n1)XML的简单易于在任何应用程序中读/写数据,这使XML很快成为数据交换的唯一公共语言,虽然不同的应用软件也支持其他的数据交换格式,但不久之后它们都将支持XML,那就意味着程序可以更容易的与Windows、Mac OS、Linux以及其他平台下产生的信息结合,然后可以很容易加载XML数据到程序中并分析它,并以XML格式输出结果。\n\n2)xml可用作数据的说明、储存、传输\n\n举个例子:假设一个微信群里面小明发了一条消息“你吃过没”。而这条消息发出后会被储存到服务器里,而当你进入微信的时候,这条消息就会从服务器里抓取过来显示到你的手机上。而这个抓取的过程中假设是以xml文件来传输(也有json,json和xml用途很相似,json、xml都有自己的格式,但其实都只是包装数据时格式不同而已,重要的是其中含有的数据,而不是包装的格式。这里只是举个例子)这时,我们用通俗易懂的文字来表示就是:\n![外链图片转存失败, '2023-09-10 07:44:33', 'XML解析/ JSON解析', 11, 1);
INSERT INTO `articles` VALUES (5, 'http://robin.com/storage/index/20230910/2736a1211aae97f7eef0573d6fa87740.jpg', 'Maven也不是Java里面的内容,但是maven是革命性的,给Java开发带来了巨大的便利。从依赖的引入和管理,开发流程的更新和发布产出,乃至版本的更新,使用maven可以大大简化开发过程中的复杂度,从而节省大量时间。可以说,maven已经成为Java开发者的标配了。所以我把maven也作为一个Java开发者对于基础必备的知识点。以后会再放上一些我的一些对于maven使用的经验和技巧等,这里就不再细说了。\r\n\r\nMaven也不是Java里面的内容,但是maven是革命性的,给Java开发带来了巨大的便利。从依赖的引入和管理,开发流程的更新和发布产出,乃至版本的更新,使用maven可以大大简化开发过程中的复杂度,从而节省大量时间。可以说,maven已经成为Java开发者的标配了。所以我把maven也作为一个Java开发者对于基础必备的知识点。以后会再放上一些我的一些对于maven使用的经验和技巧等,这里就不再细说了。\r\n\r\nMaven也不是Java里面的内容,但是maven是革命性的,给Java开发带来了巨大的便利。从依赖的引入和管理,开发流程的更新和发布产出,乃至版本的更新,使用maven可以大大简化开发过程中的复杂度,从而节省大量时间。可以说,maven已经成为Java开发者的标配了。所以我把maven也作为一个Java开发者对于基础必备的知识点。以后会再放上一些我的一些对于maven使用的经验和技巧等,这里就不再细说了。\r\n\r\n', '2023-09-10 09:44:33', 'Maven的使用', 7, 1);
INSERT INTO `articles` VALUES (6, '几乎对于每个应用来说,时间日期的处理也是绕不过去的,但是JDK8 之前的时间相关API用法并不友好。在那个时代,可以选择Joda等时间框架。到了JDK8 发布之后,全新的时间API基本融合了其他框架的优点,已经可以很好的直接使用了。\r\n\r\n对于Java开发者来说,需要熟练地使用API来对时间和日期做相关的处理。', '时间日期处理', 1);
INSERT INTO `articles` VALUES (9, 10, 'ccc', 'http://robin.com/storage/index/20231004/3afab15bcd3cfa3074dc5f79b9584a13.jpeg', '日常模块/聊天灌水', 'http://robin.com/storage/index/20230910/f21e49e6063bb951a0a2377a9a8635df.jpg', '今日台词:陆抬缓缓说道这人间不来也罢', '2023-09-10 15:59:33', '可恶的剑来!!!', 1);
INSERT INTO `articles` VALUES (10, 'ddd', 'http://robin.com/storage/index/20231004/bf44510a752e071bcafc3255f1ea5da6.jpeg', 'http://robin.com/storage/index/20230910/61ae8c6129e4f02a711427a3f96e158e.jpeg', '啦啦啦啦啦', '2023-09-10 16:12:20', '向阳花木易为春2', 1);
INSERT INTO `articles` VALUES (11, 'http://robin.com/storage/index/20230911/2d7b3a70c8eb95df57c43b3ffdd7fa64.jpeg', '胸中一点浩然气,天地千里快哉风。\n摘自《水调歌头·黄州快哉亭赠张偓佺》\n苏轼\n落日绣帘卷,亭下水连空。知君为我新作,窗户湿青红。长记平山堂上,欹枕江南烟雨,杳杳没孤鸿。认得醉翁语,山色有无中。\n一千顷,都镜净,倒碧峰。忽然浪起,掀舞一叶白头翁。堪笑兰台公子,未解庄生天籁,刚道有雌雄。 一点浩然气,千里快哉风。\n\n![外链图片转存失败, '2023-09-11 18:48:14', '逆水寒测试', 1);
INSERT INTO `articles` VALUES (12, 'http://robin.com/storage/index/20231002/9d7b70dd3391ae5a223855f9a093f7f0.jpeg', '好家伙,就差echarts基本完事了\nづ♡ど\n\n◍\'ㅅ\'◍ つ♡⊂ Ծ‸Ծ\n\n(୨୧ᵕ̤ᴗᵕ̤)\n\n(///∇//)\n\n(♡˙︶˙♡)\n\n(づ◡ど)\n\n(๑ơ ₃ ơ)♥ ♡(˃͈ દ ˂͈ ༶ )\n\n❀(///▽///)❀\n\n(Д゚෴°д)\n\n略略略\n```text\n        /*\n                           _ooOoo_\n                          o8888888o\n                          88\" . \"88\n                          (| -_- |)\n                          O\\  =  /O\n                       ____/`---\'\\____\n                     .\'  \\\\|     |//  `.\n                    /  \\\\|||  :  |||//  \\\n                   /  _||||| -:- |||||-  \\\n                   |   | \\\\\\  -  /// |   |\n                   | \\_|  \'\'\\---/\'\'  |   |\n                   \\  .-\\__  `-`  ___/-. /\n                 ___`. .\'  /--.--\\  `. . __\n              .\"\" \'<  `.___\\_<|>_/___.\'  >\'\"\".\n             | | :  `- \\`.;`\\ _ /`;.`/ - ` : | |\n             \\  \\ `-.   \\_ __\\ /__ _/   .-` /  /\n        ======`-.____`-.___\\_____/___.-`____.-\'======\n                           `=---=\'\n        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n                 佛祖保佑       永无BUG\n        */\n```\n------------------------------------\n![外链图片转存失败, '2023-09-29 09:14:08', '测bug的一天', 20, 1);
INSERT INTO `articles` VALUES (16, '技术模块/微信小程序', 'http://robin.com/storage/index/20231001/c9b2aff9ae4b34f03e0750ba25d02089.jpg', '模块启用测试\n\n------------------------------------\n\n![外链图片转存失败, '2023-10-01 15:40:30', '模块启用下线测试', 1);
INSERT INTO `articles` VALUES (17, 12, '技术模块/php', 'http://robin.com/storage/index/20231002/0c8f2701e5674242a5326d28de2cc2d3.png', '# 测试普通文本\n\nMarkdown 是一种轻量级标记语言,创始人为约翰·格鲁伯(John Gruber)。 它允许人们使用易读易写的纯文本格式编写文档,然后转换成有效的 XHTML(或者HTML)文档。这种语言吸收了很多在电子邮件中已有的纯文本标记的特性。\n由于 Markdown 的轻量化、易读易写特性,并且对于图片,图表、数学式都有支持,许多网站都广泛使用 Markdown 来撰写帮助文档或是用于论坛上发表消息。 如 GitHub、Reddit、Diaspora、Stack Exchange、OpenStreetMap 、SourceForge、简书等,甚至还能被使用来撰写电子书。\n\nJohn Gruber在2004年创造了Markdown语言,在语法上有很大一部分是跟亚伦·斯沃茨(Aaron Swartz)共同合作的。这个语言的目的是希望大家使用“易于阅读、易于撰写的纯文字格式,并选择性的转换成有效的XHTML(或是HTML)”。 其中最重要的设计是可读性,也就是说这个语言应该要能直接在字面上的被阅读,而不用被一些格式化指令标记(像是RTF与HTML)。 因此,它是现行电子邮件标记格式的惯例,虽然它也借鉴了很多早期的标记语言,如:Setext、Texile、reStructuredText。\n标准化\nMarkdown已经成为典型的转换为HTML的非正式规范 [1] 和参考实现。随着时间的推移,出现了许多Markdown实现。人们开发这些主要是由于在基本语法之上需要额外的功能 - 例如表格,脚注,定义列表(技术上的HTML描述列表)和HTML块内的Markdown。其中一些行为偏离了最开始的参考实现。与此同时,非正式规范中的一些含糊不清引起了人们的注意 [2] 。这些问题促使Markdown解析器的一些开发人员努力实现标准化。\n2016年3月发布了RFC 7763和RFC 7764。RFC 7763 从原始变体引入了MIME类型 text/markdown。RFC 7764讨论并注册了MultiMarkdown、GitHub Flavored Markdown (GFM)、Pandoc、CommonMark及Markdown等变体。 [3]\nCommonMark\n\n摘抄够啦   \n![外链图片转存失败, '2023-10-02 02:30:07', '测试markdown文章', 16, 1);
INSERT INTO `articles` VALUES (18, '技术模块/vue技术2', 'http://robin.com/storage/index/20231002/c182ce55779bd5dc82a24219c3d65f58.jpg', '# v-md-editor\n推荐使用 v-md-editor\nv-md-editor 是基于 Vue 开发的 markdown 编辑器组件\n\n1. 轻量版编辑器\n轻量版编辑器左侧编辑区域使用 textarea 实现。\n\n优点:足够轻量\n缺点:不支持更为丰富的编辑区功能扩展。例如:无法根据不同的语法在输入框内显示不同的样式。\n\n2. 进阶版编辑器\n进阶版编辑器左侧编辑区域使用 CodeMirror (opens new window)实现。\n\n优点:可以根据 CodeMirror 提供的 Api 来自定义扩展编辑区域功能,提高编辑体验。\n缺点:文件体积远大于轻量版\n\n3. 预览组件\n当你只需要对 markdown 语法进行解析并预览的时候,可以使用该组件。\n\n4. html 预览组件\n当你只需要对保存后的 html 文本进行预览的时候,可以使用该组件。\n\n5. 特性\n高度可定制化,高度可扩展性,支持自定义主题包,提供开箱即用的主题包,提供多个组件。可按需使用。\n\n# 使用\n\n## 1.markdown编辑器\n这里只讲基于vue3的使用\n\n先去挂载,然后再使用\n```javascript\nimport { createApp } from \'vue\';\nimport VMdEditor from \'@kangc/v-md-editor\';\nimport \'@kangc/v-md-editor/lib/style/base-editor.css\';\nimport githubTheme from \'@kangc/v-md-editor/lib/theme/github.js\';\nimport \'@kangc/v-md-editor/lib/theme/style/github.css\';\n\n// highlightjs\nimport hljs from \'highlight.js\';\n\nVMdEditor.use(githubTheme,{\n  Hljs: hljs,\n});\n\nconst app = createApp(/*...*/);\n\napp.use(VMdEditor);\n```\n\n页面使用\n```html\n<template>\n  <v-md-editor v-model=\"text\" height=\"400px\"></v-md-editor>\n</template>\n\n<script>\nexport default {\n  data() {\n    return {\n      text: \'\',\n    };\n  },\n};\n</script>\n```\n![外链图片转存失败,建议将图片保存下来直接上传](https://img-home.csdnimg.cn/images/20230724024159.png"content\"></v-md-preview>\n</template>\n<script setup>\n import {ref} from \'vue\'\n const content =ref(\"\") \n</script>\n```\n![外链图片转存失败, '2023-10-02 02:48:22', 'vue3中使用markdown插件的用法', 50, 1);
INSERT INTO `articles` VALUES (19, 'http://robin.com/storage/index/20231002/c7c31c5c0486a9760fce7974ae11250b.png', '# 设计模式--适配器模式 Adapter Pattern\n\n## 1.1 基本介绍\n\n(1)适配器模式将某个类的接口转换成为客户端期望的另一个接口表示,主要的目的是兼容性,让原本应接口不匹配不能一起工作的两个类可以协同工作。其别名为包装器(Wrapper).\n\n(2)适配器模式属于结构型模式\n\n(3)主要分为三类:类适配器模式、对象适配器模式、接口适配器模式\n\n\n\n## 1.2 工作原理\n\n1. 适配器模式:将一个类的接口转换成为另一种接口,让原本接口不兼容的类可以兼容。\n2. 从用户的角度看不到被适配者,是解耦的。\n3. 用户调用适配器转换出来的目标接口方法,适配器再调用被适配者的相关接口方法。\n4. 用户收到反馈结果,感觉只是和目标接口交互。\n\n\n\n# 类适配器模式\n\n例子:电脑的电源适配器将(家庭用电)电压220伏特转换为5伏特,然后给电脑供电。\n\n\n\n\n\n被适配者类:\n\n```java\npackage com.robin.adapter.classAdapter;\n\n// 被适配者类\npublic class Voltage220V {\n\n    public int outPut220V(){\n        int srcV = 220;\n        System.out.println(\"[初始-家庭家用电压]电源电压:\"+srcV+\"伏特\");\n        return srcV;\n    }\n}\n\n```\n\n适配接口:\n\n```java\npackage com.robin.adapter.classAdapter;\n\n// 适配接口\npublic interface ICpVoltage5V {\n\n    public int outPut();\n}\n\n```\n\n电脑类:\n\n```java\npackage com.robin.adapter.classAdapter;\n\npublic class Computer {\n\n    public void charge(ICpVoltage5V iCpVoltage5V){\n        int i = iCpVoltage5V.outPut();\n        if (i==5){\n            System.out.println(\"[电源适配器]电压为5伏特,可以开始充电使用了!\");\n        }else{\n            System.out.println(\"[电源适配器]电压不正常,请检查或者更换电源适配器\");\n        }\n    }\n}\n\n```\n\n适配器类:\n\n```java\npackage com.robin.adapter.classAdapter;\n\n// 适配器类\npublic class CpVoltageAdapter extends Voltage220V implements ICpVoltage5V{\n\n    @Override\n    public int outPut() {\n        // 因为是继承关系,所以调用其父类的 电源电压输出\n        int src = outPut220V();\n        // 对220V电压进行简单转换\n        int dest = src/44;\n        return dest;\n    }\n}\n\n```\n\n测试客户端类:\n\n```java\npackage com.robin.adapter.classAdapter;\n\npublic class Client {\n\n    public static void main(String[] args) {\n        Computer computer = new Computer();\n        // 通过传入其适配器类的对象来进行充电\n        computer.charge(new CpVoltageAdapter());\n        // [电源适配器]电压为5伏特,可以开始充电使用了!\n    }\n}\n\n```\n\n\n\n类适配器模式的优点和缺点:\n\n1. 缺点:Java是单继承,但再类适配器模式中,**适配器类需要继承被适配的类**,失去了灵活性。并且**被适配者类的方法都会在适配器类中暴露出来**,增加了使用的成本。\n2. 优点:因为适配器类继承了被适配者类,所以适配器类可以根据需求,灵活的重写被适配者类。\n\n\n\n# 对象适配器模式\n\n对象适配器模式针对上面的类适配器模式进行了一些修改,**通过合成复用来代替原本的继承关系**。\n\ntip:对象适配器模式是适配器模式中常用的一种。\n\n\n\n例子:还是上面的电脑电源的适配器问题,进行修改,将其改为对象适配器模式的。\n\n我们只需要将适配器类中取消继承被适配的类,然后在适配器类中提供一个被适配类的成员变量及构造器即可。\n\n![外链图片转存失败,建议将图片保存下来直接上传](https://img-home.csdnimg.cn/images/20230724024159.png"[初始-家庭家用电压]电源电压:\"+srcV+\"伏特\");\n        return srcV;\n    }\n}\n\n```\n\n\n\n适配接口:\n\n```java\npackage com.robin.adapter.objectAdapter;\n\n// 适配接口\npublic interface ICpVoltage5V {\n\n    public int outPut();\n}\n\n```\n\n\n\n电脑类:\n\n```java\npackage com.robin.adapter.objectAdapter;\n\n\npublic class Computer {\n\n    public void charge(ICpVoltage5V iCpVoltage5V){\n        int i = iCpVoltage5V.outPut();\n        if (i==5){\n            System.out.println(\"[电源适配器]电压为5伏特,可以开始充电使用了!\");\n        }else{\n            System.out.println(\"[电源适配器]电压不正常,请检查更换电源适配器\");\n        }\n    }\n}\n\n```\n\n\n\n适配器类:\n\n```java\npackage com.robin.adapter.objectAdapter;\n\n// 适配器类\npublic class CpVoltageAdapter implements ICpVoltage5V {\n\n    // 合成复用 将被适配类聚合到适配器类中\n    private Voltage220V  voltage220V = null;\n\n    // 提供被适配类的构造器\n    public CpVoltageAdapter(Voltage220V voltage220V) {\n        this.voltage220V = voltage220V;\n    }\n\n    // 重写适配接口中的方法\n    @Override\n    public int outPut() {\n        if (null != voltage220V){\n            int srcV = voltage220V.outPut220V();\n            int dstV = srcV/44;\n            System.out.println(\"电源电压适配完成,电源电压=\"+dstV);\n            return dstV;\n        }\n        return -1;\n    }\n}\n\n```\n\n\n\n客户端测试类:\n\n```java\npackage com.robin.adapter.objectAdapter;\n\npublic class Client {\n\n    public static void main(String[] args) {\n        System.out.println(\"对象适配器模式\");\n        Computer computer = new Computer();\n        computer.charge(new CpVoltageAdapter(new Voltage220V()));\n    }\n}\n\n```\n\n\n\n对象适配器模式与类适配器模式基本一致,只是通过合成复用代替继承,解决了类适配器产生的继承局限问题,使用成本更低更灵活。\n\n\n\n# 接口适配器模式\n\n接口适配器模式的思想:当不需要全部实现接口提供的方法时,可以先设计一个抽象类实现接口,并为该接口中的每个方法提供一个默认实现(空方法体),那么该抽象类的子类可以有选择的覆盖父类的某些方法来实现需求。\n\n接口适配器模式适用于不想使用一个适配接口中所有方法的情况,按照自己的需求来挑选合适的方法自行实现。\n\n\n\n比如,你要去旅游了,每个国家插座插孔和电压都不一样,你带了一个万能转换器(比如:wp-933)\n\n\n然后各国插座如下:\n\n\n\n\n暂且假定该万能转换插孔只提供一个空的插孔,需要你去自定义实现(我例子举得不是很好...有点牵强)\n\n\n\n万能插孔适配接口:\n\n```java\npackage com.robin.adapter.interfaceadpter;\n\n// 万能插孔适配接口\npublic interface AllJacks {\n\n    // 德国标准\n    public void germanJack();\n    // 欧洲标准\n    public void europeanJack();\n    // 中国,澳大利亚标准\n    public void chinaAndOzJack();\n    // 美国标准\n    public void usaJack();\n    //......\n}\n\n```\n\n万能插孔抽象类实现接口中的所有方法,提供空方法体:\n\n```java\npackage com.robin.adapter.interfaceadpter;\n\n// 抽象类实现万能适配接口,实现全部接口方法,提供空方法体\npublic abstract class AbsAllJacksAdapter implements AllJacks {\n\n    // 德国\n    @Override\n    public void germanJack() {\n\n    }\n\n    // 欧洲\n    @Override\n    public void europeanJack() {\n\n    }\n\n    // 中国和澳大利亚\n    @Override\n    public void chinaAndOzJack() {\n\n    }\n\n    // 美国\n    @Override\n    public void usaJack() {\n\n    }\n}\n\n```\n\n\n\n客户端测试:\n\n```java\npackage com.robin.adapter.interfaceadpter;\n\npublic class Client {\n\n    public static void main(String[] args) {\n        // 中国电脑插孔为三孔,方形\n        String srcJack = \"[三孔]三方形孔\";\n        // 假设我现在旅行去美国\n        AbsAllJacksAdapter absAllJacksAdapter = new AbsAllJacksAdapter(){\n            @Override\n            public void usaJack() {\n                System.out.println(\"=============使用万能转化器转换=============\");\n                // 美国电压为 100-130V,插孔为三孔,两方一圆\n                String destJack = \"[三孔]两方一圆孔\";\n                System.out.println(\"[插孔适配完毕]:\"+srcJack+\"==>\"+destJack);\n            }\n        };\n        absAllJacksAdapter.usaJack();\n    }\n}\n\n```\n\n\n\n\n# 小结\n\n适配器模式的三种方式,也其实就是被适配类,如何被适配器类获取使用的(类=>继承,对象=>合成复用,接口)。Adapter适配器模式的最大作用就是将原本不兼容的接口融合在一起工作。', '2023-10-02 04:46:21', 'csdn文章迁移测试', 1);
INSERT INTO `articles` VALUES (20, 'http://robin.com/storage/index/20231002/be4f646e1d23c6ec0f6645990807b747.jpg', '简单文本', '2023-10-02 19:08:54', '测试102', 1);
INSERT INTO `articles` VALUES (21, 'http://robin.com/storage/index/20231002/710e262c0f9264029bd65c19b38dea79.jpg', '# 《肖申克的救赎》\n\n1.生命可以归结为一种简单的选择:要么忙于生存,要么赶着去死。\n\n2.懦怯囚禁人的灵魂,希望可以感受自由。强者自救,圣者渡人。\n\n3.希望是件美丽的东西,也许是最好的东西。美好的东西是永远不会死的。\n\n4.每个人都是自己的上帝。如果你自己都放弃自己了,还有谁会救你?\n\n------------------------------------\n\n![外链图片转存失败, '2023-10-02 11:14:03', '随便测试', 1);
INSERT INTO `articles` VALUES (22, 14, '技术模块/web', 'http://robin.com/storage/index/20231003/8b2ef0b7d564915c9e14dd9653ef5490.jpg', '# 资源专栏遇到的一些问题\n\n首先,存储方面我还是先将其存到服务器的网页上面,然后再将返回的域名字符串保存到数据库中,然后既然要做资源专栏,那么就得区分不同的资源,这个时候就需要提出一个概念 mime.\n\n# MIME介绍\n>MIME类型(Multipurpose Internet Mail Extensions,多用途互联网邮件扩展类型)是一种用于标识和表示文档、文件或数据流的格式和类型的方式。以下是常见的一些MIME类型及其含义:\n\n1. text/plain:表示纯文本内容,没有任何格式化或样式信息。\n2. text/html:表示HTML文档。\n3. text/css:表示CSS样式表。\n4. application/json:表示JSON数据。\n5. application/pdf:表示PDF文档。\n6. image/jpeg:表示JPEG图像。\n7. image/png:表示PNG图像。\n8. audio/mpeg:表示MP3音频文件。\n9. video/mp4:表示MP4视频文件。\n\n这些MIME类型只是常见的一部分,实际上还有很多其他的MIME类型,用于表示各种不同类型的文档、文件和数据流。每个MIME类型都由两部分组成:主类型和子类型,它们之间用斜杠(/)分隔。**主类型表示文档、文件或数据流的大类别,而子类型表示该大类别下的具体子类型。**\n\n在Web开发和网络传输中,MIME类型通常用于指定HTTP请求和响应的Content-Type头部字段的值,以告诉浏览器或其他客户端如何解释和处理接收到的数据。', '2023-10-03 00:50:22', '常见的文章类型', 3, 1);
INSERT INTO `articles` VALUES (23, 'http://robin.com/storage/index/20231004/ddf4213a618f29f6d80e4e09e964b7d7.jpg', '# particles vue3\n[https://particles.js.org/](https://particles.js.org/)\n\n使用步骤:\n1. 安装 paricles\n\n```shell\nnpm install particles.vue3 --save\n```\n2. 安装 tsparticles-slim\n\n```shell\nnpm i tsparticles\n```\n3. 在main.js中导入并且挂载\n\n```shell\nimport Particles from \"particles.vue3\"; \napp.use(Particles)\napp.mount(\'#app\')\n```\n4. 在页面中使用\n\n```html\n<script setup>\nimport { ref } from \'vue\'\n\n// 粒子参数\nconst options =ref( {\n    background: {\n        color: {\n            value: \'#032224\'\n        }\n    },\n    // backgroundColor:\'#000000\',\n    fpsLimit: 120,\n    interactivity: {\n        events: {\n            onClick: {\n                enable: true,\n                mode: \'push\'\n            },\n            onHover: {\n                enable: true,\n                mode: \'grab\'\n            },\n            resize: true\n        },\n        modes: {\n            bubble: {\n                distance: 400,\n                duration: 2,\n                opacity: 0.8,\n                size: 40\n            },\n            push: {\n                quantity: 4\n            },\n            repulse: {\n                distance: 200,\n                duration: 0.4\n            }\n        }\n    },\n    particles: {\n        color: {\n            value: \'#ffffff\'\n        },\n        links: {\n            color: \'#ffffff\',\n            distance: 150,\n            enable: true,\n            opacity: 0.5,\n            width: 1\n        },\n        collisions: {\n            enable: true\n        },\n        move: {\n            direction: \'none\',\n            outModes: {\n                default: \'bounce\'\n            },\n            random: false,\n            speed: 4,\n            straight: false\n        },\n        number: {\n            density: {\n                enable: true,\n                area: 800\n            },\n            value: 80\n        },\n        opacity: {\n            value: 0.5\n        },\n        shape: {\n            type: \'circle\'\n        },\n        size: {\n            value: { min: 1,max: 5 },\n        }\n    },\n    detectRetina: true\n}\n)\n\nimport { loadSlim } from \"tsparticles-slim\"; \n\nconst particlesInit = async engine => {\n    //await loadFull(engine);\n    await loadSlim(engine);\n};\n\nconst particlesLoaded = async container => {\n    console.log(\"Particles container loaded\",container);\n}\n</script>\n\n<template>\n    <!-- 粒子特效插件n -->\n    <div class=\"wrapper\">\n        <vue-particles \n         id=\"tsparticles\" \n         :particlesInit=\"particlesInit\"\n         :particlesLoaded=\"particlesLoaded\" \n         :options=\"options\" />\n</template>\n\n<style>\n.wrapper {\n    height: 100vh;\n    min-width: 100vw;\n    /* background-image: linear-gradient(to bottom right,#fc466b,#3f5efb); */\n    overflow: hidden;\n}\n\n#tsparticles {\n    position: fixed;  \n    z-index: -1;\n \n}\n</style>\n```\n\n# 效果图\n![外链图片转存失败, '2023-10-04 03:53:23', 'vue3的粒子插件的使用', 17, 1);
INSERT INTO `articles` VALUES (24, 'http://robin.com/storage/index/20231004/be16c4572f21c6f5d2b9871d1eac6e2c.jpg', '![外链图片转存失败, '2023-10-04 12:45:49', '结束', 1);
INSERT INTO `articles` VALUES (25, 'http://robin.com/storage/index/20231007/5fbb4b9c01988d1b9b16195203181729.png', 'Go 面向对象\n\n# Go 面向对象\n\n \n\n## 1. struct 实体的抽象描述\n\n在Go语言中,使用struct来对现实世界实体进行描述。\n\nstruct的定义格式如下:\n\n```go\ntype 实体名 struct{\n    成员变量 数据类型\n    ...\n}\n```\n\n\n\n\n\n假设现在有一个people的结构体,我们接着对其声明创建一个结构体对象。\n\n```go\ntype people struct{\n    name string\n    age int\n}\n```\n\n\n\nstruct的使用,结构体对象的声明定义\n\n```go\np1 := people{name:\"张三\",age:17}\n// 或者\nvar p2 = people{name:\"李四\",age:19}\n```\n\n\n\n### 匿名字段和结构体嵌套\n\nGo语言中,在结构体(struct)中,实际上Go支持只提供类型,而不写字段名的方式,这便是匿名字段的定义。在结构体嵌套中经常使用。\n\n```go\ntype people struct{\n    name string\n    age int \n    pet\n}\n\ntype pet struct{\n    name string\n}\n```\n\n\n\n匿名字段可以实现面向对象中的字段继承,即成员变量的继承,在嵌套结构体中,访问嵌套结构体的成员字段就好比自己的成员字段一样。\n\n```go\npackage main\n\ntype People struct {\n	name string\n	age  int\n	Student\n}\n\ntype Student struct {\n	name string\n}\n\nfunc main() {\n	st1 := People{\"张三\",20,Student{\"李四\"}}\n	println(st1.name) // 张三\n	println(st1.Student.name)  //李四\n}\n\n```\n\n访问内嵌结构体,使用 `结构体.内嵌结构体.成员变量`,访问外部结构体,使用`结构体.成员变量`,Go语言中,最外层的结构体优先访问(就按照现实世界的思维逻辑理解即可)。Go语言允许去重载通过匿名字段继承的一些字段,当然如果我们想访问重载后对应匿名类型里面的字段,可以通过匿名字段名来访问。\n\n这里需要注意的是 结构体名定义的首字母是大写或者小写的不同,访问的对应权限不同。\n\n\n\n**Go**语言通过首字母的大小写来控制访问权限。 无论是方法,变量,常量或是自定义的变量类型,如果首字母大写,则可以被外部包访问,反之则不可以。 而结构体中的字段名,如果首字母小写的话,则该字段无法被外部包访问和解析\n\n## 2. method 方法\n\nGo语言中方法的定义很类似函数的定义格式。\n\n区别是一个方法就是一个包含了接受者的函数,接受者可以是命名类型或者结构体类型的一个值或者是一个指针。所有给定类型的方法属于该类型的方法集。\n\n\n\n对比一下:\n\n```go\n// 1. 函数的定义格式\nfunc function_name( [parameter list] ) [return_types] {\n   /* 函数体 */\n}\n\n// 2. 方法的定义格式\nfunc (variable_name variable_data_type) function_name() [return_type]{\n   /* 方法体 */\n}\n```\n\n就是方法只属于某一个结构体类型,不能被直接调用,而函数是任意类型都可以调用,只要传入对应的参数即可。\n\n如下面的例子:\n\n```go\ntype Circle struct {\n	r float32\n}\n\nfunc (c Circle) getArea() float32 {\n	return c.r * c.r * 3.14\n}\n\n\nfunc main() {\n	c1 := Circle{15}\n    area1 :=c1.getArea()\n    println(area1) //+7.065000e+002\n    // getArea()\n    // 直接调用,会出现无法调用,\n    // getArea(c1) ,尝试传入参数也无法调用\n}\n```\n\n', '2023-10-07 14:38:57', '测试120', 1);
INSERT INTO `articles` VALUES (26, 'http://robin.com/storage/index/20231011/1a0902835ae29e701cdbd74353cd042e.jpeg', '# ds dasd\n![外链图片转存失败, '2023-10-11 10:58:42', 'sddasd', 1);
INSERT INTO `articles` VALUES (27, 'http://robin.com/storage/index/20231030/26302bd3a8e6b3f591646faf8a2e2402.jpeg', '# sadsd assd\n\n## asdas \n![外链图片转存失败, '2023-10-30 10:13:03', 'cessss', 1);

-- ----------------------------
-- Table structure for comments
-- ----------------------------
DROP TABLE IF EXISTS `comments`;
CREATE TABLE `comments`  (
  `id` int(0) NOT NULL AUTO_INCREMENT COMMENT '评论id',
  `articleid` int(0) NOT NULL COMMENT '评论的文章id',
  `uid` int(0) NULL DEFAULT NULL COMMENT '评论人id',
  `commentator` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL COMMENT '评论人',
  `avatar` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL COMMENT '头像',
  `content` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL COMMENT '评论内容',
  `ctime` datetime(0) NOT NULL COMMENT '评论时间',
  `pid` int(0) NULL DEFAULT NULL COMMENT '依赖的父评论id',
  `isdelete` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT '0' COMMENT '是否被过滤或者删除',
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 43 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_0900_ai_ci ROW_FORMAT = Dynamic;

-- ----------------------------
-- Records of comments
-- ----------------------------
INSERT INTO `comments` VALUES (1, 6, 'chen', 'http://robin.com/storage/index/20230910/86952b7f57fb025d5502cc99e5e9fef9.jpeg', '我陈平安,唯有一剑,可搬山,倒海,降妖,镇魔,敕神,摘星,断江,摧城,开天!', '2023-09-09 15:35:22', '0');
INSERT INTO `comments` VALUES (2, '芜湖!!', '2023-09-09 15:35:49', '0');
INSERT INTO `comments` VALUES (3, '火力支持', '2023-09-10 19:15:43', '0');
INSERT INTO `comments` VALUES (4, '啦啦啦', '2023-09-10 20:36:30', '0');
INSERT INTO `comments` VALUES (5, '呃呃呃', '2023-09-09 20:39:27', '0');
INSERT INTO `comments` VALUES (6, '心情不错', '2023-09-11 08:44:51', '0');
INSERT INTO `comments` VALUES (7, 'robin,你在干嘛?', '2023-09-11 08:47:09', '0');
INSERT INTO `comments` VALUES (8, '我是水军内容!!!', '2023-09-11 08:48:50', '0');
INSERT INTO `comments` VALUES (9, '再水一条', '2023-09-11 08:51:56', '0');
INSERT INTO `comments` VALUES (10, '你不对劲!', '2023-09-11 08:53:49', '0');
INSERT INTO `comments` VALUES (11, '过分', '2023-09-11 08:54:17', 9, '0');
INSERT INTO `comments` VALUES (12, '呦呵,你小子也读剑来', '2023-09-11 08:54:59', '0');
INSERT INTO `comments` VALUES (13, 'cccc', '2023-09-11 18:50:57', '0');
INSERT INTO `comments` VALUES (14, 'asdasd', '2023-09-11 22:58:47', '0');
INSERT INTO `comments` VALUES (15, 'asda', '2023-09-11 22:59:06', '0');
INSERT INTO `comments` VALUES (16, '水内容', '2023-09-27 08:46:47', '0');
INSERT INTO `comments` VALUES (17, 'fasong', '2023-09-27 09:04:59', '0');
INSERT INTO `comments` VALUES (18, '2023-09-27 20:04:46', '0');
INSERT INTO `comments` VALUES (19, 'vue端测试评论1', '2023-09-28 21:33:40', '0');
INSERT INTO `comments` VALUES (20, '测试回显数据', '2023-09-28 21:36:27', '1');
INSERT INTO `comments` VALUES (21, '测试前端刷新数据', '2023-09-28 21:37:30', '0');
INSERT INTO `comments` VALUES (22, '嗨,月底咯!', '2023-09-28 21:38:20', '0');
INSERT INTO `comments` VALUES (23, '跨域测试', '2023-09-30 17:18:11', '0');
INSERT INTO `comments` VALUES (24, '跨域测试2', '2023-09-30 17:19:05', '0');
INSERT INTO `comments` VALUES (28, 'sad asd ', '2023-09-30 21:11:09', '0');
INSERT INTO `comments` VALUES (29, 15, 'asdasd as', '2023-09-30 21:11:17', '0');
INSERT INTO `comments` VALUES (30, '言论过滤测试', '2023-10-01 15:55:36', '1');
INSERT INTO `comments` VALUES (31, 'ok', '2023-10-01 22:50:51', '0');
INSERT INTO `comments` VALUES (32, '好耶,markdown文章上传测试成功', '2023-10-02 10:36:06', '0');
INSERT INTO `comments` VALUES (33, 'mardown不错', '2023-10-02 19:15:26', '0');
INSERT INTO `comments` VALUES (34, 'get', '2023-10-03 08:51:15', '0');
INSERT INTO `comments` VALUES (35, 23, '1', '2023-10-04 12:39:09', '0');
INSERT INTO `comments` VALUES (36, 'https://www.npmjs.com/package/particles.vue3 粒子插件地址', '2023-10-04 20:13:37', '0');
INSERT INTO `comments` VALUES (37, 21, '喜欢看看啥电影?', '2023-10-04 20:33:55', '0');
INSERT INTO `comments` VALUES (38, '嘿!', '2023-10-04 20:44:44', '0');
INSERT INTO `comments` VALUES (39, 19, 'ku', '2023-10-09 13:02:19', '0');
INSERT INTO `comments` VALUES (40, 'c', '2023-10-11 19:02:23', '0');
INSERT INTO `comments` VALUES (41, 18, '写的不错啊,自吹自擂', '2023-10-17 09:39:56', '0');
INSERT INTO `comments` VALUES (42, '0ok', '2023-10-21 17:25:56', '0');
INSERT INTO `comments` VALUES (43, 'zxczxc', '2023-10-30 18:14:34', '0');

-- ----------------------------
-- Table structure for likes
-- ----------------------------
DROP TABLE IF EXISTS `likes`;
CREATE TABLE `likes`  (
  `articleid` int(0) NOT NULL COMMENT '文章id',
  `likeuid` int(0) NOT NULL COMMENT '点赞的用户id',
  PRIMARY KEY (`articleid`, `likeuid`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_0900_ai_ci ROW_FORMAT = Dynamic;

-- ----------------------------
-- Records of likes
-- ----------------------------
INSERT INTO `likes` VALUES (1, 11);
INSERT INTO `likes` VALUES (2, 2);
INSERT INTO `likes` VALUES (2, 11);
INSERT INTO `likes` VALUES (3, 2);
INSERT INTO `likes` VALUES (11, 2);
INSERT INTO `likes` VALUES (17, 11);

-- ----------------------------
-- Table structure for modules
-- ----------------------------
DROP TABLE IF EXISTS `modules`;
CREATE TABLE `modules`  (
  `id` int(0) NOT NULL AUTO_INCREMENT COMMENT '模块主键',
  `name` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL COMMENT '模块名称',
  `describe` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL COMMENT '模块描述',
  `iconurl` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL COMMENT '模块的icon图标',
  `pid` int(0) NOT NULL COMMENT '模块依赖的父id',
  `pcicon` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL COMMENT 'pc端的模块图标',
  `isdelete` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT '0' COMMENT '是否被删除',
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 14 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_0900_ai_ci ROW_FORMAT = Dynamic;

-- ----------------------------
-- Records of modules
-- ----------------------------
INSERT INTO `modules` VALUES (1, '日常模块', NULL, '0');
INSERT INTO `modules` VALUES (2, '技术模块', '0');
INSERT INTO `modules` VALUES (3, '社区模块', '0');
INSERT INTO `modules` VALUES (4, '聊天灌水', 'duihuazixun', '', '0');
INSERT INTO `modules` VALUES (5, '天道酬勤', 'a-263', '0');
INSERT INTO `modules` VALUES (6, '吃喝玩乐', '日常模块/吃喝玩乐', 'chihewanle', '0');
INSERT INTO `modules` VALUES (7, '刹那感悟', '日常模块/刹那感悟', 'kuaileshiguang', 'el-gw', '0');
INSERT INTO `modules` VALUES (8, 'JAVA技术', 'java', '0');
INSERT INTO `modules` VALUES (9, '公告模块', '社区模块/公告模块', 'el-msg', '0');
INSERT INTO `modules` VALUES (10, 'vue技术2', 'el-vue2', '0');
INSERT INTO `modules` VALUES (11, '微信小程序', 'el-wx', '0');
INSERT INTO `modules` VALUES (12, 'php', 'el-php', '0');
INSERT INTO `modules` VALUES (13, 'C#', '技术模块/C#', 'el-c#', '1');
INSERT INTO `modules` VALUES (14, 'web', 'el-web', '0');

-- ----------------------------
-- Table structure for resource
-- ----------------------------
DROP TABLE IF EXISTS `resource`;
CREATE TABLE `resource`  (
  `id` int(0) NOT NULL AUTO_INCREMENT COMMENT '资源主键自增',
  `publisherid` int(0) NOT NULL COMMENT '发布人id主键',
  `filesurl` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL COMMENT '文件的url地址',
  `filetype` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL COMMENT '资源类型',
  `status` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT '0' COMMENT '资源状态 0 ,1, 2',
  `filename` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL COMMENT '资源名称',
  `ctime` datetime(0) NOT NULL COMMENT '发布时间',
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 24 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_0900_ai_ci ROW_FORMAT = Dynamic;

-- ----------------------------
-- Records of resource
-- ----------------------------
INSERT INTO `resource` VALUES (1, 'http://robin.com/storage/index/20231003/24f7aca5dfcdd50c8cd5afe2c54bb4fc.txt', 'text/plain', 'C#,winform,listView动态插入数据.txt', '2023-10-02 09:10:07');
INSERT INTO `resource` VALUES (2, 'http://robin.com/storage/index/20231003/eb72a0a7dde40507af819d3116480a32.pdf', 'application/pdf', '0', '15030123-0001568070-d9e7b5.pdf', '2023-10-03 09:21:14');
INSERT INTO `resource` VALUES (3, 'http://robin.com/storage/index/20231003/4ed242ce77a20cde2800c8a8941bb38a.xlsx', 'application/octet-stream', '-1', 'export.xlsx', '2023-10-03 09:26:21');
INSERT INTO `resource` VALUES (4, 'http://robin.com/storage/index/20231003/e8eb8277bbb7d205011f5f327ad5a0d3.md', 'text/html', 'vue模板语法.md', '2023-10-03 09:42:28');
INSERT INTO `resource` VALUES (5, 'http://robin.com/storage/index/20231003/99a91ea23e452d69171a351c1c39e625.md', 'layui 的 使用.md', '2023-10-03 09:44:35');
INSERT INTO `resource` VALUES (6, 'http://robin.com/storage/index/20231003/47332810e14d616ed0fd5f242ab8ee3a.mp4', 'video/mp4', '小红书.mp4', '2023-10-03 10:26:49');
INSERT INTO `resource` VALUES (7, 'http://robin.com/storage/index/20231003/06bb31077573f6d118c62c113e8cd870.jpg', 'image/jpeg', 'mrxtt.jpg', '2023-10-03 10:29:01');
INSERT INTO `resource` VALUES (8, 'http://robin.com/storage/index/20231003/9edeacc218c2fc6cd1f3825bfee3fac1.pdf', 'spring-boot中文文档.pdf', '2023-10-03 10:58:42');
INSERT INTO `resource` VALUES (9, 'http://robin.com/storage/index/20231003/27271d3552f40d502c54c8914849bdf6.pptx', 'application/vnd.openxmlformats-officedocument.presentationml.presentation', '课件(动效演示).pptx', '2023-10-03 12:23:31');
INSERT INTO `resource` VALUES (10, 'http://robin.com/storage/index/20231003/3c3c2f4e3f02de20cf13d53f837b6de0.docx', 'application/vnd.openxmlformats-officedocument.wordprocessingml.document', '参考文献.docx', '2023-10-03 12:27:17');
INSERT INTO `resource` VALUES (11, 'http://robin.com/storage/index/20231003/e60bf589975118dfd3af8c38563a894f.xlsx', 'export (2).xlsx', '2023-10-03 12:29:46');
INSERT INTO `resource` VALUES (12, 'http://robin.com/storage/index/20231003/04811a2e6d45a383ab6fdbf31d90a307.zip', 'application/zip', 'vue-element-admin-master.zip', '2023-10-03 12:31:03');
INSERT INTO `resource` VALUES (13, 'http://robin.com/storage/index/20231003/4b63d53cb3f9afbbc9ebe0596d2e40f1.c', 'text/x-c', '01线性表顺序存储_List.c', '2023-10-03 12:31:49');
INSERT INTO `resource` VALUES (14, 'http://robin.com/storage/index/20231003/a7a77bb1bd339be9e4a0a3d16886bea8.php', '1.php', '2023-10-03 12:32:16');
INSERT INTO `resource` VALUES (15, 'http://robin.com/storage/index/20231003/57bf670ebe7d001711d65b32c0542b26.java', 'text/x-c++', 'ok.java', '2023-10-03 12:33:42');
INSERT INTO `resource` VALUES (16, 'http://robin.com/storage/index/20231003/8f4c44174a546a0ee71338bb9f626143.cs', 'application/x-empty', 'ok2.cs', '2023-10-03 12:34:55');
INSERT INTO `resource` VALUES (17, 'http://robin.com/storage/index/20231003/2a3f051cd7476e45bbc7ca3dff700a25.mp4', '小红书短视频.mp4', '2023-10-03 12:43:57');
INSERT INTO `resource` VALUES (18, 'http://robin.com/storage/index/20231004/5e09a6e33abbd8cae14e1fc11aaeee59.rar', 'application/x-rar', 'ListView图片.rar', '2023-10-04 20:36:37');
INSERT INTO `resource` VALUES (19, 'http://robin.com/storage/index/20231004/9b4d917fba1656ad3b62514960e8033f.jpeg', 'image/webp', 'a11.jpeg', '2023-10-04 20:56:40');
INSERT INTO `resource` VALUES (20, 'http://robin.com/storage/index/20231005/beb1b51d52f11ce16ad674040c43e9c6.zip', '2020040413 张慧.zip', '2023-10-05 22:39:57');
INSERT INTO `resource` VALUES (21, 'http://robin.com/storage/index/20231009/8ae6a23231d56bc33d9486529a5fe76f.xml', 'text/xml', 'pom.xml', '2023-10-09 12:42:24');
INSERT INTO `resource` VALUES (22, 'http://robin.com/storage/index/20231009/757ee7d40ca035fb7199fd868e28d25d.zip', '游戏平台1.0.zip', '2023-10-09 12:44:05');
INSERT INTO `resource` VALUES (23, 'http://robin.com/storage/index/20231009/1250f5c6bc0c9e5986d6b76e67238e76.cs', 'LoginFrm.cs', '2023-10-09 12:44:25');
INSERT INTO `resource` VALUES (24, 'http://robin.com/storage/index/20231030/7165e2809dd31dbdf37683dcd6026aaa.jpg', 'loop2.jpg', '2023-10-30 18:15:54');

-- ----------------------------
-- Table structure for signs
-- ----------------------------
DROP TABLE IF EXISTS `signs`;
CREATE TABLE `signs`  (
  `id` int(0) NOT NULL AUTO_INCREMENT COMMENT '签名id',
  `content` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL COMMENT '签名内容',
  `updtime` timestamp(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) COMMENT '发表签名时间',
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 22 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_0900_ai_ci ROW_FORMAT = Dynamic;

-- ----------------------------
-- Records of signs
-- ----------------------------
INSERT INTO `signs` VALUES (1, '少年的肩膀,就该这样才对嘛,什么家国仇恨,浩然正气的,都不要急,先挑起清风明月、杨柳依依和草长莺飞,少年郎的肩头,本就应当满是美好的事物啊。', '2023-09-01 11:24:56', 2);
INSERT INTO `signs` VALUES (2, '君子坐而论道,少年起而行之。', '2023-09-01 11:25:35', 2);
INSERT INTO `signs` VALUES (3, '总有些人,一眼看到就会心生好感,道理都讲不通。', '2023-09-01 11:27:33', 2);
INSERT INTO `signs` VALUES (4, '这人间不来也罢', '2023-09-01 11:31:25', 2);
INSERT INTO `signs` VALUES (5, '测试数据', '2023-09-08 08:20:06', 2);
INSERT INTO `signs` VALUES (6, '测试数据2', '2023-09-08 08:24:17', 2);
INSERT INTO `signs` VALUES (7, '2023-09-08 08:26:33', 2);
INSERT INTO `signs` VALUES (8, '心中有剑 何处不是倒悬山。', '2023-09-08 08:41:23', 2);
INSERT INTO `signs` VALUES (9, '有些人心如花木,皆向阳而生', '2023-09-08 12:40:31', 2);
INSERT INTO `signs` VALUES (10, '2023-09-08 12:41:28', 11);
INSERT INTO `signs` VALUES (11, '今天心情不错', '2023-09-10 15:58:25', 10);
INSERT INTO `signs` VALUES (12, '世间唯有痴情,不许他人痴笑', '2023-09-11 10:53:07', 2);
INSERT INTO `signs` VALUES (13, '这个世界没你想的那么坏 但也没你想的那么好', '2023-09-11 18:50:08', 2);
INSERT INTO `signs` VALUES (14, '中秋明月,豪门有,贫家也有。 \n\n极慰人心。\n\n——烽火戏诸侯《剑来》', '2023-10-01 19:49:08', 2);
INSERT INTO `signs` VALUES (15, '有心为善虽善不赏,无心为恶虽恶不罚。人力有穷尽之时,尽力又尽心了,就不用太愧疚', '2023-10-01 19:58:59', 2);
INSERT INTO `signs` VALUES (16, '有庙无僧风扫地,有香无火月点灯。', '2023-10-01 20:03:35', 2);
INSERT INTO `signs` VALUES (17, '2023-10-01 22:51:23', 11);
INSERT INTO `signs` VALUES (18, '(¬︿̫̿¬☆)', '2023-10-02 12:13:52', 11);
INSERT INTO `signs` VALUES (19, 'ery', '2023-10-02 19:44:48', 18);
INSERT INTO `signs` VALUES (20, '嘿嘿完事!', '2023-10-04 20:32:50', 2);
INSERT INTO `signs` VALUES (21, '╰(*°▽°*)╯', '2023-10-09 11:08:03', 2);
INSERT INTO `signs` VALUES (22, 'czxczxc', '2023-10-30 18:16:43', 2);

-- ----------------------------
-- Table structure for user
-- ----------------------------
DROP TABLE IF EXISTS `user`;
CREATE TABLE `user`  (
  `id` int(0) NOT NULL AUTO_INCREMENT COMMENT '用户id',
  `username` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL COMMENT '用户名',
  `password` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL COMMENT '密码',
  `phone` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL COMMENT '手机号',
  `email` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL COMMENT '邮箱',
  `ctime` timestamp(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) COMMENT '注册时间',
  `avatar` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL COMMENT '头像url',
  `gender` enum('男','女','无') CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT '无' COMMENT '性别',
  `sign` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL COMMENT '用户个人签名',
  `status` enum('正常','注销','封停') CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL DEFAULT '正常' COMMENT '用户状态',
  `role` enum('管理员','普通用户') CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL DEFAULT '普通用户' COMMENT '用户角色',
  `location` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL COMMENT '地址',
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 19 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_0900_ai_ci ROW_FORMAT = Dynamic;

-- ----------------------------
-- Records of user
-- ----------------------------
INSERT INTO `user` VALUES (1, 'admin', '21232f297a57a5a743894a0e4a801fc3', '19024586372', 'ddd@126.com', '2023-09-01 11:22:46', 'http://robin.com/storage/index/20231004/6c9365149f47594addfcf3f973fa88fd.jpeg', '男', '正常', '管理员', '内蒙古科技大学包头医学院');
INSERT INTO `user` VALUES (2, '8ee60a2e00c90d7e00d5069188dc115b', '15024779820', 'robinDebug@163.com', '2023-09-01 11:23:14', '普通用户', '大理龙泉县');
INSERT INTO `user` VALUES (3, 'bird', 'abaecf8ca3f98dc13eeecbac263cd3ed', '2023-09-01 11:54:46', 'http://robin.com/storage/index/20230907/736efbbbdecfc2317c9b03b161c83590.jpg', '无', NULL);
INSERT INTO `user` VALUES (7, '裴钱', 'e10adc3949ba59abbe56e057f20f883e', '2023-09-07 15:46:35', 'http://robin.com/storage/index/20231004/17c1ea57783114cba2b2793704df01e5.jpeg', NULL);
INSERT INTO `user` VALUES (8, 'cui', '2023-09-07 15:54:09', NULL);
INSERT INTO `user` VALUES (9, '张三丰', '2023-09-07 16:11:06', NULL);
INSERT INTO `user` VALUES (10, '9df62e693988eb4e1e1444ece0578579', '2023-09-07 16:17:33', NULL);
INSERT INTO `user` VALUES (11, '77963b7a931377ad4ab5ad6a9cd718aa', '8762123', 'cui@123.com', '2023-09-07 16:18:07', '大理龙泉县');
INSERT INTO `user` VALUES (12, 'yao', '9852f6575c282db621d991fd9ced3cc1', '2023-09-08 06:55:52', '注销', NULL);
INSERT INTO `user` VALUES (13, 'solo', '2023-10-01 09:37:47', NULL);
INSERT INTO `user` VALUES (14, 'scum', '2023-10-01 09:44:41', NULL);
INSERT INTO `user` VALUES (15, 'cat3', '9b9423f286ce21b709cf1f69dc48c4a4', '2023-10-01 10:01:45', NULL);
INSERT INTO `user` VALUES (16, 'demo101', '60249d326473cf41eb665f9ea05003e6', '2023-10-01 10:03:10', NULL);
INSERT INTO `user` VALUES (17, 'demo102', 'bd14a323cd40b0338c2d85a1b1d13128', '2023-10-01 10:06:16', NULL);
INSERT INTO `user` VALUES (18, '8febfb31e5bcc247ce8d0ede460d2ca3', '2023-10-02 19:44:38', NULL);
INSERT INTO `user` VALUES (19, '陈平安', '2023-10-04 20:22:08', NULL);

SET FOREIGN_KEY_CHECKS = 1;

六、小皮服务配置

在这里插入图片描述

目前只使用了 robin.com,这个域名映射的是index模块,robinadmin.com原本想着用管理端,后面写着忘了就都写一块了。


原文地址:https://blog.csdn.net/m0_63622279/article/details/134591982

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


文章浏览阅读8.4k次,点赞8次,收藏7次。SourceCodester Online Tours & Travels Management System pay.php sql injectionLine 16 of pay.php invokes a SQL query built using unvalidated input. This call could allow an attacker to modify the statement’s meaning or to execute arbitrary SQL commands.SQL
文章浏览阅读3.4k次,点赞46次,收藏51次。本文为大家介绍在windwos系统搭建typecho博客+cpolar内网穿透工具将博客发布到公共网络环境,实现远程也可以访问和操作。_windows搭建typecho
文章浏览阅读1.1k次。- php是最优秀, 最原生的模板语言, 替代语法,让php更加的优雅的与html生活在一起 -->请放心, 最终生成的,或者说用户最终看到的,仍然是一个html文档, php代码中的内容不会被泄漏的。-- 将php与html代码混编的时候,大括号很容易造成配对错误,最好杜绝它 -->php标签内部代码由php.exe解释, php标签之外的代码原样输出,仍由web服务器解析。-- 所以php的流程控制语句, 都提供了替代语法,用冒号代替大括号 -->php echo '百变鹏仔'?_利用php将静态页面修改为动态页面
文章浏览阅读1.1k次,点赞18次,收藏15次。整理K8s网络相关笔记博文内容涉及 Linux network namespace 认知以及彼此通信Demo,实际中的应用理解不足小伙伴帮忙指正不必太纠结于当下,也不必太忧虑未来,当你经历过一些事情的时候,眼前的风景已经和从前不一样了。——村上春树。_linux network namespace 多端通信 模式认知
文章浏览阅读1.2k次,点赞22次,收藏19次。此网络模型提供了一个逻辑二层(L2)网络,该网络封装在跨 Kubernetes 集群节点的现有三层(L3)网络拓扑上。使用此模型,可以为容器提供一个隔离的 L2 网络,而无需分发路由。封装网络带来了少量的处理开销以及由于覆盖封装生成 IP header 造成的 IP 包大小增加。封装信息由 Kubernetes worker 之间的 UDP 端口分发,交换如何访问 MAC 地址的网络控制平面信息。此类网络模型中常用的封装是 VXLAN、Internet 协议安全性 (IPSec) 和 IP-in-IP。_k8s网络组件对比
文章浏览阅读1.1k次,点赞14次,收藏19次。当我们谈论网络安全时,我们正在讨论的是保护我们的在线空间,这是我们所有人的共享责任。网络安全涉及保护我们的信息,防止被未经授权的人访问、披露、破坏或修改。
文章浏览阅读1.3w次,点赞3次,收藏7次。尽管您可以通过 ping 命令解析出网站的 IP 地址,但是可能在浏览器中访问时仍然遇到问题,这可能是因为浏览器使用的 DNS 解析结果不同于 ping 命令使用的解析结果。可能是因为您的网络或设备上设置了防火墙,阻止了对特定网站的访问。有些国家或组织可能会对特定的域名进行屏蔽,从而阻止访问相关网站。如果您的网络使用代理服务器进行访问控制,可能会由于代理服务器的配置问题导致无法访问某些网站。即使您的网络和设备一切正常,目标网站本身可能也存在问题,例如服务器故障、维护或过载,导致无法访问。_能ping通打不开网页
文章浏览阅读839次,点赞22次,收藏19次。本系统带文档lw万字以上文末可领取本课题的JAVA源码参考。
文章浏览阅读2.1k次,点赞31次,收藏22次。基于微信小程序奶茶点餐外卖系统设计与实现(PHP后台+Mysql)可行性分析毕设源代码毕业设计,数据安全和系统稳定性以及团队能力和资源配备方面都具备较好的条件。因此,该项目的可行性较高。:黄菊华老师《Vue.js入门与商城开发实战》《微信小程序商城开发》图书作者,CSDN博客专家,在线教育专家,CSDN钻石讲师;微信小程序作为一种快捷、方便的移动应用形式,成为很多用户点餐外卖的首选。项目的界面和功能都可以定制,包安装运行!项目配有对应开发文档、开题报告、任务书、PPT、论文模版等。
文章浏览阅读1.8k次,点赞52次,收藏38次。本文主要通过对系统的前台系统和后台管理系统进行了功能性需求分析,对系统的安全性和可扩展性进行了非功能性需求分析。在详细的需求分析的基础上,根据系统的功能设计确定了数据库结构,实现完整的代码编写。Lucky+Baby母婴用品网站使用 Dreamweaver、HBuilder代码编辑器、Apache服务器等开发工具,完成了系统的主要模块的页面设计和功能实现。本文展示了首页页面的实现效果图,并通过代码和页面介绍了用户注册功能、商品搜索功能、生成订单和查看我的订单功能、在线付款功能功能的实现过程。
文章浏览阅读1.5k次,点赞45次,收藏40次。本设计主要实现集人性化、高效率、便捷等优点于一身的人事信息管理系统,完成首页、系统用户、通知公告、部门信息、员工薪资、考勤签到、员工请假、招聘信息、应聘信息等功能模块。
文章浏览阅读1k次。该错误通常出现在数据库读取结果集数据时,比如当我们写好SQL语句从数据库读取数据时,本身应该返回结果集,再给结果集中读取数据。解决思路:这种错误一般是因为echo后面输出了一个数组导致的,或者是数组作为字符串进行拼接运算时导致的。该错误直译为:警告:mysqli_fetch_assoc函数期望参数1是mysqli的结果集,但是给了一个布尔值。这种错误是PHP解析器在解析时遇到了语法错误,直译为:解析错误:语法错误,意料之外的...该错误直译为:提示:未定义的索引:username。_array to string conversion in
文章浏览阅读2.7w次。解决http请求报错context deadline exceeded (Client.Timeout exceeded while awaiting headers)_context deadline exceeded (client.timeout exceeded while awaiting headers)
文章浏览阅读1.3k次,点赞26次,收藏24次。复杂网络是一种由大量相互连接的元素(节点或顶点)组成的网络结构,这些连接通常是非常复杂和动态的。这些网络可以在各种领域中发现,包括社交网络、生物学系统、信息技术和交通系统等。_代理建模
文章浏览阅读2.6k次,点赞76次,收藏71次。epoll详解,事件模型,ET/LT模式,并通过三个示例进行代码实现。
文章浏览阅读3.3k次。罗拉ROLA-IP是一家来自纽约的代理IP提供商,由李嘉诚先生投资建设,韩国人工智能、自动驾驶、虚拟现实方面的领军企业World IT Show投资入股,由美国纽约大学IT管理教授团队研究开发,进入中国市场6年多,全世界设有多个分子公司。接下来,我们要检查代理和防火墙的设置,因为在绝大多数情况下,它们是导致这个错误的原因,尤其是当用户使用免费代理时。对网站的访问受阻实际上是一个非常常见的错误,它既可能是由于物理原因(硬件问题)造成的,也可能是由于软件错误引起的。检查代理设置,并确保其正确配置。_无法访问此网站,检查代理服务器和防火墙
文章浏览阅读1.1k次,点赞14次,收藏20次。本系统带文档lw万字以上文末可领取本课题的JAVA源码参考。_php洗车服务预约管理系统php源码
文章浏览阅读1.1k次。桶排序是计数排序的升级版。它利用了函数的映射关系,高效与否的关键就在于这个映射函数的确定。同时,对于桶中元素的排序,选择何种比较排序算法对于性能的影响至关重要。
文章浏览阅读936次,点赞22次,收藏17次。本系统带文档lw万字以上文末可领取本课题的JAVA源码参考。
文章浏览阅读822次,点赞15次,收藏14次。在整个设计过程中,要确定可能的具体解决方案,以实现每一个小的最终目标,对于每一个小目标,我们首先必须了解一些相关的需求分析信息。除了以上作品下面是2023-2024年最新100套计算机专业原创的毕业设计源码+数据库,是近期作品,如果你的题目刚好在下面可以文末领取java源码参考。springboot基于springboot的在线考试系统。springboot基于springboot的商城购物系统。springboot基于微信小程序的智慧校园设计与实现。springboot基于用户的协同过滤算法的话题推荐。