【问题提出】项目中用到了Bootstrap的tab功能,在每个tab页间切换的时候,自动产生了形如:“xxx?cd=xx#xxxxx”的请求地址,并发给了controller层,由于“=”之后的都被看出了“cd”值内容,DB肯定没有与其匹配的值,所以控制台一直会报错。源代码大致如下:
<span style="font-family: Arial, Helvetica, sans-serif;"> </span><span style="font-family: Arial, Helvetica, sans-serif;"><!--tab 标签start --></span>
<div class="tabCategory ">
<ul id="myTab" class="nav nav-tabs">
<li class="active"><a href="<strong>#moreDetail</strong>" data-toggle="tab"><strong>更多细节</strong></a></li><span> </span>
<span> </span>...
</ul>
</div>
<div class="tabControl">
<div id="myTabContent" class="tab-content">
<div class="tab-pane fade in active" id="<strong>moreDetail</strong>">
...
</div>
</div>
</div>
<!--tab 标签end -->
分析过程:这种tab切换的实现目测跟常用的“锚点”技术差不多。-->服务器端拦截过滤请求太麻烦,尽量做到前端直接禁止访问请求--->阻止href跳转 -->href="javascript:;#moreDetail"就可以阻止访问了。