ttomcat-1778514358873.zip-extract/apache-tomcat-11.0.18-src/java/org/apache/catalina/session/FileStore.java

Path
ttomcat-1778514358873.zip-extract/apache-tomcat-11.0.18-src/java/org/apache/catalina/session/FileStore.java
Status
scanned
Type
file
Name
FileStore.java
Extension
.java
Programming language
Java
Mime type
text/plain
File type
ASCII text, with CRLF line terminators
Tag

      
    
Rootfs path

      
    
Size
11099 (10.8 KB)
MD5
6ae43e16221ff31dd263a11ecd5b892c
SHA1
e846b2be27ff939522f556d5102234de4b040cb2
SHA256
6152b73dceaf3e2d215c31c0153d06add6b8dcce856877944817f71b5837e7a7
SHA512

      
    
SHA1_git
57e256952ff651b30459246f0810ecc35cab3383
Is binary

      
    
Is text
True
Is archive

      
    
Is media

      
    
Is legal

      
    
Is manifest

      
    
Is readme

      
    
Is top level

      
    
Is key file

      
    
FileStore.java | 10.8 KB |

/* * 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.catalina.session; import java.io.BufferedOutputStream; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; import java.io.ObjectInputStream; import java.io.ObjectOutputStream; import java.util.ArrayList; import java.util.List; import java.util.concurrent.locks.Lock; import jakarta.servlet.ServletContext; import org.apache.catalina.Context; import org.apache.catalina.Session; import org.apache.juli.logging.Log; import org.apache.juli.logging.LogFactory; import org.apache.tomcat.util.concurrent.KeyedReentrantReadWriteLock; import org.apache.tomcat.util.res.StringManager; /** * Concrete implementation of the <b>Store</b> interface that utilizes a file per saved Session in a configured * directory. Sessions that are saved are still subject to being expired based on inactivity. */ public final class FileStore extends StoreBase { private static final Log log = LogFactory.getLog(FileStore.class); private static final StringManager sm = StringManager.getManager(FileStore.class); // ----------------------------------------------------- Constants /** * The extension to use for serialized session filenames. */ private static final String FILE_EXT = ".session"; // ----------------------------------------------------- Instance Variables /** * The pathname of the directory in which Sessions are stored. This may be an absolute pathname, or a relative path * that is resolved against the temporary work directory for this application. */ private volatile String directory = "."; /** * A File representing the directory in which Sessions are stored. */ private File directoryFile = null; private KeyedReentrantReadWriteLock sessionLocksById = new KeyedReentrantReadWriteLock(); /** * Name to register for this Store, used for logging. */ private static final String storeName = "fileStore"; /** * Name to register for the background thread. */ private static final String threadName = "FileStore"; // ------------------------------------------------------------- Properties /** * @return The directory path for this Store. */ public String getDirectory() { return directory; } /** * Set the directory path for this Store. * * @param path The new directory path */ public synchronized void setDirectory(String path) { String oldDirectory = this.directory; this.directory = path; this.directoryFile = null; support.firePropertyChange("directory", oldDirectory, this.directory); } /** * @return The thread name for this Store. */ public String getThreadName() { return threadName; } @Override public String getStoreName() { return storeName; } @Override public int getSize() throws IOException { // Acquire the list of files in our storage directory File dir = directory(); if (dir == null) { return 0; } String[] files = dir.list(); // Figure out which files are sessions int keycount = 0; if (files != null) { for (String file : files) { if (file.endsWith(FILE_EXT)) { keycount++; } } } return keycount; } // --------------------------------------------------------- Public Methods @Override public void clear() throws IOException { String[] keys = keys(); for (String key : keys) { remove(key); } } @Override public String[] keys() throws IOException { // Acquire the list of files in our storage directory File dir = directory(); if (dir == null) { return new String[0]; } String[] files = dir.list(); // Bugzilla 32130 if (files == null || files.length < 1) { return new String[0]; } // Build and return the list of session identifiers List<String> list = new ArrayList<>(); int n = FILE_EXT.length(); for (String file : files) { if (file.endsWith(FILE_EXT)) { list.add(file.substring(0, file.length() - n)); } } return list.toArray(new String[0]); } @Override public Session load(String id) throws ClassNotFoundException, IOException { // Open an input stream to the specified pathname, if any File file = file(id); if (file == null) { return null; } Context context = getManager().getContext(); Log contextLog = context.getLogger(); if (contextLog.isTraceEnabled()) { contextLog.trace(sm.getString(getStoreName() + ".loading", id, file.getAbsolutePath())); } ClassLoader oldThreadContextCL = context.bind(null); try { Lock readLock = sessionLocksById.getLock(id).readLock(); readLock.lock(); try { if (!file.exists()) { return null; } try (FileInputStream fis = new FileInputStream(file.getAbsolutePath()); ObjectInputStream ois = getObjectInputStream(fis)) { StandardSession session = (StandardSession) manager.createEmptySession(); session.readObjectData(ois); session.setManager(manager); return session; } catch (FileNotFoundException e) { if (contextLog.isDebugEnabled()) { contextLog.debug(sm.getString("fileStore.noFile", id, file.getAbsolutePath()), e); } return null; } } finally { readLock.unlock(); } } finally { context.unbind(oldThreadContextCL); } } @Override public void remove(String id) throws IOException { File file = file(id); if (file == null) { return; } if (manager.getContext().getLogger().isTraceEnabled()) { manager.getContext().getLogger() .trace(sm.getString(getStoreName() + ".removing", id, file.getAbsolutePath())); } Lock writeLock = sessionLocksById.getLock(id).writeLock(); writeLock.lock(); try { if (file.exists() && !file.delete()) { throw new IOException(sm.getString("fileStore.deleteSessionFailed", file)); } } finally { writeLock.unlock(); } } @Override public void save(Session session) throws IOException { // Open an output stream to the specified pathname, if any File file = file(session.getIdInternal()); if (file == null) { return; } if (manager.getContext().getLogger().isTraceEnabled()) { manager.getContext().getLogger() .trace(sm.getString(getStoreName() + ".saving", session.getIdInternal(), file.getAbsolutePath())); } Lock writeLock = sessionLocksById.getLock(session.getIdInternal()).writeLock(); writeLock.lock(); try { try (FileOutputStream fos = new FileOutputStream(file.getAbsolutePath()); ObjectOutputStream oos = new ObjectOutputStream(new BufferedOutputStream(fos))) { ((StandardSession) session).writeObjectData(oos); } } finally { writeLock.unlock(); } } // -------------------------------------------------------- Private Methods /** * Return a File object representing the pathname to our session persistence directory, if any. The directory will * be created if it does not already exist. */ private synchronized File directory() throws IOException { // Synchronised to avoid concurrent attempts to create the directory. if (this.directory == null) { return null; } if (this.directoryFile != null) { return this.directoryFile; } File file = new File(this.directory); if (!file.isAbsolute()) { Context context = manager.getContext(); ServletContext servletContext = context.getServletContext(); File work = (File) servletContext.getAttribute(ServletContext.TEMPDIR); file = new File(work, this.directory); } if (!file.exists() || !file.isDirectory()) { if (!file.delete() && file.exists()) { throw new IOException(sm.getString("fileStore.deleteFailed", file)); } if (!file.mkdirs() && !file.isDirectory()) { throw new IOException(sm.getString("fileStore.createFailed", file)); } } this.directoryFile = file; return file; } /** * Return a File object representing the pathname to our session persistence file, if any. * * @param id The ID of the Session to be retrieved. This is used in the file naming. */ private File file(String id) throws IOException { File storageDir = directory(); if (storageDir == null) { return null; } String filename = id + FILE_EXT; File file = new File(storageDir, filename); File canonicalFile = file.getCanonicalFile(); // Check the file is within the storage directory if (!canonicalFile.toPath().startsWith(storageDir.getCanonicalFile().toPath())) { log.warn(sm.getString("fileStore.invalid", file.getPath(), id)); return null; } return canonicalFile; } }
Detected license expression
apache-2.0
Detected license expression (SPDX)
Apache-2.0
Percentage of license text
11.53
Copyrights

      
    
Holders

      
    
Authors

      
    
License detections License expression License expression SPDX
apache_2_0-4bde3f57-78aa-4201-96bf-531cba09e7de apache-2.0 Apache-2.0
URL Start line End line
http://www.apache.org/licenses/LICENSE-2.0 9 9