-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathLogController.java
More file actions
66 lines (53 loc) · 1.68 KB
/
LogController.java
File metadata and controls
66 lines (53 loc) · 1.68 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
package controller;
import java.io.File;
import java.text.SimpleDateFormat;
import java.time.LocalDate;
import java.util.Date;
import java.util.logging.FileHandler;
import java.util.logging.Level;
import java.util.logging.LogRecord;
import java.util.logging.Logger;
import java.util.logging.SimpleFormatter;
public class LogController {
private Logger logger;
public LogController() throws Exception {
checkLogLocation();
SimpleDateFormat formatter = new SimpleDateFormat("yyyyMMdd_HHmmss");
logger = Logger.getLogger("XMLGenerator");
logger.setUseParentHandlers(false);
FileHandler fh = new FileHandler("log\\log_" + formatter.format(new Date()) + ".log");
logger.addHandler(fh);
fh.setFormatter(new SimpleFormatter() {
private static final String format = "[%1$tF %1$tT] [%2$-7s] %3$s %n";
@Override
public synchronized String format(LogRecord lr) {
return String.format(format,
new Date(lr.getMillis()),
lr.getLevel().getLocalizedName(),
lr.getMessage()
);
}
});
}
private void checkLogLocation() {
File directory = new File("Log");
if (! directory.exists()){
directory.mkdir();
}
}
public void writeInfoLog(String text) {
logger.log(Level.INFO, text);
writeConsole(text);
}
public void writeWarningLog(String text) {
logger.log(Level.WARNING, text);
writeConsole(text);
}
public void writeErrorLog(String text) {
logger.log(Level.SEVERE, text);
writeConsole(text);
}
public void writeConsole(String text) {
System.out.println(LocalDate.now() + " - " + text);
}
}