stor.java

来自「JAVA FTP 上传下载 的源文件」· Java 代码 · 共 196 行

JAVA
196
字号
/* * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements.  See the NOTICE file * distributed with this work for additional information * regarding copyright ownership.  The ASF licenses this file * to you 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.ftpserver.command.impl;import java.io.IOException;import java.io.OutputStream;import java.net.InetAddress;import java.net.SocketException;import org.apache.ftpserver.command.AbstractCommand;import org.apache.ftpserver.ftplet.DataConnection;import org.apache.ftpserver.ftplet.DataConnectionFactory;import org.apache.ftpserver.ftplet.DefaultFtpReply;import org.apache.ftpserver.ftplet.FtpException;import org.apache.ftpserver.ftplet.FtpFile;import org.apache.ftpserver.ftplet.FtpReply;import org.apache.ftpserver.ftplet.FtpRequest;import org.apache.ftpserver.impl.FtpIoSession;import org.apache.ftpserver.impl.FtpServerContext;import org.apache.ftpserver.impl.IODataConnectionFactory;import org.apache.ftpserver.impl.LocalizedFtpReply;import org.apache.ftpserver.impl.ServerFtpStatistics;import org.apache.ftpserver.util.IoUtils;import org.slf4j.Logger;import org.slf4j.LoggerFactory;/** * <strong>Internal class, do not use directly.</strong> *  * <code>STOR &lt;SP&gt; &lt;pathname&gt; &lt;CRLF&gt;</code><br> *  * This command causes the server-DTP to accept the data transferred via the * data connection and to store the data as a file at the server site. If the * file specified in the pathname exists at the server site, then its contents * shall be replaced by the data being transferred. A new file is created at the * server site if the file specified in the pathname does not already exist. * * @author The Apache MINA Project (dev@mina.apache.org) * @version $Rev: 734241 $, $Date: 2009-01-13 22:05:31 +0100 (Tue, 13 Jan 2009) $ */public class STOR extends AbstractCommand {    private final Logger LOG = LoggerFactory.getLogger(STOR.class);    /**     * Execute command.     */    public void execute(final FtpIoSession session,            final FtpServerContext context, final FtpRequest request)            throws IOException, FtpException {        try {            // get state variable            long skipLen = session.getFileOffset();            // argument check            String fileName = request.getArgument();            if (fileName == null) {                session                        .write(LocalizedFtpReply                                .translate(                                        session,                                        request,                                        context,                                        FtpReply.REPLY_501_SYNTAX_ERROR_IN_PARAMETERS_OR_ARGUMENTS,                                        "STOR", null));                return;            }            // 24-10-2007 - added check if PORT or PASV is issued, see            // https://issues.apache.org/jira/browse/FTPSERVER-110            DataConnectionFactory connFactory = session.getDataConnection();            if (connFactory instanceof IODataConnectionFactory) {                InetAddress address = ((IODataConnectionFactory) connFactory)                        .getInetAddress();                if (address == null) {                    session.write(new DefaultFtpReply(                            FtpReply.REPLY_503_BAD_SEQUENCE_OF_COMMANDS,                            "PORT or PASV must be issued first"));                    return;                }            }            // get filename            FtpFile file = null;            try {                file = session.getFileSystemView().getFile(fileName);            } catch (Exception ex) {                LOG.debug("Exception getting file object", ex);            }            if (file == null) {                session.write(LocalizedFtpReply.translate(session, request, context,                        FtpReply.REPLY_550_REQUESTED_ACTION_NOT_TAKEN,                        "STOR.invalid", fileName));                return;            }            fileName = file.getAbsolutePath();            // get permission            if (!file.isWritable()) {                session.write(LocalizedFtpReply.translate(session, request, context,                        FtpReply.REPLY_550_REQUESTED_ACTION_NOT_TAKEN,                        "STOR.permission", fileName));                return;            }            // get data connection            session.write(                    LocalizedFtpReply.translate(session, request, context,                            FtpReply.REPLY_150_FILE_STATUS_OKAY, "STOR",                            fileName)).awaitUninterruptibly(10000);            DataConnection dataConnection;            try {                dataConnection = session.getDataConnection().openConnection();            } catch (Exception e) {                LOG.debug("Exception getting the input data stream", e);                session.write(LocalizedFtpReply.translate(session, request, context,                        FtpReply.REPLY_425_CANT_OPEN_DATA_CONNECTION, "STOR",                        fileName));                return;            }            // transfer data            boolean failure = false;            OutputStream outStream = null;            try {                outStream = file.createOutputStream(skipLen);                long transSz = dataConnection.transferFromClient(session.getFtpletSession(), outStream);                LOG.info("File uploaded {}", fileName);                // notify the statistics component                ServerFtpStatistics ftpStat = (ServerFtpStatistics) context                        .getFtpStatistics();                ftpStat.setUpload(session, file, transSz);                                // attempt to close the output stream so that errors in                 // closing it will return an error to the client (FTPSERVER-119)                 if(outStream != null) {                    outStream.close();                }            } catch (SocketException ex) {                LOG.debug("Socket exception during data transfer", ex);                failure = true;                session.write(LocalizedFtpReply.translate(session, request, context,                        FtpReply.REPLY_426_CONNECTION_CLOSED_TRANSFER_ABORTED,                        "STOR", fileName));            } catch (IOException ex) {                LOG.debug("IOException during data transfer", ex);                failure = true;                session                        .write(LocalizedFtpReply                                .translate(                                        session,                                        request,                                        context,                                        FtpReply.REPLY_551_REQUESTED_ACTION_ABORTED_PAGE_TYPE_UNKNOWN,                                        "STOR", fileName));            } finally {                // make sure we really close the output stream                IoUtils.close(outStream);            }            // if data transfer ok - send transfer complete message            if (!failure) {                session.write(LocalizedFtpReply.translate(session, request, context,                        FtpReply.REPLY_226_CLOSING_DATA_CONNECTION, "STOR",                        fileName));            }        } finally {            session.resetState();            session.getDataConnection().closeDataConnection();        }    }}

⌨️ 快捷键说明

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