ckeditor5 vue检查图像已删除

时间:2018-10-11 05:04:09

标签: php laravel vue.js ckeditor5

我在this package的文章表单中使用的是ckeditor5 vue版本,并且还附带了通过添加此代码来处理图片上传的示例

UploadAdapter: function (loader) {
    this.loader = loader
    this.upload = () => {
        const body = new FormData();
        body.append('gambar', this.loader.file);

        let token = window.localStorage.getItem('token');

        return fetch('https://bkcuvue.test/api/v1/artikel/upload', {
            headers: {"Authorization": 'Bearer ' + token},
            body: body,
            method: 'POST'
        })
            .then(response => response.json())
            .then(downloadUrl => {
                return {
                    default: downloadUrl
                }
            })
            .catch(error => {
                console.log(error);
            });
    }
    this.abort = () => {
        console.log('Abort upload.')
    }
},

然后在我的后端(laravel)就是这样

public function upload(Request $request)
    {
        if(!empty($request->gambar))
            $fileName = Helper::image_processing($this->imagepath,$this->width,$this->height,$request,'');
        else
            $fileName = '';

        return response()->json('/' . $this->imagepath . $fileName . '.jpg');
    }

到ckeditor组件

<vue-ckeditor type="classic" v-model="htmlContent" :upload-adapter="UploadAdapter"></vue-ckeditor>

它有效!但是我很快意识到的问题是因为此方法将图像上传到服务器,然后将图像路径返回到或编辑器,该图像路径将作为纯html标签保存到数据库中...

然后,例如,如果我上传图像,然后想要删除或更改图像,则编辑器将从编辑器中删除img标签,而不是服务器上的真实图像文件。...

图像文件将保留在服务器上,除非我选择图像并手动通过ftp或ssh进入服务器,然后将其删除,否则无法删除它。

有什么方法可以检查图像标签是否被删除,然后它将在服务器上删除。也许后端有一种方法可以检查任何文章是否都没有使用此图像文件...

如果我两次上传相同的图像,那么它将两次也将相同的文件上传到服务器两次,如何检测服务器上是否已存在相同的图像文件而不上传重复的图像,而是立即返回图像路径< / p>

1 个答案:

答案 0 :(得分:0)

我使用这种方法,上传图像并保存URL。当我发送编辑器的内容时​​,还会发送URL,并且在服务器上,我将URL包含在编辑器的内容中,而不将URL删除,然后删除相应的文件。

客户:

onChange={ ( event, editor ) => {

  this.state.description = editor.getData();

  var vm = this

  var urls = Array.from( new DOMParser().parseFromString( editor.getData(), 'text/html' )
             .querySelectorAll( 'img' ) )
             .map( img => img.getAttribute( 'src' ) );

  urls.forEach(function(element) {
    if (String(element).length > 10) {
      if (vm.state.filesCKeditor.length > 0) {
        if(filter(vm.state.filesCKeditor, function(o) { return String(o) === String(element) }).length == 0)
         {
           vm.state.filesCKeditor.push(element)
         }
       }else{
         vm.state.filesCKeditor.push(element)
       }
     }
   });
}}

enter image description here

服务器:

foreach (explode(',',$this->post('filesCKeditor')) as $value) {
  # code...
  if (!isset(explode($value,$this->post('content'))[1])) {
    print_r('false');//add code for delete image
  }
}