Puse lo siguiente en el web.xml de mi aplicación para intentar no permitir PUT, DELETE, etc .:
<security-constraint>
<web-resource-collection>
<web-resource-name>restricted methods</web-resource-name>
<url-pattern>/*</url-pattern>
<http-method>DELETE</http-method>
<http-method>PUT</http-method>
<http-method>SEARCH</http-method>
<http-method>COPY</http-method>
<http-method>MOVE</http-method>
<http-method>PROPFIND</http-method>
<http-method>PROPPATCH</http-method>
<http-method>MKCOL</http-method>
<http-method>LOCK</http-method>
<http-method>UNLOCK</http-method>
<http-method>delete</http-method>
<http-method>put</http-method>
<http-method>search</http-method>
<http-method>copy</http-method>
<http-method>move</http-method>
<http-method>propfind</http-method>
<http-method>proppatch</http-method>
<http-method>mkcol</http-method>
<http-method>lock</http-method>
<http-method>unlock</http-method>
</web-resource-collection>
<auth-constraint />
</security-constraint>
Ok, entonces ahora:
Si hago una solicitud con el método de DELETE, obtengo un 403 de vuelta.
Si hago una solicitud con el método de delete, obtengo un 403 de vuelta.
PERO
Si hago una solicitud con el método de DeLeTeme sale bien!
¿Cómo puedo hacer que no permita estas mayúsculas y minúsculas?
Editar: lo estoy probando con un programa C #:
private void button1_Click(object sender, EventArgs e)
{
textBox1.Text = "making request";
System.Threading.Thread.Sleep(400);
WebRequest req = WebRequest.Create("http://serverurl/Application/cache_test.jsp");
req.Method = txtMethod.Text;
try
{
HttpWebResponse resp = (HttpWebResponse)req.GetResponse();
textBox1.Text = "Status: " + resp.StatusCode;
if (resp.StatusCode == System.Net.HttpStatusCode.OK)
{
WebHeaderCollection header = resp.Headers;
using (System.IO.StreamReader reader = new System.IO.StreamReader(resp.GetResponseStream(), ASCIIEncoding.ASCII))
{
//string responseText = reader.ReadToEnd();
textBox1.Text += "\r\n" + reader.ReadToEnd();
}
}
}
catch (Exception ex)
{
textBox1.Text = ex.Message;
}
}
txtMethod.Textes un cuadro de texto donde estoy escribiendo el nombre del método. Cuando hay un 403, se lanza una excepción que queda atrapada en el bloque catch.
Cache_test.jsp contiene:
<%
response.setHeader("Cache-Control", "no-store, no-cache, must-revalidate, post-check=0, pre-check=0");
response.setHeader("Pragma","no-cache");
out.print("Method used was: "+request.getMethod());
%>
HttpWebRequestse mayúsculas y minúsculas reconocer y convertir métodos HTTP estándar a mayúsculas. Además, se documenta que solo permite métodos HTTP estándar. La mejor opción es utilizar una secuencia TCP sin procesar (por ejemplo, en netcat, o PuTTY raw, o telnet, etc.).