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

📄 confirmationcallback.java

📁 Mobile 应用程序使用 Java Micro Edition (Java ME) 平台
💻 JAVA
📖 第 1 页 / 共 2 页
字号:
/* * @(#)ConfirmationCallback.java	1.17 05/11/17 * * Copyright 2006 Sun Microsystems, Inc. All rights reserved. * SUN PROPRIETARY/CONFIDENTIAL. Use is subject to license terms. */package javax.security.auth.callback;/** * <p> Underlying security services instantiate and pass a * <code>ConfirmationCallback</code> to the <code>handle</code> * method of a <code>CallbackHandler</code> to ask for YES/NO, * OK/CANCEL, YES/NO/CANCEL or other similar confirmations. * * @version 1.17, 11/17/05 * @see javax.security.auth.callback.CallbackHandler */public class ConfirmationCallback implements Callback, java.io.Serializable {    private static final long serialVersionUID = -9095656433782481624L;    /**     * Unspecified option type.     *     * <p> The <code>getOptionType</code> method returns this     * value if this <code>ConfirmationCallback</code> was instantiated     * with <code>options</code> instead of an <code>optionType</code>.     */    public static final int UNSPECIFIED_OPTION		= -1;    /**     * YES/NO confirmation option.     *     * <p> An underlying security service specifies this as the     * <code>optionType</code> to a <code>ConfirmationCallback</code>     * constructor if it requires a confirmation which can be answered     * with either <code>YES</code> or <code>NO</code>.     */    public static final int YES_NO_OPTION		= 0;    /**     * YES/NO/CANCEL confirmation confirmation option.     *     * <p> An underlying security service specifies this as the     * <code>optionType</code> to a <code>ConfirmationCallback</code>     * constructor if it requires a confirmation which can be answered     * with either <code>YES</code>, <code>NO</code> or <code>CANCEL</code>.     */    public static final int YES_NO_CANCEL_OPTION	= 1;    /**     * OK/CANCEL confirmation confirmation option.     *     * <p> An underlying security service specifies this as the     * <code>optionType</code> to a <code>ConfirmationCallback</code>     * constructor if it requires a confirmation which can be answered     * with either <code>OK</code> or <code>CANCEL</code>.     */    public static final int OK_CANCEL_OPTION		= 2;     /**     * YES option.     *     * <p> If an <code>optionType</code> was specified to this     * <code>ConfirmationCallback</code>, this option may be specified as a     * <code>defaultOption</code> or returned as the selected index.     */    public static final int YES				= 0;    /**     * NO option.     *     * <p> If an <code>optionType</code> was specified to this     * <code>ConfirmationCallback</code>, this option may be specified as a     * <code>defaultOption</code> or returned as the selected index.     */    public static final int NO				= 1;    /**     * CANCEL option.     *     * <p> If an <code>optionType</code> was specified to this     * <code>ConfirmationCallback</code>, this option may be specified as a     * <code>defaultOption</code> or returned as the selected index.     */    public static final int CANCEL			= 2;    /**     * OK option.     *     * <p> If an <code>optionType</code> was specified to this     * <code>ConfirmationCallback</code>, this option may be specified as a     * <code>defaultOption</code> or returned as the selected index.     */    public static final int OK				= 3;     /** INFORMATION message type.  */    public static final int INFORMATION			= 0;    /** WARNING message type. */    public static final int WARNING			= 1;    /** ERROR message type. */    public static final int ERROR			= 2;    /**     * @serial     * @since 1.4     */    private String prompt;    /**     * @serial     * @since 1.4     */    private int messageType;    /**     * @serial     * @since 1.4     */    private int optionType = UNSPECIFIED_OPTION;    /**     * @serial     * @since 1.4     */    private int defaultOption;    /**     * @serial     * @since 1.4     */    private String[] options;    /**     * @serial     * @since 1.4     */    private int selection;    /**     * Construct a <code>ConfirmationCallback</code> with a     * message type, an option type and a default option.     *     * <p> Underlying security services use this constructor if     * they require either a YES/NO, YES/NO/CANCEL or OK/CANCEL     * confirmation.     *     * <p>     *     * @param messageType the message type (<code>INFORMATION</code>,     *			<code>WARNING</code> or <code>ERROR</code>). <p>     *     * @param optionType the option type (<code>YES_NO_OPTION</code>,     *			<code>YES_NO_CANCEL_OPTION</code> or     *			<code>OK_CANCEL_OPTION</code>). <p>     *     * @param defaultOption the default option     *			from the provided optionType (<code>YES</code>,     *			<code>NO</code>, <code>CANCEL</code> or     *			<code>OK</code>).     *     * @exception IllegalArgumentException if messageType is not either     *			<code>INFORMATION</code>, <code>WARNING</code>,     *			or <code>ERROR</code>, if optionType is not either     *			<code>YES_NO_OPTION</code>,     *			<code>YES_NO_CANCEL_OPTION</code>, or     *			<code>OK_CANCEL_OPTION</code>,     *			or if <code>defaultOption</code>     *			does not correspond to one of the options in     *			<code>optionType</code>.     */    public ConfirmationCallback(int messageType,                int optionType, int defaultOption) {	if (messageType < INFORMATION || messageType > ERROR ||	    optionType < YES_NO_OPTION || optionType > OK_CANCEL_OPTION)	    throw new IllegalArgumentException();	switch (optionType) {	case YES_NO_OPTION:	    if (defaultOption != YES && defaultOption != NO)		throw new IllegalArgumentException();	    break;	case YES_NO_CANCEL_OPTION:	    if (defaultOption != YES && defaultOption != NO &&		defaultOption != CANCEL)		throw new IllegalArgumentException();	    break;	case OK_CANCEL_OPTION:	    if (defaultOption != OK && defaultOption != CANCEL)		throw new IllegalArgumentException();	    break;	}		 	this.messageType = messageType;	this.optionType = optionType;	this.defaultOption = defaultOption;    }    /**     * Construct a <code>ConfirmationCallback</code> with a     * message type, a list of options and a default option.     *     * <p> Underlying security services use this constructor if     * they require a confirmation different from the available preset     * confirmations provided (for example, CONTINUE/ABORT or STOP/GO).     * The confirmation options are listed in the <code>options</code> array,     * and are displayed by the <code>CallbackHandler</code> implementation     * in a manner consistent with the way preset options are displayed.     *     * <p>     *     * @param messageType the message type (<code>INFORMATION</code>,     *			<code>WARNING</code> or <code>ERROR</code>). <p>     *     * @param options the list of confirmation options. <p>     *     * @param defaultOption the default option, represented as an index     *			into the <code>options</code> array.     *     * @exception IllegalArgumentException if messageType is not either     *			<code>INFORMATION</code>, <code>WARNING</code>,     *			or <code>ERROR</code>, if <code>options</code> is null,     *			if <code>options</code> has a length of 0,     *			if any element from <code>options</code> is null,     *			if any element from <code>options</code>     *			has a length of 0, or if <code>defaultOption</code>     *			does not lie within the array boundaries of     *			<code>options</code>.     */    public ConfirmationCallback(int messageType,                String[] options, int defaultOption) {	if (messageType < INFORMATION || messageType > ERROR ||	    options == null || options.length == 0 ||	    defaultOption < 0 || defaultOption >= options.length)	    throw new IllegalArgumentException();	for (int i = 0; i < options.length; i++) {	    if (options[i] == null || options[i].length() == 0)		throw new IllegalArgumentException();	}		 	this.messageType = messageType;	this.options = options;	this.defaultOption = defaultOption;

⌨️ 快捷键说明

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