arifseft / laravel-wordpress
为 Laravel (6.x 和 7.x) 提供的简单博客包(带有管理面板)。包括所有视图、控制器、路由,并可以将博客添加到任何现有的 Laravel 应用中。完全可定制的博客(视图、URL 和许多其他选项)。包括图像上传和美观的管理界面来管理您的博客。默认为
Requires
- cviebrock/eloquent-sluggable: ~8.0|~7.0|~6.0|~4.8|~4.7|~4.6|~4.5
- intervention/image: 2.*
- laravel/helpers: ^1.3
- laravelium/feed: ~2.12.0|~3.0.0|3.1.*|v6.0.*|v7.0.*|v8.0.*
Requires (Dev)
This package is auto-updated.
Last update: 2024-09-24 19:03:56 UTC
README
您是否使用过 WordPress?开发者称这个包为类似于 WordPress 的 Laravel 博客。
给我们这个包一个星标来支持我们 ⭐ 😍
安装视频 - 不到 5 分钟
轻量级且全面
具有令人难以置信的功能的轻量级 Laravel 博客包。我强烈推荐它,因为
- 快速安装(<3 分钟)
- 非常容易扩展
- 开箱即用功能强大
- 其简洁性允许轻松与最新版本的 Laravel 兼容
- 除了 Laravel 知识外没有其他概念
- 与 Bagisto 等其他 Laravel 平台兼容
杰出功能
- 全文搜索 - 在所有博客文章中搜索
- 多级分类 - 使用 Baum 的嵌套集
- 多语言支持
快速且易于安装(多语言版本)
1- 通过 composer 安装
composer require binshops/laravel-blog
对于新的 Laravel 安装,运行以下命令
composer require laravel/ui
php artisan ui vue --auth
2- 运行以下两个命令以复制配置文件、迁移文件和视图文件
php artisan vendor:publish --provider="BinshopsBlog\BinshopsBlogServiceProvider"
3- 执行迁移以创建表
php artisan migrate;
4- 您必须在您的 \App\User (在 laravel 8 \App\Models\User) 模型中添加一个方法。正如该方法的名称所示,它确定哪个用户可以管理帖子。将您的逻辑放在那里
/**
* Enter your own logic (e.g. if ($this->id === 1) to
* enable this user to be able to add/edit blog posts
*
* @return bool - true = they can edit / manage blog posts,
* false = they have no access to the blog admin panel
*/
public function canManageBinshopsBlogPosts()
{
// Enter the logic needed for your app.
// Maybe you can just hardcode in a user id that you
// know is always an admin ID?
if ( $this->id === 1
&& $this->email === "your_admin_user@your_site.com"
){
// return true so this user CAN edit/post/delete
// blog posts (and post any HTML/JS)
return true;
}
// otherwise return false, so they have no access
// to the admin panel (but can still view posts)
return false;
}
5- 在 public/
中创建一个名为 blog_images
的目录
6- 以管理员身份登录并设置您的包: /blog_admin/setup
恭喜!您的博客已准备好使用。(URL 在配置文件中可自定义)
管理面板 URI: /blog_admin
前端 URI: /en/blog
要查看 Packagist 上的包,请点击此 链接
单语言版本
要安装包的单语言版本,请使用版本 v8.1x
1- composer require binshops/laravel-blog:v8.1.2
2- php artisan vendor:publish --provider="BinshopsBlog\BinshopsBlogServiceProvider"
3- php artisan vendor:publish --tag=laravel-fulltext
4- php artisan migrate;
您可以在 "single-lang" 分支中看到单语言版本。
重要提示
- 对于 laravel 8.x 的默认 auth User 模型,将
binshopsblog.php
中的用户模型更改为:\App\Models\User::class
功能
- 与最新 Laravel 版本(laravel 8.x)兼容
- 向后兼容之前的 Laravel 版本
- 全文搜索 - 在博客文章中进行搜索
- 多级分类支持
- 完全通过其
config/binshopsblog.php
配置文件进行配置 - 现成的管理面板
- 完全可自定义管理视图和前端视图
- 分页视图
- 上传图像的能力
- 管理帖子、分类
- 管理评论和评论批准
- 其他选项包括使用 Disqus 评论或禁用评论
最近更改
- 9.1.x 多语言支持
- 8.0.x 与 Laravel 8.x 兼容性
此包适用于谁/谁
- 运行 Laravel 的网站
- 希望拥有网站博客的人。这个 Laravel 博客提供了易于使用的界面来撰写博客文章/分配分类/管理现有帖子
- 仅管理员用户可以编辑/管理博客(这不适合您的网站上每个用户都能管理帖子的情况)
- 为任何喜欢将类似WordPress的Laravel博客添加到Laravel网站中的人
如何自定义博客视图/模板
完成正确的vendor:publish
后,所有默认模板文件都将位于/resources/views/vendor/binshopsblog/中,并易于编辑以符合您的需求。
自定义管理视图
如果您需要自定义管理视图,只需将文件从vendor/binshopsblog/src/Views/binshopsblog_admin
复制到resources/views/vendor/binshopsblog_admin
。然后您可以像修改其他任何视图文件一样修改它们。
路由
它将自动设置所有必需的路由(包括面向公众的和管理后端)。有一些配置选项(例如将/blog/ URL更改为其他内容),可以在binshopsblog.php文件中完成。
配置选项
所有配置选项都有注释,说明它们的作用。请参考您的/config/目录中的binshopsblog.php
文件。
自定义用户模型
您可以通过配置文件更改默认用户模型。
事件
您可以在/src/Events目录中找到所有触发的事件。
将以下内容(以及事件监听器)添加到您的EventServiceProvider.php
文件中,以便在事件触发时使用这些事件。
内置CAPTCHA/反垃圾邮件
内置了一个内置的CAPTCHA(反垃圾邮件评论)系统,您可以轻松地将其替换为您自己的实现。
内置了一个基本的反垃圾邮件CAPTCHA功能。
请查看config/binshops.php中的captcha部分。有一个内置的系统(基本!)可以防止大多数自动垃圾邮件尝试。编写自己的CAPTCHA系统
我故意将CAPTCHA系统写得很简单,这样您就可以添加自己的CAPTCHA选项。应该很容易添加任何其他CAPTCHA系统。
如果您想自己编写实现,请创建自己的类,该类实现了\BinshopsBlog\Interfaces\CaptchaInterface,然后更新config/binshopsblog.php文件(更改captcha_type选项)。
您需要实现三种方法:public function captcha_field_name() : string
返回一个字符串,例如"captcha"。它用于表单验证。public function view() : string
binshops::partials.add_comment_form视图应包含什么视图文件?您可以设置为所需的内容,然后创建自己的视图文件。默认包含的基本CAPTCHA类将返回"binshops::captcha.basic"。public function rules() : array
返回一个数组用于规则(这些是标准的Laravel验证规则。这是检查CAPTCHA是否成功的地方。可选:public function runCaptchaBeforeShowingPosts() : null
这不是接口的一部分,不是必需的。默认情况下,它什么都不做。但您可以在该方法中添加一些代码,它将在BinshopsReaderController::viewSinglePost方法中运行。
图片上传错误
尝试将此添加到config/app.php
'Image' => Intervention\Image\Facades\Image::class
- 同时确保/tmp是可写的。如果您已启用open_basedir,请确保将其值添加:/tmp。
- 确保/public/blog_images(或您在配置中设置的任何目录)由服务器可写
- 您可能需要设置更高的内存限制,或上传更小的图片文件。这取决于您的服务器。我已经使用它上传了巨大的(10mb+)jpg图片而没有问题,一旦服务器正确设置以处理更大的文件上传。
版本历史
- 9.2.x 稳定版本的软件包
- 9.0.x 多语言支持测试版
- 8.0.x 与Laravel 8的兼容性
- 7.3.0 新的管理UI
- 3.0.1 - 将所有短标签(<?)替换为完整的打开标签(<?php)
- 2.0 - 添加全文搜索(通过配置文件启用它 - 默认情况下是禁用的)。
- 1.1.1 - 添加基本CAPTCHA
- 1.0.5 - composer.json更改。
- 1.0 - 首次发布
- 0.1 - 初始发布