📄 logincommand.java
字号:
/*********************************************************************** * Copyright (c) 2000-2004 The Apache Software Foundation. * * All rights reserved. * * ------------------------------------------------------------------- * * 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.james.imapserver.commands;import org.apache.james.imapserver.AuthenticationException;import org.apache.james.imapserver.ImapRequest;import org.apache.james.imapserver.ImapSession;import org.apache.james.imapserver.ImapSessionState;import java.util.StringTokenizer;import java.util.List;class LoginCommand extends NonAuthenticatedStateCommand{ LoginCommand() { this.commandName = "LOGIN"; this.getArgs().add( new AstringArgument( "username" ) ); this.getArgs().add( new AstringArgument( "password" ) ); } protected boolean doProcess( ImapRequest request, ImapSession session, List argValues ) { String userName = (String) argValues.get(0); String password = (String) argValues.get(1); session.setCurrentUser( userName ); if ( session.getUsers().test( session.getCurrentUser(), password ) ) { session.getSecurityLogger().info( "Login successful for " + session.getCurrentUser() + " from " + session.getRemoteHost() + "(" + session.getRemoteIP() + ")" ); // four possibilites handled: // private mail: isLocal, is Remote // other mail (shared, news, etc.) is Local, is Remote if ( session.getImapHost().isHomeServer( session.getCurrentUser() ) ) { session.okResponse( request.getCommand() ); session.setState( ImapSessionState.AUTHENTICATED ); } else { String remoteServer = null; try { remoteServer = session.getImapSystem().getHomeServer( session.getCurrentUser() ); } catch ( AuthenticationException ae ) { session.setConnectionClosed( session.closeConnection( TAGGED_NO, " cannot find your inbox, closing connection", "" ) ); return false; } if ( session.getImapHost().hasLocalAccess( session.getCurrentUser() ) ) { session.okResponse( "[REFERRAL " + remoteServer + "]" + SP + "Your home server is remote, other mailboxes available here" ); session.setState( ImapSessionState.AUTHENTICATED ); } else { session.closeConnection( TAGGED_NO, " [REFERRAL" + SP + remoteServer + "]" + SP + "No mailboxes available here, try remote server", "" ); return false; } } session.setCurrentNamespace( session.getImapHost().getDefaultNamespace( session.getCurrentUser() ) ); session.setCurrentSeperator( session.getImapSystem().getHierarchySeperator( session.getCurrentNamespace() ) ); // position at root of default Namespace, // which is not actually a folder session.setCurrentFolder( session.getCurrentNamespace() + session.getCurrentSeperator() + "" ); getLogger().debug( "Current folder for user " + session.getCurrentUser() + " from " + session.getRemoteHost() + "(" + session.getRemoteIP() + ") is " + session.getCurrentFolder() ); return true; } // failed password test // We should add ability to monitor attempts to login session.noResponse( request.getCommand() ); session.getSecurityLogger().error( "Failed attempt to use Login command for account " + session.getCurrentUser() + " from " + session.getRemoteHost() + "(" + session.getRemoteIP() + ")" ); return true; }}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -