本文整理汇总了C++中LogEntry::validate方法的典型用法代码示例。如果您正苦于以下问题:C++ LogEntry::validate方法的具体用法?C++ LogEntry::validate怎么用?C++ LogEntry::validate使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类LogEntry
的用法示例。
在下文中一共展示了LogEntry::validate方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: parseLine
//.........这里部分代码省略.........
day = atoi(matches[0].c_str());
month = atoi(matches[1].c_str());
year = atoi(matches[2].c_str());
hour = atoi(matches[3].c_str());
minute = atoi(matches[4].c_str());
second = atoi(matches[5].c_str());
if(month) {
month--;
} else {
//parse non numeric month
for(int i=0;i<12;i++) {
if(strcmp(matches[1].c_str(), ls_ncsa_months[i])==0) {
month=i;
break;
}
}
}
//could not parse month (range 0-11 as used by mktime)
if(month<0 || month>11) return 0;
//convert zone to utc offset
int tz_hour = atoi(matches[7].substr(0,2).c_str());
int tz_min = atoi(matches[7].substr(2,2).c_str());
int tz_offset = tz_hour * 3600 + tz_min * 60;
if(matches[6] == "-") {
tz_offset = -tz_offset;
}
time_str.tm_year = year - 1900;
time_str.tm_mon = month;
time_str.tm_mday = day;
time_str.tm_hour = hour;
time_str.tm_min = minute;
time_str.tm_sec = second;
time_str.tm_isdst = -1;
entry.timestamp = mktime(&time_str);
//apply utc offset
entry.timestamp -= tz_offset;
matches.clear();
ls_ncsa_entry_request.match(request_str, &matches);
if(matches.size() < 5) {
return 0;
}
// entry.method = matches[0];
entry.path = matches[1];
// entry.protocol = matches[2];
entry.response_code = matches[3].c_str();
entry.response_size = atol(matches[4].c_str());
if(matches.size() > 5) {
std::string agentstr = matches[5];
matches.clear();
ls_ncsa_entry_agent.match(agentstr, &matches);
if(matches.size()==3) {
entry.referrer = matches[0];
entry.user_agent = matches[1];
std::string extra = matches[2];
// NOTE: could store extra fields and allow --paddle-mode to address then via their offset
if(!extra.empty()) {
std::vector<std::string> extra_fields;
if(ls_ncsa_extra_field.matchAll(extra, &extra_fields)) {
// for(size_t i=0;i<extra_fields.size();i++) {
// debugLog("extra fields %d: %s", i, extra_fields[i].c_str());
// }
if(!extra_fields.empty() && !extra_fields[0].empty()) {
entry.pid = extra_fields[0];
if(entry.pid.size()>=2 && entry.pid[0] == '"' && entry.pid[entry.pid.size()-1] == '"') {
entry.pid = entry.pid.substr(1, entry.pid.size()-2);
}
}
}
}
}
}
//successful if response code less than 400
int code = atoi(entry.response_code.c_str());
entry.setSuccess();
entry.setResponseColour();
return entry.validate();
}
示例2: parseLine
//.........这里部分代码省略.........
//parse timestamp
struct tm time_str;
int day, month, year, hour, minute, second;
std::string request_str = matches[4];
std::string datestr = matches[3];
matches.clear();
ls_ncsa_entry_date.match(datestr, &matches);
if(matches.size() != 6 && matches.size() != 8) {
return 0;
}
day = atoi(matches[0].c_str());
month = atoi(matches[1].c_str());
year = atoi(matches[2].c_str());
hour = atoi(matches[3].c_str());
minute = atoi(matches[4].c_str());
second = atoi(matches[5].c_str());
if(month) {
month--;
} else {
//parse non numeric month
for(int i=0;i<12;i++) {
if(strcmp(matches[1].c_str(), ls_ncsa_months[i])==0) {
month=i;
break;
}
}
}
//could not parse month (range 0-11 as used by mktime)
if(month<0 || month>11) return 0;
int tz_offset = 0;
//there is a timezone delta
if (matches.size() == 8) {
//convert zone to utc offset
int tz_hour = atoi(matches[7].substr(0,2).c_str());
int tz_min = atoi(matches[7].substr(2,2).c_str());
tz_offset = tz_hour * 3600 + tz_min * 60;
if(matches[6] == "-") {
tz_offset = -tz_offset;
}
}
time_str.tm_year = year - 1900;
time_str.tm_mon = month;
time_str.tm_mday = day;
time_str.tm_hour = hour;
time_str.tm_min = minute;
time_str.tm_sec = second;
time_str.tm_isdst = -1;
entry.timestamp = mktime(&time_str);
//apply utc offset
entry.timestamp -= tz_offset;
matches.clear();
ls_ncsa_entry_request.match(request_str, &matches);
if(matches.size() < 5) {
return 0;
}
// entry.method = matches[0];
entry.path = matches[1];
// entry.protocol = matches[2];
entry.response_code = matches[3].c_str();
entry.response_size = atol(matches[4].c_str());
if(matches.size() > 5) {
std::string agentstr = matches[5];
matches.clear();
ls_ncsa_entry_agent.match(agentstr, &matches);
if(matches.size()==3) {
entry.referrer = matches[0];
entry.user_agent = matches[1];
entry.pid = matches[2];
}
}
//successful if response code less than 400
int code = atoi(entry.response_code.c_str());
entry.setSuccess();
entry.setResponseColour();
return entry.validate();
}