Build a directory browser with ColdFusion
By Pete Freitag
Most web servers have directory browsing disabled, but sometimes you want it to work for certain directories. Most web servers also allow you to setup specific settings for your directories for instance you could do it with an .htaccess
file on Apache. But if you don't have access to your web server, you can create a directory index pretty easily with ColdFusion's cfdirectory
tag.
I have whipped up a simple one you can use, just save the following code as index.cfm
in the directory where you want to see a file listing:
<!DOCTYPE html> <html> <head><title><cfoutput>#Replace(cgi.script_name, "index.cfm", "")#</cfoutput></title> <style type="text/css"> body,td { font-family: verdana; padding: 2px 0px 2px 0px; color:silver; } th { border-bottom: 1px solid silver;text-align:left;margin-bottom: 2px; color:black; } a.sort { text-decoration: none; color: silver; } a:hover { background-color: blue; color: white; } p { font-size: x-small; } </style> </head> <body> <cfparam name="url.sort" default="datelastmodified desc"> <cfdirectory directory="#ExpandPath("./")#" action="list" name="dir" sort="#url.sort#"> <table width="100%" cellpadding="0" cellspacing="0"> <tr> <th>Name <a href="?sort=name" class="sort" title="Sort By Name">∨</a></th> <th>Size (bytes) <a href="?sort=size" class="sort" title="Sort By Size">∨</a></th> <th>Last Modified <a href="?sort=datelastmodified+desc" class="sort" title="Sort By Date">∨</a></th> </tr> <cfoutput query="dir"> <cfif dir.name IS NOT "index.cfm"> <tr> <td><a href="#dir.name#">#dir.name#</a></td> <td>#dir.size#</td> <td>#dir.datelastmodified#</td> </tr> </cfif> </cfoutput> </table> <p>Directory Browser by <a href="https://www.petefreitag.com/">Pete Freitag</a></p> </body> </html>
You can see a slightly modified version of this script on the daily mashup archives page.
Build a directory browser with ColdFusion was first published on September 12, 2005.
If you like reading about coldfusion, cfml, cfdirectory, browse, or index then you might also like:
- Left and Right Accept Negative Counts
- URL Safe Base64 Encoding / Decoding in CFML
- Using Hashicorp Vault with ColdFusion
- CFML Left and Right Functions can Accept Negative Counts
The FuseGuard Web Application Firewall for ColdFusion & CFML is a high performance, customizable engine that blocks various attacks against your ColdFusion applications.
CFBreak
The weekly newsletter for the CFML Community
Comments
Any thoughts?
I get a 404 File not Found error when trying to access that file. But chances are if you don't ColdFusion installed. You can get it from Adobe.com
Apache does have a built in mechanism for directory browsing. See my apache cheat sheet for an example: http://www.petefreitag.com/cheatsheets/apache/
Thanks!
- J
P.S. Your link to your cheat sheet has a problem.
Thanks I allowed my CF server to process html files and just thru the script in there for when I'm doing testing and can't remember the directory for a file off the top of my head. It's a great help!
Many thanks for this post.
Do you know if it's possible to select a folder with CF?
I'm trying to implement a batch upload and processing module and I'd like the user to select a folder containing all the files that need to be uploaded, instead of either selecting each file one by one, or doing multiple upload.
After selecting the folder, I can easily use cfdirectory to list all the files and process each one. This is not a problem. I have tested the following with a hard-coded directory and it works great!
<cfdirectory directory="#variables.selectedDirectory#" action="list" name="qDir">
Now, I want to make it more dynamic, i.e. the #variables.selectedDirectory# would depend on which folder the user would select.
How can we do this in CF?
If you want to let the browser pick a folder then you need to use Flash, or another method.