国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Java > 正文

在Java的Struts中判斷是否調用AJAX及用攔截器對其優化

2019-11-26 14:41:16
字體:
來源:轉載
供稿:網友

Strut2判斷是否是AJAX調用
1.   AJAX與傳統Form表單
實際上,兩者一般都是通過HTTP的POST請求。區別是瀏覽器提交Form表單后,期望服務器返回一個完整的HTML頁面。而AJAX調用是由XMLHttpRequest對象(不同瀏覽器可能不一樣)發出,瀏覽器期望服務器返回HTML片段即可,具體是JSON、XML等都沒有要求。返回到瀏覽器后如何使用,也是由JS腳本自己決定的。
 
2. 請求是不是AJAX
那么對于服務器端,如何判斷一個HTTP請求是不是AJAX調用?這需要看HTTP的Header。
 
我們可以通過Header中的x-request-with來判斷。盡管不同瀏覽器發送AJAX請求的對象不同,但是如果使用jQuery發送AJAX請求的話,jQuery內部實現ajax的時候,已經加入了標識。jQuery源碼中是這樣的:xhr.setRequestHeader("X-Requested-With","XMLHttpRequest");
所以,如果項目的前臺頁面都是通過jQuery發送AJAX請求的話,這樣判斷是安全的。
 
下面是HTTP請求攜帶的Header信息。
 
普通Form表單提交

===MimeHeaders ===accept = */*referer =http://localhost:8080/user2/toQueryPage.actionaccept-language = zh-CNuser-agent = Mozilla/4.0 (compatible; MSIE8.0; Windows NT 6.1; WOW64; Trident/4.0; SLCC2; .NET CLR 2.0.50727; .NET CLR3.5.30729; .NET CLR 3.0.30729; Media Center PC 6.0; InfoPath.3; .NET4.0C;.NET4.0E)accept-encoding = gzip, deflatehost = localhost:8080connection = Keep-Alivecache-control = no-cache

 
AJAX調用(IE)

===MimeHeaders ===x-requested-with = XMLHttpRequestaccept-language = zh-cnreferer =http://localhost:8080/user2/toQueryPage.actionaccept = application/json, text/javascript,*/*; q=0.01content-type =application/x-www-form-urlencodedaccept-encoding = gzip, deflateuser-agent = Mozilla/4.0 (compatible; MSIE8.0; Windows NT 6.1; WOW64; Trident/4.0; SLCC2; .NET CLR 2.0.50727; .NET CLR3.5.30729; .NET CLR 3.0.30729; Media Center PC 6.0; InfoPath.3; .NET4.0C;.NET4.0E)host = localhost:8080content-length = 57connection = Keep-Alivecache-control = no-cache

 
3.   在Action中獲得HTTP請求頭
在Action類中,通過ServletRequestAware接口獲得HttpServletRequest對象,再通過getHeader方法得到我們想要的頭信息。

public abstract class BaseAction     <ParamVo extends BaseParamVo, ResultVo extends BaseResultVo>       extends ActionSupport         implements ServletRequestAware {      private static final String AJAX_RESULT_NAME = "ajaxResult";   private static final String XHR_OBJECT_NAME = "XMLHttpRequest";   private static final String HEADER_REQUEST_WITH = "x-requested-with";      /**    * Request對象,用來判斷請求是否是AJAX調用    */   private HttpServletRequest request;      private ParamVo paramVo;      private ResultVo resultVo;      @Override   public String execute() {     String resultPage = SUCCESS;     try {       resultVo = doExecute(paramVo);     }     catch (BaseException e) {       resultPage = ERROR;     }          if (XHR_OBJECT_NAME.equals(request.getHeader(HEADER_REQUEST_WITH))) {       resultPage = AJAX_RESULT_NAME;     }          return resultPage;   } } 

 Struts2性能調優攔截器
當我們在工作中需要實現某些小需求時,不妨先進行下簡單的調研,看看正在使用的開源框架是否已經具備了我們需要的功能,這樣就不用重復發明輪子了。
 下面以性能測試為例,看看如何調查Struts2框架是否具備這種功能。

1.   struts-default.xml

因為Struts2的許多核心功能都是基于內部攔截器來實現的,所以我們首先要看看它是否有性能調優相關的攔截器。這就需要查看strut2-core-2.3.1.2.jar中的默認配置文件struts-default.xml了。

<span style="white-space:pre"> </span><interceptor name="alias" class="com.opensymphony.xwork2.interceptor.AliasInterceptor"/>       <interceptor name="autowiring" class="com.opensymphony.xwork2.spring.interceptor.ActionAutowiringInterceptor"/>       <interceptor name="chain" class="com.opensymphony.xwork2.interceptor.ChainingInterceptor"/>       <interceptor name="conversionError" class="org.apache.struts2.interceptor.StrutsConversionErrorInterceptor"/>       <interceptor name="cookie" class="org.apache.struts2.interceptor.CookieInterceptor"/>       <interceptor name="clearSession" class="org.apache.struts2.interceptor.ClearSessionInterceptor" />       <interceptor name="createSession" class="org.apache.struts2.interceptor.CreateSessionInterceptor" />       <interceptor name="debugging" class="org.apache.struts2.interceptor.debugging.DebuggingInterceptor" />       <interceptor name="execAndWait" class="org.apache.struts2.interceptor.ExecuteAndWaitInterceptor"/>       <interceptornameinterceptorname="exception" class="com.opensymphony.xwork2.interceptor.ExceptionMappingInterceptor"/>       <interceptor name="fileUpload" class="org.apache.struts2.interceptor.FileUploadInterceptor"/>       <interceptor name="i18n" class="com.opensymphony.xwork2.interceptor.I18nInterceptor"/>       <interceptor name="logger" class="com.opensymphony.xwork2.interceptor.LoggingInterceptor"/>       <interceptor name="modelDriven" class="com.opensymphony.xwork2.interceptor.ModelDrivenInterceptor"/>       <interceptor name="scopedModelDriven" class="com.opensymphony.xwork2.interceptor.ScopedModelDrivenInterceptor"/>       <interceptor name="params" class="com.opensymphony.xwork2.interceptor.ParametersInterceptor"/>       <interceptor name="actionMappingParams" class="org.apache.struts2.interceptor.ActionMappingParametersInteceptor"/>       <interceptor name="prepare" class="com.opensymphony.xwork2.interceptor.PrepareInterceptor"/>       <interceptor name="staticParams" class="com.opensymphony.xwork2.interceptor.StaticParametersInterceptor"/>       <interceptor name="scope" class="org.apache.struts2.interceptor.ScopeInterceptor"/>       <interceptor name="servletConfig" class="org.apache.struts2.interceptor.ServletConfigInterceptor"/>       <interceptor name="timer" class="com.opensymphony.xwork2.interceptor.TimerInterceptor"/>       <interceptor name="token" class="org.apache.struts2.interceptor.TokenInterceptor"/>       <interceptor name="tokenSession" class="org.apache.struts2.interceptor.TokenSessionStoreInterceptor"/>       <interceptor name="validation" class="org.apache.struts2.interceptor.validation.AnnotationValidationInterceptor"/>       <interceptor name="workflow" class="com.opensymphony.xwork2.interceptor.DefaultWorkflowInterceptor"/>       <interceptor name="store" class="org.apache.struts2.interceptor.MessageStoreInterceptor" />       <interceptor name="checkbox" class="org.apache.struts2.interceptor.CheckboxInterceptor" />       <interceptor name="profiling" class="org.apache.struts2.interceptor.ProfilingActivationInterceptor" />       <interceptor name="roles" class="org.apache.struts2.interceptor.RolesInterceptor" />       <interceptor name="annotationWorkflow" class="com.opensymphony.xwork2.interceptor.annotations.AnnotationWorkflowInterceptor" />       <interceptor name="multiselect" class="org.apache.struts2.interceptor.MultiselectInterceptor" /> 

Struts2像個百寶箱一樣內置了很多攔截器,可以看到profiling很可能就是符合我們需求的攔截器,那現在就打開源碼一探究竟。
 
2.   ProfilingActivationInterceptor

org.apache.struts2.interceptor.ProfilingActivationInterceptor.java

public class ProfilingActivationInterceptor extendsAbstractInterceptor {     private String profilingKey = "profiling";   private boolean devMode;      @Inject(StrutsConstants.STRUTS_DEVMODE)   public void setDevMode(String mode) {     this.devMode = "true".equals(mode);   }     @Override   public String intercept(ActionInvocationinvocation) throws Exception {     if (devMode) {       Object val =invocation.getInvocationContext().getParameters().get(profilingKey);       if (val != null) {         String sval = (val instanceof String ?(String)val : ((String[])val)[0]);         boolean enable = "yes".equalsIgnoreCase(sval)|| "true".equalsIgnoreCase(sval);         UtilTimerStack.setActive(enable);         invocation.getInvocationContext().getParameters().remove(profilingKey);       }     }     return invocation.invoke();     }   } 

 
從源碼中可以看到,只要瀏覽器發過來的HTTP請求參數中包含profiling=true或者yes,性能攔截器就會開啟Timer工具類,打印出Action的執行消耗時間。

3.   struts.xml

因為profiling攔截器沒有包含到默認的defaultStack中,所以我們要先將它追加到我們自定義的攔截器棧中。

<package name="ajax-default" extends="velocity-default">     <result-types>       <result-type name="json" class="org.apache.struts2.json.JSONResult"/>     </result-types>          <interceptors>       <interceptor-stacknameinterceptor-stackname="ajaxInterceptorStack">       <interceptor-refnameinterceptor-refname="defaultStack" />       <interceptor-ref name="profiling"/>       </interceptor-stack>     </interceptors>          <default-interceptor-refnamedefault-interceptor-refname="ajaxInterceptorStack" />          <global-results>       <result name="comAjaxResult" type="json">         <param name="excludeNullProperties">true</param>         <param name="root">result</param>         <param name="ignoreHierarchy">false</param>       </result>     </global-results>   </package> 

4.   userview.js

現在就可以修改AJAX調用參數,追加上profiling參數就可以開始性能調優了。

function searchAllUser(){   jQuery.ajax({     type:"post",     url: "searchAllUser.action",     processData:true,     dataType:'json',     data:jQuery("#userQueryForm").serialize() + "&profiling=yes",     success:function(data) {     if (data.status == 1) {        alert("創建成功");        generateTableFromJson("result", data.resultRows);     } else {        alert("創建失敗");     }     }   }); } 

 
5.   最終效果
 
打印結果就是下面這樣。除了總執行時間外,Action方法的執行時間和Result的渲染時間都會分別列出。

201611385424070.png (411×59)

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 台中市| 安平县| 正宁县| 大方县| 同德县| 清水县| 扶沟县| 洪泽县| 南岸区| 民丰县| 灵寿县| 石阡县| 台山市| 沈丘县| 凌海市| 长治县| 深水埗区| 阿拉尔市| 九江县| 平顺县| 巢湖市| 安多县| 都昌县| 保康县| 娄底市| 呼伦贝尔市| 孟村| 荆门市| 开远市| 晴隆县| 阳新县| 湖口县| 江源县| 布尔津县| 呼和浩特市| 闽清县| 和政县| 类乌齐县| 双峰县| 宜宾县| 高雄县|