Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/lazyskills/lin-cms-tp6

基于ThinkPHP 6.0 的 Lin CMS 后端实现
https://github.com/lazyskills/lin-cms-tp6

annotation-tool lin-cms php71 thinkphp6

Last synced: 3 months ago
JSON representation

基于ThinkPHP 6.0 的 Lin CMS 后端实现

Awesome Lists containing this project

README

        






Lin-CMS-TP6


php version
ThinkPHP version
LISENCE

# 简介

## 预防针

* 本项目非官方团队出品,仅出于学习、研究目的丰富下官方项目的语言支持。
* 本项目采取后跟进官方团队功能的形式,即官方团队出什么功能,这边就跟进开发什么功能,开发者不必前端担心适配问题。
* 在上一点的基础上,我们会尝试加入一些自己的想法并实现。
* 局限于本人水平,有些地方还需重构,已经纳入了计划中,当然也会有我没考虑到的,希望有更多人参与进来一起完善,毕竟PHP作为世界上最好的语言不能缺席。

## 线上文档地址(完善中...)

文档:[LazySkills/Lin-Cms-Tp6](https://lazyskills.github.io/views/php/lin-cms-tp6/)

## 线上 Demo

可直接参考官方团队的线上Demo:[http://face.cms.7yue.pro/](http://face.cms.7yue.pro/),用户名:super,密码:123456

## 什么是 Lin CMS?

> Lin-CMS 是林间有风团队经过大量项目实践所提炼出的一套**内容管理系统框架**。Lin-CMS 可以有效的帮助开发者提高 CMS 的开发效率。

本项目是基于ThinkPHP 6.0的 Lin CMS 后端实现。

官方团队产品了解请访问[TaleLin](https://github.com/TaleLin)

## Lin CMS 的特点

Lin CMS 的构筑思想是有其自身特点的。下面我们阐述一些 Lin 的主要特点。

**Lin CMS 是一个前后端分离的 CMS 解决方案**

这意味着,Lin 既提供后台的支撑,也有一套对应的前端系统,当然双端分离的好处不仅仅在于此,我们会在后续提供NodeJS和PHP版本的 Lin。如果你心仪 Lin,却又因为技术栈的原因无法即可使用,没关系,我们会在后续提供更多的语言版本。为什么 Lin 要选择前后端分离的单页面架构呢?

首先,传统的网站开发更多的是采用服务端渲染的方式,需用使用一种模板语言在服务端完成页面渲染:比如 JinJa2、Jade 等。 服务端渲染的好处在于可以比较好的支持 SEO,但作为内部使用的 CMS 管理系统,SEO 并不重要。

但一个不可忽视的事实是,服务器渲染的页面到底是由前端开发者来完成,还是由服务器开发者来完成?其实都不太合适。现在已经没有多少前端开发者是了解这些服务端模板语言的,而服务器开发者本身是不太擅长开发页面的。那还是分开吧,前端用最熟悉的 Vue 写 JS 和 CSS,而服务器只关注自己的 API 即可。
·
其次,单页面应用程序的体验本身就要好于传统网站。

更多关于Lin CMS的介绍请访问[Lin CMS线上文档](http://doc.cms.7yue.pro/)

**框架本身已内置了 CMS 常用的功能**

Lin 已经内置了 CMS 中最为常见的需求:用户管理、权限管理、日志系统等。开发者只需要集中精力开发自己的 CMS 业务即可

## Lin CMS TP6 的特点

在当前项目的版本`(0.0.1)`中,特点更多来自于`ThinkPHP 6.0`框架本身带来的特点。通过充分利用框架的特性,实现高效的后端使用、开发,也就是说,只要你熟悉`ThinkPHP`框架,那么对于理解使用和二次开发本项目是没有难度的,即便对于框架的某些功能存在疑问也完全可以通过ThinkPHP官方的开发手册找到答案。当然我们更欢迎你通过[Issues](https://lazyskills.github.io/views/php/lin-cms-tp6/)来向我们提问:)

在下一个版本中`(>0.0.1)`,我们会在框架的基础上融入一些自己的东西来增强或者优化框架的使用、开发体验。

## 所需基础

由于 Lin 采用的是前后端分离的架构,所以你至少需要熟悉 PHP 和 Vue。

Lin 的服务端框架是基于 ThinkPHP6.0的,所以如果你比较熟悉ThinkPHP的开发模式,那将可以更好的使用本项目。但如果你并不熟悉ThinkPHP,我们认为也没有太大的关系,因为框架本身已经提供了一套完整的开发机制,你只需要在框架下用 PHP 来编写自己的业务代码即可。照葫芦画瓢应该就是这种感觉。

但前端不同,前端还是需要开发者比较熟悉 Vue 的。但我想以 Vue 在国内的普及程度,绝大多数的开发者是没有问题的。这也正是我们选择 Vue 作为前端框架的原因。如果你喜欢 React Or Angular,那么加入我们,为 Lin 开发一个对应的版本吧。

# 快速开始

## Server 端必备环境

* 安装MySQL(version: 5.6+)

* 安装PHP环境(version: 7.1+)

## 获取工程项目

```bash
git clone https://github.com/LazySkills/lin-cms-tp6.git
```

> 执行完毕后会生成lin-cms-tp6目录

## 安装依赖包

执行命令前请确保你已经安装了composer工具

```bash
# 进入项目根目录
cd lin-cms-tp6
# 先执行以下命令,全局替换composer源,解决墙的问题
composer config -g repo.packagist composer https://mirrors.aliyun.com/composer/
# 接着执行以下命令安装依赖包
composer install
```

## 数据库配置

Lin 需要你自己在 MySQL 中新建一个数据库,名字由你自己决定。例如,新建一个名为 lin-cms 的数据库。接着,我们需要在工程中进行一项简单的配置。使用编辑器打开 Lin 工程根目录下``/config/database.php``,找到如下配置项:

```php
// 服务器地址
'hostname' => '',
// 数据库名
'database' => 'lin-cms',
// 用户名
'username' => 'root',
// 密码
'password' => '',

//省略后面一堆的配置项
```

**请务必根据自己的实际情况修改此配置项**

## 数据迁移

> 如果你已经部署过官方团队其他版本的Lin-cms后端,并且已经生成了相应基础数据库表,可以略过数据迁移章节,但必须将原来lin_user表中super记录删除(密码加密方式不一致,会导致登陆失败),并在根目录下运行`php think seed:run` ,这条命令会为你在lin_user表中插入一条记录,即super,如果你并没有部署过其他版本的LinCMS后端,请继续阅读后面的内容

配置完数据库连接信息后,我们需要为数据库导入一些核心的基础表,在项目根目录中,打开命令行,输入:

```bash
php think migrate:run
```

当你看到如下提示时,说明迁移脚本已经启动并在数据库中生成了相应的基础数据库表

```php
== 20190427113042 User: migrating
== 20190427113042 User: migrated 0.0540s

== 20190427125215 Book: migrating
== 20190427125215 Book: migrated 0.0593s

== 20190427125655 LinAuth: migrating
== 20190427125655 LinAuth: migrated 0.0721s

== 20190427125839 LinEvent: migrating
== 20190427125839 LinEvent: migrated 0.0648s

== 20190427125956 LinGroup: migrating
== 20190427125956 LinGroup: migrated 0.0656s

== 20190427130203 LinLog: migrating
== 20190427130203 LinLog: migrated 0.0558s

== 20190427130637 LinPoem: migrating
== 20190427130637 LinPoem: migrated 0.0879s

All Done. Took 0.6255s
```

迁移成功后我们需要为lin_user表插入一条数据,作为超级管理员,方便你后续在前端项目中登陆和测试,继续在命令行中输入:

```bash
php think seed:run
```

当你看到如下提示时,说明迁移脚本已经启动并在lin_user表中创建了一条记录

```php
== UserSeeder: seeding
== UserSeeder: seeded 0.0351s

All Done. Took 0.0385s
```

## 运行

如果前面的过程一切顺利,项目所需的准备工作就已经全部完成,这时候你就可以试着让工程运行起来了。在工程的根目录打开命令行,输入:

```bash
php think run --port 5000 //启动thinkPHP内置的Web服务器
```

启动成功后会看到如下提示:

```php
ThinkPHP Development server is started On
You can exit with `CTRL-C`
```

打开浏览器,访问``http://127.0.0.1:5000``,你会看到一个欢迎界面,至此,Lin-cms-tp6部署完毕,可搭配[lin-cms-vue](https://github.com/TaleLin/lin-cms-vue)使用了。

## 下个版本开发计划

- [ ] 常用异步任务封装

## 感谢以下开源产品

万分感谢,以下排名不分先后

- [`ThinkPHP v6`](https://www.kancloud.cn/manual/thinkphp6_0) ThinkPHP6.0官方文档
- [`LazySkills/PAA-ThinkPHP6`](https://github.com/LazySkills/PAA-thinkphp6) 优秀的TP6注解框架
- [`LazySkills/think-annotation`](https://github.com/LazySkills/think-annotation) 优秀注解扩展
- [`firebase/php-jwt`](https://packagist.org/packages/firebase/php-jwt) `php-jwt`验证器
- [`sentsin/layui`](https://github.com/sentsin/layui) 优秀前端框架

再次感谢,希望大家能帮这几个项目点点`star`。

## 讨论交流

### QQ 交流群

#### 林间有风官方群

QQ 群号:643205479

#### Lin-Cms-Tp6交流群

QQ 群号:669813444

### 微信公众号

微信搜索:林间有风