1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17 package org.apache.logging.log4j.core.helpers;
18
19 import org.apache.logging.log4j.Logger;
20 import org.apache.logging.log4j.status.StatusLogger;
21
22 import java.io.File;
23 import java.io.UnsupportedEncodingException;
24 import java.net.MalformedURLException;
25 import java.net.URI;
26 import java.net.URL;
27 import java.net.URLDecoder;
28
29
30
31
32 public final class FileUtils {
33
34
35 private static final String PROTOCOL_FILE = "file";
36
37 private static final String JBOSS_FILE = "vfsfile";
38
39 private static final Logger logger = StatusLogger.getLogger();
40
41 private FileUtils() {
42 }
43
44
45
46
47
48
49
50
51 public static File fileFromURI(URI uri) {
52 if (uri == null || (uri.getScheme() != null &&
53 (!PROTOCOL_FILE.equals(uri.getScheme()) && !JBOSS_FILE.equals(uri.getScheme())))) {
54 return null;
55 } else {
56 if (uri.getScheme() == null) {
57 try {
58 uri = new File(uri.getPath()).toURI();
59 } catch (Exception ex) {
60 logger.warn("Invalid URI " + uri);
61 return null;
62 }
63 }
64 try {
65 return new File(URLDecoder.decode(uri.toURL().getFile(), "UTF8"));
66 } catch (MalformedURLException ex) {
67 logger.warn("Invalid URL " + uri, ex);
68 } catch (UnsupportedEncodingException uee) {
69 logger.warn("Invalid encoding: UTF8", uee);
70 }
71 return null;
72 }
73 }
74
75 public static boolean isFile(URL url) {
76 return url != null && (url.getProtocol().equals(PROTOCOL_FILE) || url.getProtocol().equals(JBOSS_FILE));
77 }
78 }