Reputation: 5069
How can I add http header to soap webservice using netbeans and glassfish?
My webservice class:
package com.service;
import com.model.Contact;
import com.model.Phonebook;
import java.util.ArrayList;
import javax.jws.WebMethod;
import javax.jws.WebParam;
import javax.jws.WebService;
@WebService(serviceName = "PhonebookService")
public class PhonebookService {
private Phonebook phonebook = new Phonebook();
@WebMethod(operationName = "insert")
public String insert(@WebParam(name = "contact") Contact contact) {
phonebook.add(contact);
return contact.getName() + " inserted";
}
@WebMethod(operationName = "update")
public String update(@WebParam(name = "contact") Contact contact) {
phonebook.update(contact);
return contact.getName() + " updated";
}
@WebMethod(operationName = "remove")
public String remove(@WebParam(name = "contact") Contact contact) {
phonebook.remove(contact);
return contact.getName() + " removed";
}
@WebMethod(operationName = "list")
public ArrayList<Contact> list() {
return phonebook.list();
}
}
I would like to add "Access-Control-Allow-Origin: *" header
How can I do it?
Upvotes: 0
Views: 2045
Reputation: 5069
Searching over internet for hours, I ended up coding the following code which allow to add extra http headers. I am using it with netbeans generated webservice and built-in glassfish 3 server
import java.io.*;
import javax.servlet.*;
import javax.servlet.annotation.WebFilter;
import javax.servlet.http.*;
@WebFilter(urlPatterns = { "/*" })
public class CrossOriginResourceSharingFilter implements Filter {
public CrossOriginResourceSharingFilter() { }
@Override
public void init(FilterConfig fConfig) throws ServletException { }
@Override
public void destroy() { }
@Override
public void doFilter(
ServletRequest request, ServletResponse response,
FilterChain chain) throws IOException, ServletException {
((HttpServletResponse)response).addHeader(
"Access-Control-Allow-Origin", "*"
);
((HttpServletResponse)response).addHeader(
"Access-Control-Allow-Headers", "Content-Type, Authorization, Accept"
);
((HttpServletResponse)response).addHeader(
"Access-Control-Allow-Methods", "GET, POST, OPTIONS"
);
chain.doFilter(request, response);
}
}
Upvotes: 1