1 В избранное 0 Ответвления 0

OSCHINA-MIRROR/centchen-class-scanner

Клонировать/Скачать
Внести вклад в разработку кода
Синхронизировать код
Отмена
Подсказка: Поскольку Git не поддерживает пустые директории, создание директории приведёт к созданию пустого файла .keep.
Loading...
README.md

Класс-сканер

Введение

Класс-сканер — это Java-класс для сканирования, который используется для получения классов из указанного пакета и фильтрации по указанной аннотации.

Реализованные функции:

  • получение всех классов из пакета;
  • получение классов из пакета с последующей обработкой через функцию обратного вызова;
  • получение классов с указанной аннотацией из пакета;
  • получение классов с указанной аннотацией из пакета с последующей обработкой через функцию обратного вызова;
  • специфические функции SpringBootStarter:
    • автоматическое получение всех классов при запуске проекта и последующая обработка через функцию обратного вызова;
    • автоматическое получение классов с указанной аннотацией при запуске проекта и последующая обработка через функцию обратного вызова.

Структура проекта

Класс-сканер состоит из следующих компонентов:

  • scanner-core — основной пакет;
  • scanner-spring-boot-starter — модуль стартера Spring Boot;
  • class-scanner-example — пример пакета.

Инструкция по использованию

Поскольку проект не был загружен в центральный репозиторий Maven, необходимо настроить его хранилище в проекте. Для этого добавьте следующую конфигурацию в файл конфигурации репозитория:

<repositories>
    <repository>
        <id>cent-repo</id>
        <url>https://gitee.com/centy/maven/raw/master</url>
    </repository>
</repositories>
1. Использование основного пакета scanner-core
  • Добавить зависимость (пример использования Maven, Gradle может быть настроен самостоятельно):

Добавить следующий пакет зависимостей в проект:

<dependency>
    <groupId>org.cent</groupId>
    <artifactId>scanner-core</artifactId>
    <version>1.0.2-SNAPSHOT</version>
</dependency>
  • Пример кода

Можно использовать следующий тестовый код:

package org.cent.scanner.core.scanner;

import lombok.extern.slf4j.Slf4j;
import org.cent.scanner.core.anno.Scannable;
import org.cent.scanner.core.callback.ScannerCallback;
import org.cent.scanner.core.scanner.impl.DefaultClassScanner;
import org.junit.Test;
import sun.jvm.hotspot.utilities.Assert;

import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
import java.util.Arrays;
import java.util.List;

@Scannable
@ClassScannerTestCase.CustomScannable
@Slf4j
public class ClassScannerTestCase {

    private final List<String> scanPkgs = Arrays.asList(
            "org", "lombok", "com.sun", "javax"
    );
    private ClassScanner classScanner = new DefaultClassScanner();

    /**
     * Тестовый случай: сканирование нескольких пакетов
     */
    @Test
    public void testScan() {
        List<Class> classList = classScanner.scan(scanPkgs);
        Assert.that(classList.size() > 0, "Сканирование не удалось, результат пустой!");
        log.info("Всего отсканировано {} классов", classList.size());
    }

    /**
     * Тестовый случай: Сканирование классов с аннотацией Scannable из нескольких пакетов.
     */
    @Test
    public void testScanByAnno() {
        List<Class> classList = classScanner.scanByAnno(scanPkgs, Scannable.class);
        Assert.that(classList.size() > 0, "Сканирование не удалось, результат пустой!");
        log.info("Всего отсканировано {} классов", classList.size());
    }

    /**
     * Тестовый случай: Сканирование нескольких пакетов с выполнением callback-функции.
     */
    @Test
    public void testScanAndCallback() {
        classScanner.scanAndCallback(scanPkgs, new TestCallback());
    }

    /**
     * Тестовый случай: Сканирование классов с аннотацией CustomScannable из нескольких пакетов, выполнение callback-функции.
     */
    @Test
    public void testScanAndCallbackByAnno() {
        classScanner.scanAndCallbackByAnno(scanPkgs, CustomScannable.class, new TestCallback());
    }


    /**
     * Callback-функция
     */
    @Slf4j
    static class TestCallback implements ScannerCallback {
        @Override
        public void callback(List<Class> clzs) {
            clzs.forEach(clz -> log.info(clz.getName()));
            Assert.that(clzs.size() > 0, "Результат сканирования неправильный!");
        }
    }

    /**
     * Пользовательская аннотация
     */
    @Target(ElementType.TYPE)
    @Retention(RetentionPolicy.RUNTIME)
    static @interface CustomScannable {

    }
}
2. Использование модуля стартера SpringBoot
  • Добавить зависимость
<dependency>
    <groupId>org.cent</groupId>
    <artifactId>scanner-spring-boot-starter</artifactId>
    <version>1.0.1-SNAPSHOT</version>
</dependency>
  • Пример кода [автоматическое сканирование]

a. Разработать функцию обратного вызова

package org.cent.demo.scanner.callback;

import lombok.extern.slf4j.Slf4j;
import org.cent.scanner.core.callback.ScannerCallback;

import java.util.List;

@Slf4j
public class CustomCallback implements ScannerCallback {

    @Override
    public void callback(List<Class> list) {
        list.forEach(clz -> {
            log.info(clz.getName());
        });
    }
}

b. В файле application.yml добавить следующую конфигурацию:

org:
  scanner:
    auto:
      enable: true
      callback: org.cent.demo.scanner.callback.CustomCallback
      packages:
        - org.cent

c. Запустить выполнение, вывод будет следующим:

2019-01-16 15:53:50.713  INFO 4365 --- [           main] o.c.d.scanner.callback.CustomCallback    : org.cent.demo.scanner.Application
2019-01-16 15:53:50.714  INFO 4365 --- [           main] o.c.d.scanner.callback.CustomCallback

Комментарии ( 0 )

Вы можете оставить комментарий после Вход в систему

Введение

Описание недоступно Развернуть Свернуть
Apache-2.0
Отмена

Обновления

Пока нет обновлений

Участники

все

Недавние действия

Загрузить больше
Больше нет результатов для загрузки
1
https://api.gitlife.ru/oschina-mirror/centchen-class-scanner.git
git@api.gitlife.ru:oschina-mirror/centchen-class-scanner.git
oschina-mirror
centchen-class-scanner
centchen-class-scanner
master