⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 snmpmsgprocessingmodel.java

📁 Mobile 应用程序使用 Java Micro Edition (Java ME) 平台
💻 JAVA
字号:
/* * @(#)file      SnmpMsgProcessingModel.java * @(#)author    Sun Microsystems, Inc. * @(#)version   1.20 * @(#)date      08/09/12 * * Copyright 2006 Sun Microsystems, Inc. All rights reserved. * SUN PROPRIETARY/CONFIDENTIAL. Use is subject to license terms. * */package com.sun.jmx.snmp.internal;import com.sun.jmx.snmp.mpm.SnmpMsgTranslator;import com.sun.jmx.snmp.SnmpTooBigException;import com.sun.jmx.snmp.SnmpStatusException;import com.sun.jmx.snmp.SnmpPdu;import com.sun.jmx.snmp.SnmpPduFactory;import com.sun.jmx.snmp.SnmpSecurityParameters;import com.sun.jmx.snmp.SnmpParams;/** * The message processing model interface. Any message processing model must implement this interface in order to be integrated in the engine framework. * The model is called by the dispatcher when a call is received or when a call is sent. * <p><b>This API is a Sun Microsystems internal API  and is subject  * to change without notice.</b></p> * @since 1.5 */public interface SnmpMsgProcessingModel extends SnmpModel {    /**     * This method is called when a call is to be sent to the network.     * @param factory The pdu factory to use to encode and decode pdu.     * @return The object that will handle every steps of the sending (mainly marshalling and security).     */    public SnmpOutgoingRequest getOutgoingRequest(SnmpPduFactory factory);    /**     * This method is called when a call is received from the network.     * @param factory The pdu factory to use to encode and decode pdu.     * @return The object that will handle every steps of the receiving (mainly unmarshalling and security).     */    public SnmpIncomingRequest getIncomingRequest(SnmpPduFactory factory);         /**     * This method is called when a response is received from the network.     * @param factory The pdu factory to use to encode and decode pdu.     * @return The object that will handle every steps of the receiving (mainly unmarshalling and security).     */    public SnmpIncomingResponse getIncomingResponse(SnmpPduFactory factory);    /**     * This method is called to instantiate a pdu according to the passed pdu type and parameters.      * @param p The request parameters.     * @param type The pdu type.     * @return The pdu.     */    public SnmpPdu getRequestPdu(SnmpParams p, int type) throws SnmpStatusException;    /**     * This method is called to encode a full scoped pdu that has not been encrypted. <CODE>contextName</CODE>, <CODE>contextEngineID</CODE> and data are known.     * <BR>The specified parameters are defined in RFC 2572 (see also the {@link com.sun.jmx.snmp.SnmpV3Message} class).     * @param version The SNMP protocol version.     * @param msgID The SNMP message ID.     * @param msgMaxSize The max message size.     * @param msgFlags The message flags.     * @param msgSecurityModel The message security model.     * @param params The security parameters.     * @param contextEngineID The context engine ID.     * @param contextName The context name.     * @param data The encoded data.     * @param dataLength The encoded data length.     * @param outputBytes The buffer containing the encoded message.     * @return The encoded bytes number.     */    public int encode(int version,		      int msgID,		      int msgMaxSize,		      byte msgFlags,		      int msgSecurityModel,		      SnmpSecurityParameters params,		      byte[] contextEngineID,		      byte[] contextName,		      byte[] data,		      int dataLength,		      byte[] outputBytes) throws SnmpTooBigException;    /**     * This method is called to encode a full scoped pdu that as been encrypted. <CODE>contextName</CODE>, <CODE>contextEngineID</CODE> and data are known.     * <BR>The specified parameters are defined in RFC 2572 (see also the {@link com.sun.jmx.snmp.SnmpV3Message} class).     * @param version The SNMP protocol version.     * @param msgID The SNMP message ID.     * @param msgMaxSize The max message size.     * @param msgFlags The message flags.     * @param msgSecurityModel The message security model.     * @param params The security parameters.     * @param encryptedPdu The encrypted pdu.     * @param outputBytes The buffer containing the encoded message.     * @return The encoded bytes number.     */    public int encodePriv(int version,			  int msgID,			  int msgMaxSize,			  byte msgFlags,			  int msgSecurityModel,			  SnmpSecurityParameters params,			  byte[] encryptedPdu,			  byte[] outputBytes) throws SnmpTooBigException;     /**     * This method returns a decoded scoped pdu. This method decodes only the <CODE>contextEngineID</CODE>, <CODE>contextName</CODE> and data. It is needed by the <CODE>SnmpSecurityModel</CODE> after decryption.     * @param pdu The encoded pdu.     * @return The partialy scoped pdu.     */    public SnmpDecryptedPdu decode(byte[] pdu) throws SnmpStatusException;        /**     * This method returns an encoded scoped pdu. This method encode only the <CODE>contextEngineID</CODE>, <CODE>contextName</CODE> and data. It is needed by the <CODE>SnmpSecurityModel</CODE> for decryption.     * @param pdu The pdu to encode.     * @param outputBytes The partialy scoped pdu.     * @return The encoded bytes number.     */    public int encode(SnmpDecryptedPdu pdu,		      byte[] outputBytes) throws SnmpTooBigException;    /**     * In order to change the behavior of the translator, set it.     * @param translator The translator that will be used.     */    public void setMsgTranslator(SnmpMsgTranslator translator);    /**     * Returns the current translator.     * @return The current translator.     */    public SnmpMsgTranslator getMsgTranslator();}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -