laravel-admin引用wangEditor编辑器 使用一:上传图片

2024-01-31 18:58

本文主要是介绍laravel-admin引用wangEditor编辑器 使用一:上传图片,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.安装wangEditor

安装

composer require laravel-admin-ext/wang-editor

然后

php artisan vendor:publish --tag=laravel-admin-wangEditor

配置

config/admin.php文件的extensions,加上属于这个扩展的一些配置

    'extensions' => ['wang-editor' => [// 如果要关掉这个扩展,设置为false'enable' => true,// 编辑器的配置'config' => []]]

详见:https://github.com/laravel-admin-extensions/wangEditor

https://www.kancloud.cn/wangfupeng/wangeditor3/335776 使用手册

2.新建组件:app/Admin/Extensions/WangEditor.php 如下:

<?php
namespace App\Admin\Extensions;
use Encore\Admin\Form\Field;
class WangEditor extends Field
{protected $view = 'admin.wang-editor';protected static $css = ['/vendor/laravel-admin-ext/wang-editor/wangEditor-3.0.10/release/wangEditor.min.css'];protected static $js = ['/vendor/laravel-admin-ext/wang-editor/wangEditor-3.0.10/release/wangEditor.min.js',];public function render(){$name = $this->formatName($this->column);$this->script = <<<EOT
var E = window.wangEditor
var editor = new E('#{$this->id}');// 通过 url 参数配置 debug 模式。url 中带有 wangeditor_debug_mode=1 才会开启 debug 模式
//    editor.customConfig.debug = location.href.indexOf('wangeditor_debug_mode=1') > 0editor.customConfig.debug = true
editor.customConfig.uploadFileName = 'mypic';
editor.customConfig.uploadImgHeaders = {'X-CSRF-TOKEN': $('input[name="_token"]').val()
}
editor.customConfig.zIndex = 0;
editor.customConfig.uploadImgServer = '/uploadimg'; //这里是图片上传请求接口 路由中已经配好 否则找不到
editor.customConfig.onchange = function (html) {$('input[name=$name]').val(html);
}editor.customConfig.uploadImgHooks = {customInsert: function (insertImg, result, editor) {if (typeof(result.length) != "undefined") {for (var i = 0; i <= result.length - 1; i++) {var j = i;var url = result[i].newFileName;insertImg(url);}toastr.success(result[j]['info']);}switch (result['ResultData']) {case 7:toastr.error("图片过大");break;case 6:toastr.error("最多可以上传1张图片");break;case 5:toastr.error("请选择一个文件");break;case 4:toastr.error("上传失败");break;case 3:toastr.error(result['info']);break;case 2:toastr.error("文件类型不合法");break;case 1:toastr.error(result['info']);break;}}
}editor.create();
EOT;return parent::render();}
}

3.新建视图文件 resources/views/admin/wang-editor.blade.php

如下:

<div class="form-group {!! !$errors->has($label) ?: 'has-error' !!}">
    <label for="{{$id}}" class="col-sm-2 control-label">{{$label}}</label>
    <div class="{{$viewClass['field']}}">
        @include('admin::form.error')
        <div id="{{$id}}" style="width: 100%; height: 100%;">
            <p>{!! old($column, $value) !!}</p>
        </div>
        <input type="hidden" name="{{$name}}" value="{{ old($column, $value) }}" />
    </div>
</div>

4.然后注册进laravel-admin

在app/Admin/bootstrap.php中添加以下代码:

use App\Admin\Extensions\WangEditor;
use Encore\Admin\Form;
Form::extend('wangeditor', WangEditor::class);

5.新建图片上传控制器 作图片上传处理(我的是上传到阿里云)

   public function uploadimg(Request $request){$mypic = $_FILES['mypic'];if (!empty($mypic)) {$ext = strtolower(substr($mypic['type'], strrpos($mypic['type'], '/') + 1));$exts = ['jpg', 'png', 'gif', 'jpeg'];if (!in_array($ext, $exts)) {$response[] = ['ResultData' => 2, 'info' => '文件类型不允许,请上传常规的图片(gif、jpg、jpeg与png)文件'];return $response;}$content = file_get_contents($mypic['tmp_name']);$filename = date('His') . uniqid() . "." . $ext;$env = config('app.env', 'local');$savePath = 'uploads/official/img/' . date("Y/m/d");$file = "/storage/{$savePath}/{$filename}";if ($env !== 'production') {$file = "/storage/$env/{$savePath}/{$filename}";}Storage::cloud()->put($file, $content);//删除本地图片$l = substr(strstr($localPath, "public"), 7);//区分线上还是测试机if ($env == 'production') {$l = '/var/www/zx/storage/app/public/'.$l;} else {$l = '/var/www/html/dev_admin/storage/app/public/'.$l;}if(file_exists($l)){unlink($l);}$filenames = '你的网址' . $file;$response[] = ['ResultData' => 0, 'info' => '上传成功', 'newFileName' => $filenames];return $response;}else{$response[] = ['ResultData' => 5, 'info' => '请选择一个文件'];return $response;}}

6.路由配置

Route::post('/uploadimg', 'UploadsController@uploadimg');

7.管理后台调用:

 public function form(){return FormBuilder::buildFrom(OfficialDevelopments::class, function (Form $form) {$form->wangeditor('content', '内容')->rules('required', ['required' => '必填']);})->get();}

然后就出现下图:

 

这篇关于laravel-admin引用wangEditor编辑器 使用一:上传图片的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/664742

相关文章

使用Python实现IP地址和端口状态检测与监控

《使用Python实现IP地址和端口状态检测与监控》在网络运维和服务器管理中,IP地址和端口的可用性监控是保障业务连续性的基础需求,本文将带你用Python从零打造一个高可用IP监控系统,感兴趣的小伙... 目录概述:为什么需要IP监控系统使用步骤说明1. 环境准备2. 系统部署3. 核心功能配置系统效果展

使用Java将各种数据写入Excel表格的操作示例

《使用Java将各种数据写入Excel表格的操作示例》在数据处理与管理领域,Excel凭借其强大的功能和广泛的应用,成为了数据存储与展示的重要工具,在Java开发过程中,常常需要将不同类型的数据,本文... 目录前言安装免费Java库1. 写入文本、或数值到 Excel单元格2. 写入数组到 Excel表格

redis中使用lua脚本的原理与基本使用详解

《redis中使用lua脚本的原理与基本使用详解》在Redis中使用Lua脚本可以实现原子性操作、减少网络开销以及提高执行效率,下面小编就来和大家详细介绍一下在redis中使用lua脚本的原理... 目录Redis 执行 Lua 脚本的原理基本使用方法使用EVAL命令执行 Lua 脚本使用EVALSHA命令

Java 中的 @SneakyThrows 注解使用方法(简化异常处理的利与弊)

《Java中的@SneakyThrows注解使用方法(简化异常处理的利与弊)》为了简化异常处理,Lombok提供了一个强大的注解@SneakyThrows,本文将详细介绍@SneakyThro... 目录1. @SneakyThrows 简介 1.1 什么是 Lombok?2. @SneakyThrows

使用Python和Pyecharts创建交互式地图

《使用Python和Pyecharts创建交互式地图》在数据可视化领域,创建交互式地图是一种强大的方式,可以使受众能够以引人入胜且信息丰富的方式探索地理数据,下面我们看看如何使用Python和Pyec... 目录简介Pyecharts 简介创建上海地图代码说明运行结果总结简介在数据可视化领域,创建交互式地

Java Stream流使用案例深入详解

《JavaStream流使用案例深入详解》:本文主要介绍JavaStream流使用案例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录前言1. Lambda1.1 语法1.2 没参数只有一条语句或者多条语句1.3 一个参数只有一条语句或者多

Java Spring 中 @PostConstruct 注解使用原理及常见场景

《JavaSpring中@PostConstruct注解使用原理及常见场景》在JavaSpring中,@PostConstruct注解是一个非常实用的功能,它允许开发者在Spring容器完全初... 目录一、@PostConstruct 注解概述二、@PostConstruct 注解的基本使用2.1 基本代

C#使用StackExchange.Redis实现分布式锁的两种方式介绍

《C#使用StackExchange.Redis实现分布式锁的两种方式介绍》分布式锁在集群的架构中发挥着重要的作用,:本文主要介绍C#使用StackExchange.Redis实现分布式锁的... 目录自定义分布式锁获取锁释放锁自动续期StackExchange.Redis分布式锁获取锁释放锁自动续期分布式

springboot使用Scheduling实现动态增删启停定时任务教程

《springboot使用Scheduling实现动态增删启停定时任务教程》:本文主要介绍springboot使用Scheduling实现动态增删启停定时任务教程,具有很好的参考价值,希望对大家有... 目录1、配置定时任务需要的线程池2、创建ScheduledFuture的包装类3、注册定时任务,增加、删

使用Python实现矢量路径的压缩、解压与可视化

《使用Python实现矢量路径的压缩、解压与可视化》在图形设计和Web开发中,矢量路径数据的高效存储与传输至关重要,本文将通过一个Python示例,展示如何将复杂的矢量路径命令序列压缩为JSON格式,... 目录引言核心功能概述1. 路径命令解析2. 路径数据压缩3. 路径数据解压4. 可视化代码实现详解1