CKFinder 3

CKFinder 3 là trình quản lý tập tin được tích hợp với CKEditor 4 và CKEditor 5. Nó giúp bạn dễ dàng đưa các tập tin và hình ảnh vào nội dung của Editor một cách an toàn.

Đây là một tính năng có phí và bạn cần có một giấy phép để sử dụng nó, ngoài giấy phép thương mại của CKEditor của bạn.

Amazon S3

Amazon S3 là một dịch vụ lưu trữ đối tượng cung cấp khả năng thay đổi quy mô, mức độ sẵn sàng của dữ liệu, độ bảo mật và hiệu suất hàng đầu trong ngành.

Khách hàng thuộc mọi quy mô và ngành nghề có thể lưu trữ và bảo vệ dữ liệu thuộc mọi kích thước cho hầu hết tất cả các trường hợp sử dụng, chẳng hạn như hồ dữ liệu, ứng dụng hoạt động trên đám mây và ứng dụng di động.

Thực hiện kết nối  Amazon S3 với CKFinder

Trước khi, bắt đầu thực hiện tính năng này, bạn cần phải tích hợp CKFinder vào CKEditor trong Laravel (Phiên bản được áp dụng trong bài viết là Laravel 11).

Nếu bạn chưa thực hiện setting nào liên quan đến CKFinder và CKEditor trong Laravel thì bạn có thể tham khảo lại bài viết sau:

● Integrating CKEditor 5 in Laravel 10 using Vite

● Integrating CKFinder Into CKEditor 5 In Laravel

Dưới đây là các thông số kỹ thuật cần thiết để config Amazon S3 storage cho CKFinder:

Option Name Type Mô tả
name Boolean Unique name của backend.
adapter String Type adapter được sử dụng bởi backend - s3 cho Amazon S3
bucket String Bucket name.
region String Region identifier. Danh sách regions và endpoints xem tại đây.
key String Access key.
secret String Secret value.

signature

(Optional)

String

Signature version cho region (mặc định là v4).

Danh sách regions và supported signature versions tại đây.

visibility

(Optional)

String

Khả năng hiển thị của các tập tin.

Mặc định là private, nghĩa là các tập tin upload lên S3 không thể truy cập trực tiếp.

Để cho phép truy cập trực tiếp, bạn hãy đặt giá trị này thành public.

baseUrl

(Optional)

String

Base URL được sử dụng để truy cập các tập tin CKFinder trên Amazon S3.

Nếu các tập tin công khai, bạn có thể tìm common prefix của chúng tương tự như bên dưới:

https://s3-eu-west-1.amazonaws.com/bucket

root

(Optional)

String

Đường dẫn thư mục chứa tập tin người dùng của CKFinder.

Thư mục này phải tồn tại trên Server.

useProxyCommand

(Optional) (3.1.0)

Boolean Liệu các liên kết đến các tập tin được lưu trữ trên backend này có nên trỏ đến lệnh Proxy hay không.

Tiếp theo, chúng ta hãy mở tập tin config/ckfinder.php và điều chỉnh các thông số cần thiết của ['backends']['default'] để có thể kết nối với Amazon S3 như sau:

$config['backends']['default'] = array(
    'name'         => 'default',
    'adapter'      => 's3',
    'bucket'       => env('AWS_BUCKET'),
    'region'       => env('AWS_DEFAULT_REGION'),
    'key'          => env('AWS_ACCESS_KEY_ID'),
    'secret'       => env('AWS_SECRET_ACCESS_KEY'),
    'visibility'   => 'public',
    'baseUrl'      => env('AWS_URL'),
    'root'         => '/',
);

Tiếp theo, bạn cần tạo AWS access key nếu bạn chưa thực hiện điều này. Để biết thêm chi tiết, bạn có thể tham khảo tài liệu chính thức của Amazon Web Services.

Lưu ý quan trọng: Hãy tuân thủ các Best Practices của IAM và tránh sử dụng AWS root access key trực tiếp để đảm bảo an toàn.

Cuối cùng, chúng ta hãy mở tập tin .env và cung cấp các thông tin cần thiết như sau:

AWS_ACCESS_KEY_ID=xxxxxx
AWS_SECRET_ACCESS_KEY=xxxxxx
AWS_DEFAULT_REGION=xxxxxx
AWS_BUCKET=xxxxxx
AWS_URL=xxxxxx

Kết quả của công việc bạn đã làm đang chờ bạn khám phá!

Sau khi đã cùng nhau hoàn thành những bước trên, giờ đây chúng ta hãy cùng nhau khám phá và tận hưởng thành quả của công sức mình.

Chúng ta hãy mở trình duyệt lên và truy cập vào địa chỉ  http://127.0.0.1 để chiêm ngưỡng kết quả do chính bản thân chúng ta tạo ra 🤤🤤🤤🏆🍨🍨🍨.

CÓ THỂ BẠN QUAN TÂM

Cloudflare's Turnstile CAPTCHA in Laravel

Cloudflare's Turnstile CAPTCHA in Laravel

Ngày 28/09/2022, Cloudflare đã thông báo về phiên bản beta mở của Turnstile, một giải pháp thay thế vô hình cho CAPTCHA. Bất kỳ ai, ở bất kỳ đâu trên Internet muốn thay thế CAPTCHA trên trang web c...

Document Laravel API With OpenAPI (Swagger)

Document Laravel API With OpenAPI (Swagger)

Swagger là gì? Swagger là một Ngôn ngữ mô tả giao diện để mô tả các API RESTful được thể hiện bằng JSON. Swagger được sử dụng cùng với một bộ công cụ phần mềm mã nguồn mở để thiết kế, xây dựng, l...

Laravel Authentication With Laravel UI

Laravel Authentication With Laravel UI

Laravel UI Laravel UI cung cấp một cách nhanh chóng để mở rộng các route và view cần thiết cho chức năng Authentication và bao gồm các cài đặt liên quan cho Bootstrap, React hoặc Vue. Mặc dù nó v...

Integrating CKEditor 5 in Laravel 10 using Vite

Integrating CKEditor 5 in Laravel 10 using Vite

CKEditor 5CKEditor 5 là một trình soạn thảo văn bản phong phú JavaScript với nhiều tính năng và khả năng tùy chỉnh. CKEditor 5 có kiến trúc MVC hiện đại, mô hình dữ liệu tùy chỉnh và DOM ảo, mang...

Laravel UI Custom Email Verification Template

Laravel UI Custom Email Verification Template

Nếu bạn đang dùng thư viện laravel/ui để làm các chức năng liên quan đến authentication, và trong dự án của bạn, bạn cần thay đổi template email verification thay vì sử dụng template email verificatio...

How to insert into a database at lightning speed?

How to insert into a database at lightning speed?

Trong quá trình thực hiện dự án cho công ty, một trong những yêu cầu đặt ra là import dữ liệu từ file CSV (chứa dữ liệu từ hệ thống cũ) vào cơ sở dữ liệu MySQL của hệ thống mới. Do sự thay đổi cấu...

Laravel Routing

Laravel Routing

Route là gì? Đúng như tên gọi của nó, Route thực hiện chức năng định tuyến, dẫn đường cho các HTTP request gửi đến đúng nơi mà ta mong muốn. Với sự phát triển mạnh mẽ của ứng dụng web ngày nay, việc...

Integrating elFinder Into CKEditor 5 In Laravel

Integrating elFinder Into CKEditor 5 In Laravel

CKEditor 5 CKEditor 5 là một trình soạn thảo văn bản phong phú JavaScript với nhiều tính năng và khả năng tùy chỉnh. CKEditor 5 có kiến trúc MVC hiện đại, mô hình dữ liệu tùy chỉnh và DOM ảo, mang...

Integrating elFinder into TinyMCE 6 in Laravel

Integrating elFinder into TinyMCE 6 in Laravel

TinyMCE TinyMCE là một trình soạn thảo WYSIWYG được xây dựng trên nền tảng Javascript, được phát triển dưới dạng mã nguồn mở theo giấy phép MIT bởi Tiny Technologies Inc. TinyMCE cho phép người d...

ManhDanBlogs