Модераторы: LSD, AntonSaburov
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Отслеживание подключаемых клиентов, log4j, Лог действий клиента 
V
    Опции темы
Girin
Дата 14.3.2008, 11:53 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 81
Регистрация: 6.2.2008

Репутация: нет
Всего: нет



Необходимо вести логирование действий в сервлете каждого подключившегося к серверу клиента. То есть записывать в лог IP адрес клиента , его действия и время . Добавил аппендер к сервлету , но пока получается вести лог общих действий 
Код
if(post.contains("description"))//если запрос на описание 
        {
         logger.info("description request");//то добавить в лог 
          ....
         }

Необходимо вести более подробную информацию. Логгер инициирализирую в методе сервлета 
Код
public void init()
    {
         BasicConfigurator.configure();
         logger.info("Entering application.");   
    }

Как получить информацию об IP  подключившихся клиентов в сервлете ? Для информации о времени надо использовать, как  я думаю, класс Date ?  

Это сообщение отредактировал(а) Girin - 14.3.2008, 11:54
PM   Вверх
Kangaroo
Дата 14.3.2008, 13:30 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


AA - Aussie Animal
****


Профиль
Группа: Участник Клуба
Сообщений: 2042
Регистрация: 7.10.2006
Где: US

Репутация: 14
Всего: 104



Цитата(Girin @  14.3.2008,  10:53 Найти цитируемый пост)
Как получить информацию об IP  подключившихся клиентов в сервлете ?

Вот:
Цитата

 java.lang.String  getRemoteAddr()
          Returns the Internet Protocol (IP) address of the client that sent the request.
 java.lang.String  getRemoteHost()
          Returns the fully qualified name of the client that sent the request.




Цитата(Girin @  14.3.2008,  10:53 Найти цитируемый пост)
Для информации о времени надо использовать, как  я думаю, класс Date ?  

или Calendar.
new Date() or Calendar.getInstance вернут текущее время.

А вообще такое делается не в каждом сервлете, а фильтром. Тогда у вас этот код будет в одном месте, а не разбросан по сервлетам.


--------------------
Lost....
PM MAIL MSN   Вверх
Zamuta
Дата 14.3.2008, 20:03 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 389
Регистрация: 18.1.2006

Репутация: 4
Всего: 6



Girin

Код

public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
        doBeforeProcessing(request, response);       
        try {
            MDC.put("ipAddress", request.getRemoteAddr());
            chain.doFilter(request, response);
        } catch (Throwable t) {           
            log.fatal(t);
        } finally {
            MDC.remove("ipAddress");
        }
        doAfterProcessing(request, response);        
    }


Код

log4j.appender.fileout=org.apache.log4j.DailyRollingFileAppender
log4j.appender.fileout.File=log4j.OUT
log4j.appender.fileout.DatePattern='.'yyyy-MM-dd
log4j.appender.fileout.layout=org.apache.log4j.PatternLayout
log4j.appender.fileout.layout.conversionPattern=->[%d{dd:MM:yy HH:mm:ss,SSS}] | [%5p] [%t] [%M] [%L] [RemoteIP: %.15X{ipAddress}] %n


Это сообщение отредактировал(а) Zamuta - 14.3.2008, 20:03


--------------------
Thank you opensource.
PM MAIL ICQ   Вверх
Girin
Дата 14.3.2008, 20:24 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 81
Регистрация: 6.2.2008

Репутация: нет
Всего: нет



 Kangaroo,  Zamuta  благодарю за помощь . То что нужно
PM   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Java"
LSD   AntonSaburov
powerOn   tux
  • Прежде, чем задать вопрос, прочтите это!
  • Книги по Java собираются здесь.
  • Документация и ресурсы по Java находятся здесь.
  • Используйте теги [code=java][/code] для подсветки кода. Используйтe чекбокс "транслит", если у Вас нет русских шрифтов.
  • Помечайте свой вопрос как решённый, если на него получен ответ. Ссылка "Пометить как решённый" находится над первым постом.
  • Действия модераторов можно обсудить здесь.
  • FAQ раздела лежит здесь.

Если Вам помогли, и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, LSD, AntonSaburov, powerOn, tux.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Java EE (J2EE) и Spring | Следующая тема »


 




[ Время генерации скрипта: 0.0541 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.