com.gargoylesoftware.htmlunit.attachment.Attachment Maven / Gradle / Ivy
/*
* Copyright (c) 2002-2008 Gargoyle Software Inc.
*
* 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 com.gargoylesoftware.htmlunit.attachment;
import com.gargoylesoftware.htmlunit.Page;
import com.gargoylesoftware.htmlunit.WebResponse;
/**
* An attachment represents a page received from the server which contains a
* {@code Content-Disposition=attachment} header.
*
* @version $Revision: 3132 $
* @author Bruce Chapman
* @author Sudhan Moghe
* @author Daniel Gredler
*/
public class Attachment {
/** The attached page. */
private final Page page_;
/**
* Creates a new attachment for the specified page.
* @param page the attached page
*/
public Attachment(final Page page) {
page_ = page;
}
/**
* Returns the attached page.
* @return the attached page
*/
public Page getPage() {
return page_;
}
/**
* Returns the attachment's filename, as suggested by the Content-Disposition
* header, or null if no filename was suggested.
* @return the attachment's suggested filename, or null if none was suggested
*/
public String getSuggestedFilename() {
final WebResponse response = page_.getWebResponse();
final String disp = response.getResponseHeaderValue("Content-Disposition");
int start = disp.indexOf("filename=");
if (start == -1) {
return null;
}
start += "filename=".length();
int end = disp.indexOf(";", start);
if (end == -1) {
end = disp.length();
}
if (disp.charAt(start) == '"' && disp.charAt(end - 1) == '"') {
start++;
end--;
}
return disp.substring(start, end);
}
/**
* Returns true if the specified response represents an attachment.
* @param response the response to check
* @return true if the specified response represents an attachment, false otherwise
* @see RFC 2183
*/
public static boolean isAttachment(final WebResponse response) {
final String disp = response.getResponseHeaderValue("Content-Disposition");
if (disp == null) {
return false;
}
return disp.startsWith("attachment");
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy