- Getting Started
- Browser Support
- Languages Support
- Shortcuts
- Activation
- Examples
- Customize the Editor
- Use-cases
- Plugins
- APIs
- Development Frameworks
- Server Integrations
- Server SDKs
- Migration Guides
- Changelog
Java File Server Delete
How it works
- Code intercepts the file removed from the editor.
- Removing a file sends to the server a request to delete the file from disk.
- Once the request reaches the server, it deletes the file.
Intercept file being removed
Removing a file from the editor triggers two events: froalaEditor.file.beforeRemove
and froalaEditor.file.removed
. You can use either of them to delete the file from the server, however it is recomended to use the second one, since at that point you make sure that the file was removed from the editable area.
Send request to the server
There is no built-in feature that makes the request to the server, however you can use an AJAX request.
<script>
// Catch the file being removed.
var editor = new FroalaEditor('selector');
editor.opts.events['file.unlink'] = function (e, editor, file) {
$.ajax({
// Request method.
method: 'POST',
// Request URL.
url: '/delete_file',
// Request params.
data: {
src: file.getAttribute('href')
}
})
.done (function (data) {
console.log ('File was deleted');
})
.fail (function (err) {
console.log ('File delete problem: ' + JSON.stringify(err));
})
}
</script>
Delete the file
The server implementation is responsible for receiving the request and handling it appropriately. The code on the previous step makes the file path available in the javax.servlet.http.HttpServletRequest
parameter. The com.froala.editor.File.delete
method from the Java SDK expects the path of the file to remove from disk.
Note: The path is relative to the project root.
String src = request.getParameter("src");
File.delete(request, src);
Complete Example
<script>
// Catch the file being removed.
var editor = new FroalaEditor('selector');
editor.opts.events['file.unlink'] = function (e, editor, file) {
$.ajax({
// Request method.
method: 'POST',
// Request URL.
url: '/delete_file',
// Request params.
data: {
src: file.getAttribute('href')
}
})
.done (function (data) {
console.log ('File was deleted');
})
.fail (function (err) {
console.log ('File delete problem: ' + JSON.stringify(err));
})
}
</script>
package com.froala.examples.servlets;
import java.io.IOException;
import javax.servlet.ServletException;
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.google.gson.Gson;
/**
* Servlet implementation class DeleteFile
*/
@WebServlet("/delete_file")
public class DeleteFile extends HttpServlet {
private static final long serialVersionUID = 1L;
/**
* @see HttpServlet#HttpServlet()
*/
public DeleteFile() {
super();
}
/**
* @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse
* response)
*/
@Override
protected void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
String src = request.getParameter("src");
try {
File.delete(request, src);
} catch (Exception e) {
e.printStackTrace();
response.sendError(HttpServletResponse.SC_INTERNAL_SERVER_ERROR);
return;
}
String jsonResponseData = new Gson().toJson("Success");
response.setContentType("application/json");
response.setCharacterEncoding("UTF-8");
response.getWriter().write(jsonResponseData);
}
}
Do you think we can improve this article? Let us know.