在这次实验中,需要改写Tomcat使之能够响应其他种类的协议。
在新的协议中,GET请求使用的?请求方式在路由器端会被自动过滤掉,因此考虑使用其他标识符进行GET请求的标识。
假定需要传入的参数为:username=xiaoxiaff&password=xiaoxiaff
在HTTP11Processer中找到行816
inputBuffer.parseRequestLine();
这行代码是对传入的Request请求进行解析。
包括:
GET、POST请求方式的解析。
GET请求的query解析。
URI的解析。
protocal协议类型的解析。
进入此方法,跳转至InternalInputBuffer.java中。
如果需要自行放入GET请求参数可以在此处入手。将行476
request.queryString().setBytes(buf, questionPos + 1,
end - questionPos - 1);
只要将buf换成我们需要的GET参数即可。
在看看行476完整的上下文
request.unparsedURI().setBytes(buf, start, end - start); if (questionPos >= 0) { request.queryString().setBytes(buf, questionPos + 1, end - questionPos - 1); request.requestURI().setBytes(buf, start, questionPos - start); } else { request.requestURI().setBytes(buf, start, end - start); }
在这里可以看到,questionPos是由此段之前的代码定位到的?,用来标识GET请求,重新设置requestURI即可完成uri的定向。
这种重新定向uri和get请求的方法,适合在传入的uri不满足tomcat自带的GET和POST请求解析时,由我们自己完成判断并实现指定页面跳转。