Pessoal,
Pode parecer uma pergunta newbie, mas realmente isso está me tirando o sono. Tenho uma aplicação VRaptor numa Cloud. Um de meus Controllers externaliza URLs para serem acessadas por uma app mobile. Consigo acessar os métodos GET sem problema, retornando o que desejo deles, porém quando chamo os métodos POST para enviar informação para ser processada, obtenho Bad Server - HTTP Error, outras vezes recebo Timeout. Para proteger minhas URLs utilizo autenticação BASIC configurada na minha aplicação e no JBoss. Como falei, para os GET tudo funciona ok, mas no caso dos POST nada feito.
Meu web.xml
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5">
<display-name>MinhaApp</display-name>
<filter>
<filter-name>vraptor</filter-name>
<filter-class>br.com.caelum.vraptor.VRaptor</filter-class>
</filter>
<filter-mapping>
<filter-name>vraptor</filter-name>
<url-pattern>/*</url-pattern>
<dispatcher>FORWARD</dispatcher>
<dispatcher>REQUEST</dispatcher>
</filter-mapping>
<context-param>
<param-name>javax.servlet.jsp.jstl.fmt.locale</param-name>
<param-value>pt_BR</param-value>
</context-param>
<context-param>
<param-name>br.com.caelum.vraptor.packages</param-name>
<param-value>
br.com.bronx.vraptor.saci,
br.com.caelum.vraptor.deserialization.gson,
br.com.caelum.vraptor.serialization.gson.adapters
</param-value>
</context-param>
<security-role>
<description>Normal user to the My application.</description>
<role-name>MyUser</role-name>
</security-role>
<security-constraint>
<web-resource-collection>
<web-resource-name>General My use.</web-resource-name>
<url-pattern>/service/*</url-pattern>
<http-method>GET</http-method>
<http-method>POST</http-method>
<http-method>PUT</http-method>
</web-resource-collection>
<auth-constraint>
<role-name>MyUser</role-name>
</auth-constraint>
<user-data-constraint>
<transport-guarantee>NONE</transport-guarantee>
</user-data-constraint>
</security-constraint>
<login-config>
<auth-method>BASIC</auth-method>
</login-config>
</web-app>
No meu standalone.xml do JBoss adicionei:
<security-domain name="MinhaApp" cache-type="default">
<authentication>
<login-module code="org.jboss.security.auth.spi.UsersRolesLoginModule" flag="required">
<module-option name="usersProperties" value="/my-users.properties"/>
<module-option name="rolesProperties" value="/my-user-roles.properties"/>
</login-module>
</authentication>
</security-domain>
Creio que estas configurações não são o problema pois, como falei, o GET funciona corretamente quando forneço o usuário/senha corretos.
Existe alguma configuração para o JBoss aceitar POST Cross-Domain?
Agradeço desde já por qualquer ajuda.