- Back to Docs
- Install and Configure
- Image
- Server Upload
- Server Delete
- S3 Upload
- Resize
- Validation
- Image Manager
- Simple Server
- File
- Server Upload
- Server Delete
- S3 Upload
- Validation
- References
- Image
- File
- S3
Java File Server Upload
How it works
- You specify the upload options when the rich text editor is initialized on client side.
- When an file is inserted, the javascript editor automatically makes an AJAX request to the server.
- Once the request hits the server, it stores the file and sends back to the client the link to the uploaded file.
Initialize the javascript editor
To get started, the rich text editor needs to have the fileUploadURL
option set as the URL where you want to have the files uploaded. Additionally, you can set other options related to the way the files are being uploaded and what data your server receives: fileUploadParam
, fileUploadParams
, fileUploadMethod
, fileMaxSize
, fileAllowedTypes
.
<script> $(function() { $('.selector').froalaEditor({ // Set the file upload URL. fileUploadURL: '/upload_file' }) }); </script>
Receive the uploaded file and store it
The server implementation is responsible for receiving the request and handling it appropriately. In Java, the uploaded file is available in the javax.servlet.http.HttpServletRequest
parameter. The Java editor SDK is designed to automatically detect the uploaded file, so you just have to specify the path where to store it.
Note: The path of the file is relative to the root of the project.
String fileRoute = "/public/"; Map<Object, Object> responseData = File.upload(request, fileRoute);
For the uploaded file to be stored correctly, the server should have the rights to write in the uploads folder. Additionally, you should check that the uploaded file is public accessible in browser so it can be displayed to your users.
Return the path to the uploaded file
If the save action is completed successfully, the SDK is generating an FileResponse
object with the absolute path to the uploaded file, so your server just have to return it back to the client side.
String jsonResponseData = new Gson().toJson(responseData); response.setContentType("application/json"); response.setCharacterEncoding("UTF-8"); response.getWriter().write(jsonResponseData);
Complete Example
<script> $(function() { $('.selector').froalaEditor({ // Set the file upload URL. fileUploadURL: '/upload_file' }) }); </script>
package com.froala.examples.servlets; import java.io.IOException; import java.util.HashMap; import java.util.Map; import javax.servlet.ServletException; import javax.servlet.annotation.MultipartConfig; import javax.servlet.annotation.WebServlet; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import com.froala.editor.File; import com.froala.editor.file.FileOptions; import com.google.gson.Gson; /** * Servlet implementation class UploadFile */ @WebServlet("/upload_file") @MultipartConfig public class UploadFile extends HttpServlet { private static final long serialVersionUID = 1L; /** * @see HttpServlet#HttpServlet() */ public UploadFile() { super(); } /** * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse * response) */ @Override protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String fileRoute = "/public/"; // No validation. FileOptions options = new FileOptions(); options.setValidation(null); Map<Object, Object> responseData; try { responseData = File.upload(request, fileRoute, options); } catch (Exception e) { e.printStackTrace(); responseData = new HashMap<Object, Object>(); responseData.put("error", e.toString()); } String jsonResponseData = new Gson().toJson(responseData); response.setContentType("application/json"); response.setCharacterEncoding("UTF-8"); response.getWriter().write(jsonResponseData); } }