requestblockinghandler.java
来自「开源的axis2框架的源码。用于开发WEBSERVER」· Java 代码 · 共 104 行
JAVA
104 行
/* * Copyright 2004,2005 The Apache Software Foundation. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */package org.apache.axis2.clustering;import org.apache.axis2.handlers.AbstractHandler;import org.apache.axis2.context.MessageContext;import org.apache.axis2.context.ConfigurationContext;import org.apache.axis2.AxisFault;import org.apache.axis2.description.AxisServiceGroup;import org.apache.axis2.description.Parameter;import org.apache.axis2.description.AxisService;import org.apache.axis2.description.HandlerDescription;/** * */public class RequestBlockingHandler extends AbstractHandler { public InvocationResponse invoke(MessageContext msgContext) throws AxisFault { // Handle blocking at gobal level ConfigurationContext cfgCtx = msgContext.getConfigurationContext(); Boolean isBlockingAllRequests = (Boolean) cfgCtx.getProperty(ClusteringConstants.BLOCK_ALL_REQUESTS); AxisServiceGroup serviceGroup = msgContext.getAxisServiceGroup(); // Handle blocking at service group level Boolean isBlockingServiceGroupRequests = Boolean.FALSE; if (serviceGroup != null) { Parameter blockingParam = serviceGroup.getParameter(ClusteringConstants.BLOCK_ALL_REQUESTS); if (blockingParam != null) { isBlockingServiceGroupRequests = (Boolean) blockingParam.getValue(); } } // Handle blocking at service level AxisService service = msgContext.getAxisService(); Boolean isBlockingServiceRequests = Boolean.FALSE; if (service != null) { Parameter blockingParam = service.getParameter(ClusteringConstants.BLOCK_ALL_REQUESTS); if (blockingParam != null) { isBlockingServiceRequests = (Boolean) blockingParam.getValue(); } } if (isBlockingAllRequests != null && isBlockingAllRequests.booleanValue()) { // Allow only NodeManager service commit requests to pass through. Block all others AxisService axisService = msgContext.getAxisService(); if (!axisService.getName().equals(ClusteringConstants.NODE_MANAGER_SERVICE)) { if (!msgContext.getAxisOperation().getName().equals("commit")) { throw new AxisFault("System is being reinitialized. " + "Please try again in a few seconds."); } else { throw new AxisFault("NodeManager service cannot call any other " + "operation after calling prepare"); } } } else if (isBlockingServiceGroupRequests.booleanValue()) { throw new AxisFault("This service group is being initialized or unloaded. " + "Please try again in a few seconds."); } else if (isBlockingServiceRequests.booleanValue()) { throw new AxisFault("This service is being initialized. " + "Please try again in a few seconds."); } return InvocationResponse.CONTINUE; } public boolean equals(Object obj) { if(obj instanceof RequestBlockingHandler){ RequestBlockingHandler that = (RequestBlockingHandler) obj; HandlerDescription thisDesc = this.getHandlerDesc(); HandlerDescription thatDesc = that.getHandlerDesc(); if(thisDesc != null && thatDesc != null && thisDesc.getName().equals(thatDesc.getName())){ return true; } } return false; } public int hashCode() { if(this.handlerDesc != null){ return this.handlerDesc.hashCode(); } return super.hashCode(); }}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?