source: trunk/EventBenchConsole/src/de/ugoe/cs/eventbench/web/WeblogParser.java @ 107

Last change on this file since 107 was 78, checked in by sherbold, 14 years ago
  • updated robot filter
  • extended parsing to handle clients that did not submit agent informations
  • Property svn:mime-type set to text/plain
File size: 4.1 KB
Line 
1package de.ugoe.cs.eventbench.web;
2
3import java.io.FileNotFoundException;
4import java.io.IOException;
5import java.text.ParseException;
6import java.text.SimpleDateFormat;
7import java.util.ArrayList;
8import java.util.HashMap;
9import java.util.LinkedList;
10import java.util.List;
11import java.util.Map;
12
13import de.ugoe.cs.eventbench.web.data.WebEvent;
14import de.ugoe.cs.util.FileTools;
15import de.ugoe.cs.util.console.Console;
16
17public class WeblogParser {
18       
19        private long timeout;
20       
21        private int minLength = 2;
22       
23        private List<List<WebEvent>> sequences;
24       
25        private static final String ROBOTFILTERFILE = "misc/robotfilter.txt";
26       
27        private String robotRegex = ".*";
28       
29        public WeblogParser() {
30                timeout = 3600000; // 1 hour session-timeout as default
31        }
32       
33        public WeblogParser(long timeout) {
34                this.timeout = timeout;
35        }
36       
37        public List<List<WebEvent>> getSequences() {
38                return sequences;
39        }
40       
41        public void setTimeout(long timeout) {
42                this.timeout = timeout;
43        }
44       
45        public void setMinLength(int minLength) {
46                this.minLength = minLength;
47        }
48       
49        public void parseFile(String filename) throws IOException, FileNotFoundException, ParseException {
50                String[] lines = FileTools.getLinesFromFile(filename);
51               
52                Map<String, List<Integer>> cookieSessionMap = new HashMap<String, List<Integer>>();
53                int lastId = -1;
54               
55                SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
56                loadRobotRegex();
57               
58                sequences = new ArrayList<List<WebEvent>>();
59               
60                for( String line : lines ) {
61                        String[] values = line.substring(1, line.length()-1).split("\" \"");
62                       
63                        // use cookie as session identifier
64                        int cookieStart = values[0].lastIndexOf('.');
65                        String cookie = values[0].substring(cookieStart+1);
66                        String dateString = values[1];
67                        long timestamp = dateFormat.parse(dateString).getTime();
68                        String uri = values[2];
69                        // String ref = values[3]; // referer is not yet used!
70                        String agent;
71                        if( values.length>4 ) {
72                                agent = values[4];
73                        } else {
74                                agent = "noagent";
75                        }
76                       
77                        List<String> postedVars = new ArrayList<String>();
78                        if( values.length==6 ) { // post vars found
79                                for( String postVar : values[5].split(" ") ) {
80                                        postedVars.add(postVar);
81                                }
82                        }
83                        if( !isRobot(agent) ) {
84                                WebEvent event = new WebEvent(uri, timestamp, postedVars);
85                               
86                                // find session and add event
87                                List<Integer> sessionIds = cookieSessionMap.get(cookie);
88                                if( sessionIds==null ) {
89                                        sessionIds = new ArrayList<Integer>();
90                                        // start new session
91                                        sessionIds.add(++lastId);
92                                        cookieSessionMap.put(cookie, sessionIds);
93                                        sequences.add(new LinkedList<WebEvent>());
94                                }
95                                Integer lastSessionIndex = sessionIds.get(sessionIds.size()-1);
96                                List<WebEvent> lastSession = sequences.get(lastSessionIndex);
97                                long lastEventTime = timestamp;
98                                if( !lastSession.isEmpty() ) {
99                                        lastEventTime = lastSession.get(lastSession.size()-1).getTimestamp();
100                                }
101                                if( timestamp-lastEventTime>timeout ) {
102                                        sessionIds.add(++lastId);
103                                        List<WebEvent> newSession = new LinkedList<WebEvent>();
104                                        newSession.add(event);
105                                        sequences.add(newSession);
106                                } else {
107                                        lastSession.add(event);
108                                }
109                        }
110                }
111                pruneShortSequences();
112        }
113
114        private void pruneShortSequences() {
115                Console.traceln(""+sequences.size()+ " user sequences found");
116                // prune sequences shorter than min-length
117                int i=0;
118                while( i<sequences.size() ) {
119                        if( sequences.get(i).size()<minLength ) {
120                                sequences.remove(i);
121                        } else {
122                                i++;
123                        }
124                }
125                Console.traceln(""+sequences.size()+ " remaining after pruning of sequences shorter than " + minLength);
126        }
127       
128        private void loadRobotRegex() throws IOException, FileNotFoundException {
129                String[] lines = FileTools.getLinesFromFile(ROBOTFILTERFILE);
130                StringBuilder regex = new StringBuilder();
131                for( int i=0; i<lines.length; i++ ) {
132                        regex.append("(.*"+lines[i]+".*)");
133                        if( i!=lines.length-1 ) {
134                                regex.append("|");
135                        }
136                }
137                robotRegex = regex.toString();
138        }
139       
140        private boolean isRobot(String agent) {
141                return agent.matches(robotRegex);
142        }
143}
Note: See TracBrowser for help on using the repository browser.