ajax - laravel怎麼驗證blob檔案是圖片?
仅有的幸福
仅有的幸福 2017-05-16 16:49:55
0
3
785

如果是表單普通方式提交,後台驗證沒什麼問題:

        $file = $request->avatar;
        $input = array('image' => $file);
        $rules = array(
            'image' => 'image'
        );
        $validator = \Validator::make($input, $rules);
        if ( $validator->fails() ) {
            return \Response::json([
                'success' => false,
                'errors' => $validator->getMessageBag()->toArray()
            ]);

        }

可是,用formData物件提交,這個圖片文件轉換成了blob文件,就不能驗證了:

        $('#uploadAvatar').on('click', function (e) {

            $('#uploadAvatar').html('正在保存...');
            $("#image").cropper('getCroppedCanvas').toBlob(function (blob) {
                var formData = new FormData();

                formData.append('croppedImage', blob);

                $.ajaxSetup({
                    headers: {
                        'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content')
                    }
                });


                $.ajax({
                    type: "POST",
                    url: "{{ url('/avatar') }}",
                    processData: false,
                    contentType: false,
                    cache: false,
                    data: formData
                }).done(function (response) {
                    showResponse(response);
                }).fail(function (data) {
                    alert('提交失败,请尝试重新提交');
                });

            });

        });

後台怎麼才可以驗證blob檔案是圖片?

仅有的幸福
仅有的幸福

全部回覆(3)
过去多啦不再A梦

很簡單啊,搞個臨時變數還原回來不就好了?
$file = file_put_contents('/path/to/new/file_name', $blob);

phpcn_u1582

擴充驗證規則用getimagesize

大家讲道理

可以用 base64 流的方式

熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板