• Как понять работают все links в футере?

    azerphoenix
    @azerphoenix
    Java Software Engineer
    Можно получить HTTP статус этих ссылок.

    Вот, простой пример (указанный ниже код можно сократить и упростить):
    import java.io.IOException;
    import java.net.HttpURLConnection;
    import java.net.MalformedURLException;
    import java.net.URL;
    
    public class URLChecker {
    
      public static int checkUrl(String currentUrl) {
        URL checkUrl = null;
        HttpURLConnection http = null;
        int statusCode = 0;
        try {
          checkUrl = new URL(currentUrl);
        } catch (MalformedURLException e) {
          e.printStackTrace();
        }
        try {
          if (checkUrl != null) {
            http = (HttpURLConnection)checkUrl.openConnection();
          }
        } catch (IOException e) {
          e.printStackTrace();
        }
        try {
          if (http != null) {
            statusCode = http.getResponseCode();
          }
        } catch (IOException e) {
          e.printStackTrace();
        }
        return statusCode;
      }
    }

    А дальше проверяете статус ссылки и если он равен 200, то все ок. А если нет, то значит ссылка нерабочая.
    Ответ написан
    Комментировать
  • Почему не запускается чистый Maven проект?

    azerphoenix
    @azerphoenix Куратор тега Java
    Java Software Engineer
    Добрый вечер. Давайте попробуем разобраться.

    Если вам не нужны плагины, то вы можете их удалить.
    <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-project-info-reports-plugin</artifactId>
                <version>3.1.2</version>
            </plugin>
        </plugins>


    Для maven это норм такой геморрой?:)

    Нет конечно же. Просто вы решили начать изучать Java и сразу же решили взяться за Maven. Можно было для начала изучить сам язык, а затем изучить системы сборки, но это уже ваше дело)


    Error injecting: org.apache.maven.report.projectinfo.CiManagementReport
    java.lang.NoClassDefFoundError: org/apache/maven/doxia/siterenderer/DocumentContent

    Вот, полезная информация:
    This is caused by maven-project-info-reports-plugin updated to 3.0.0, and rely on doxia-site-renderer 1.8 (and have org.apache.maven.doxia.siterenderer.DocumentContent this class), but maven-site-plugin:3.3 rely on doxia-site-renderer:1.4 (and do not have org.apache.maven.doxia.siterenderer.DocumentContent)

    https://stackoverflow.com/questions/51091539/maven...

    Для быстрого старта проекта вы можете использовать архетипы. В частности ищите архетип maven quickstart
    Скрин - https://i.imgur.com/tPVfFH9.png

    Попробуйте вышеуказанные решения, а затем отпишитесь. Также вы можете выложить исходник вашего проекта на гитхаб и скинуть ссылку.
    Ответ написан
    4 комментария
  • Какие знания нужны для взлома мобильной игры?

    azerphoenix
    @azerphoenix
    Java Software Engineer
    Ну во-первых, чтобы взломать клиентскую часть игры вам нужно изучить язык, на котором написана данная игра. Так как это фреймворк Unity, то скорее всего вам нужен язык C#.
    Далее вам нужно изучить реверс-инженеринг. Грубо говоря, вам нужно собранный apk игры декомпилировать, найти нужные строки, изменить их по своему усмотрению, а затем собрать новый apk. Тут вам скорее понадобится владение Java.
    Во-вторых, все современные игры синхронизируются с сервером, а значит, вам нужно взломать не только клиентскую часть, но и серверную часть тоже. Тут уже нужны совсем другие навыки. Например, вам нужно знание принципов работы сетей, владение языками рнр или пайтон, быть знакомыми с sql эксплоитами и xss атаками и т.д. В общем, как по мне это все выходит за рамки правил данного сервиса и далее нет смысла это все описывать. Ищите специализированные форумы, где вам могут подсказать или помочь.
    Ответ написан
    Комментировать
  • Делают ли MarketPlace на Java Spring?

    azerphoenix
    @azerphoenix Куратор тега Java
    Java Software Engineer
    Добрый день.
    Микросервисы могут быть разработаны на разных языках и необязательно, чтобы они все были на одном языке. К тому же скорее всего вы это все разворачиваете при помощи докера, что безусловно упрощает процесс развертывания.
    В каком случае есть смысл переписать e-commerce продукт на Java ?

    В том случае, когда в вашем штате есть Java разработчик. И в том случае, когда содержать в штате других разработчиков обходится дорого.
    Наверное, можно попробовать собрать штат из js разработчиков, чтобы они пилили и фронт и бэк, но особого смысла это тоже не даст.

    Пока планируется переписать на фреймворк Symfony ( php ) с laravel для улучшения архитектуры приложения.

    Не вижу смысла потом переходить на Spring.

    Подразумевается наличие большого числа микросервисов - парсеры цен, загрузчики картинок с сайтов поставщиков через предоставленный ими прайс в формате yml, интеграция служб доставки, платежных систем.

    Spring и Java со всем этим легко справляются. Но на Symfony тоже возможна реализация микросервисов. Так что выбирайте то, что вам дешевле обойдется и в плане разработки и в плане поддержки, развертывания и т.д.
    Ответ написан
    Комментировать
  • Как сделать редактор текста todo list?

    azerphoenix
    @azerphoenix Куратор тега Java
    Java Software Engineer
    Добрый день!
    Все довольно просто:

    1 способ:
    1) у вас должна быть страница редактирования записи.
    2) добавьте кнопку редактировать. Кнопка редактировать перенаправляет юзера (GET запрос) с id (path variable или request param - идентификатор записи).
    3) По идентификатору достаете текст записи на странице редактирования записи
    4) редактируете запись и сохраняете.

    2 способ:
    1) можно все указанное сделать при помощи ajax. Вместо перенаправления на отдельную страницу загружать содержимое в модальном окне (доставать данные средствами js при помощи ajax).
    2) а дальше уже сохраняете данные сабмитом содержимого формы из модалки

    P.S. небольшой совет:
    todo.setCompleted("No");
    Предположу, что у вас статус completed является типом String. Лучше используйте тип boolean. А еще лучше обертку Boolean, который принимает true false & null
    Ответ написан
    Комментировать
  • Подойдет ли MacBook Pro 2020 (MWP42) и в целом Mac OS для полноценной разработки на Java?

    azerphoenix
    @azerphoenix
    Java Software Engineer
    Добрый вечер!

    Подойдет ли MacBook и в целом система Mac OS для программирования на Java?

    Да, также как и любая другая OS.

    Возможно ли пройти путь от полного неуча до Senior Software Java Developer на Маке или так без Windows не обойтись?

    Я этот путь прошел без виндовс, только на линукс (правда, до senior еще не добрался =) ). В общем, кому что нравится...

    Если все таки, если я хочу программировать на Mac OS, то мне стоит больше присмотреться к той же iOS разработке?

    Необязательно. Если вы хотите стать iOS разработчиком, то наличие MacOS обязательно. А так, вы можете писать на маках что угодно и на чем угодно... хоть на Java, C# и т.д.

    В дополнение к маку купите еще книжки по Java. Поищите аналогичные вопросы на этом сайте, уже были ответы что стоит прочитать начинающему разработчику.
    Ответ написан
    Комментировать
  • Можно ли использовать нижнее подчеркивание в методах для тестов?

    azerphoenix
    @azerphoenix Куратор тега Java
    Java Software Engineer
    Да, можно.
    Подробности тут:
    https://dzone.com/articles/7-popular-unit-test-naming

    А использование нижнего подчеркивания не в тестах не рекомендуется.
    Ответ написан
    3 комментария
  • Должны ли переменные final ( не static ) всегда писаться большими буквами?

    azerphoenix
    @azerphoenix Куратор тега Java
    Java Software Engineer
    Добрый день!
    В данном случае согласен с коллегой @sergey-gornostaev
    Но вот, что самое интересное:
    https://vertex-academy.com/tutorials/ru/modifikato...
    *Обратите внимание: переменные с final - это константы. При этом их принято писать заглавными буквами - тут CamelStyle не работает :


    Вот, еще интересная выдержка из ответа:

    In java, making something final means that it can't be reasigned to another reference to another instance, but if it's a reference to a mutable class, the mutable values inside the class can still be modified.

    For example, a final String is a constant because Strings are immutable in Java, but a final ArrayList means that you cannot assign it to another ArrayList, but you can still add and remove elements to that ArrayList

    https://stackoverflow.com/questions/39459727/diffe...
    Ответ написан
  • Является ли объявление этой переменной бессмысленной или она улучшает читабельность кода?

    azerphoenix
    @azerphoenix Куратор тега Java
    Java Software Engineer
    С точки зрения clean code лучше сделать с отдельной переменной.
    Ответ написан
    Комментировать
  • Как правильно конвертировать POJO в XML?

    azerphoenix
    @azerphoenix Куратор тега Java
    Java Software Engineer
    Добрый день!
    У вас есть dto - Request, но нет dto Response.

    Вот, примерная структура pojo для Response (источник)
    public class Response { 
    	public int p_id;
    	public int status;
    	public String message;
    	public int id;
    	public Date dts;
    	public String text;
    }


    Также вам для того, чтобы ответ возвращать в xml нужно добавить одну библиотеку для jackson (если вы используете именно его).
    <dependency>
        <groupId>com.fasterxml.jackson.dataformat</groupId>
        <artifactId>jackson-dataformat-xml</artifactId>
        <version>2.11.1</version>
    </dependency>

    Подробности тут
    Ответ написан
    Комментировать
  • Как проще всего поднять несколько локальных инстансов приложения для отладки/тестирования?

    azerphoenix
    @azerphoenix Куратор тега Java
    Java Software Engineer
    Добрый день!
    Как по мне проще всего использовать docker. Можно еще использовать docker-compose, чтобы быстро разворачивать контейнеры с нужными параметрами.
    Ответ написан
    Комментировать
  • Пропали атрибуты в карточке товара после обновления темы, как быть?

    azerphoenix
    @azerphoenix
    Java Software Engineer
    Добрый день.

    если не найду тут ответ напишу им, просто 50$ придется платить им за подписку на поддержу, и не факт еще если помогут)) в любом случае спасибо за ответ

    Коллега подсказал вам правильно. Нужно обратиться разработчику и да, они помогут.

    Что касается вашей проблемы, то это происходит по той причине, что ваша тема, в силу отутствия лицензии могла устареть и шаблоны WC могли устареть тоже.

    Попробуйте:
    1) обновить тему до актуальной версии.
    2) откатиться до старой версии WC или восстановить сайт из бекапа.

    Единственный вариант который я вижу и он меня не радует, это экспортировать товар и всю проделанную работу и заново загрузить движок WordPress.

    Это конечно решение, но зачем вам так сильно напрягаться.

    Использую тему *Betheme, лицензия* напомню что после обновления темы а именно с перехода 24.0.3.1 на 25.0.1

    Возможно, что есть некий конфликт. Можете еще попробовать другое решение. Из директории templates внутри плагина woocomemrce скопируйте шаблоны в директорию woocommerce самой темы.
    Ответ написан
    1 комментарий
  • Как понять микросервисы?

    azerphoenix
    @azerphoenix
    Java Software Engineer
    Добрый день!
    Прежде всего ответьте на один вопрос - какую именно проблему вы хотите решить переходом на микросервисную архитектуру. Обратите внимание, что обеспечивать ACID в микросервисной структуре сложнее, чем в монолитах. Также обслуживание микросервисов тоже сложнее. Если есть нагрузка на сервис, то не факт, что вам нужны микросервисы. Возможно, что вам нужна оптимизация сервиса или более производительное железо.

    Если у каждого сервиса есть свой api, зачем API Gateway (точка входа), можно же на nginx сделать обращение по location на нужный api?

    Например, в случае с Spring API Gateway в нем есть балансировщик. Балансировщик помогает снижать нагрузку с микросервиса, если у вас имеются несколько копий, то каждый раз запросы идут на разные копии. Также gateway удобен тем, что клиент не беспокоится о том, на какой эндпоинт нужно отправлять запрос. Возможно, что у вас несколько копий одного сервиса и то какой из них должен ответить на запрос клиента, самого клиента это не касается.

    Стоит ли использовать RabbitMQ для общения между сервисами? Правильно ли понимаю, что точка входа на ноде, посылает запрос в раббит и ждет от него же ответ и отдает клиенту?

    Можно и через RabbitMQ. А так например, Spring API Gateway использует асинхронные запросы (Spring Webflux) для реализации данной задачи.

    Например делаем микросервис по авторизации пользователя и регистрации. У него должна быть своя база данных?

    Это зависит от вашей задачи. Да, может быть и своя БД. А может быть и нет.

    Получается микросервис отвечающий за пользователей CRUD + Регистрация, авторизация, сброс пароля?

    Опять-таки зависит от вашей задачи, от нагрузки и т.д. Возможно, что регистрация, авторизация и сброс пароля будут отдельными микросервисами. А возможно, что User CRUD будет одним микросервисом.
    Ответ написан
    Комментировать
  • Spring boot - как происходит запуск?

    azerphoenix
    @azerphoenix Куратор тега Java
    Java Software Engineer
    Есть приложение, читающее файлы из файловой системы и загружающее в БД часть содержимого.

    Ну в данном случае для импорта БД нужно использовать sql скрипты и какую-нибудь либу. Например, flyway.

    Есть сервисные классы, в них ряд методов, но возвращаемые типы в методах повторяются.

    Если это необходимо, то можно использовать дженерики.

    Хотелось бы сделать без спринг шелла, без команд в мейне.

    По идее flyway (или например, liquibase) лучше подходят для этих целей.
    Ответ написан
    Комментировать
  • Правильно ли я называю тесты?

    azerphoenix
    @azerphoenix Куратор тега Java
    Java Software Engineer
    Добрый день.
    Вопрос не глупый. Ведь, от правильного нейминга зависит то, насколько хорошо ваш код будет читаемым.
    Вот, информация о конвенции нейминга тестов.
    https://dzone.com/articles/7-popular-unit-test-naming
    Ответ написан
    Комментировать
  • Как выводить посты с разными стилями и разметкой в wordpress?

    azerphoenix
    @azerphoenix
    Java Software Engineer
    Добрый день!
    Я уже давно не занимаюсь ВП разработкой, но вашу задачу можно решить разными способами.
    1) не залезая в рнр код, а только CSS стилями. Например, при помощи псевдоклассов first-child last-child nth-child() и т.д.
    2) с использованием рнр кода (как по мне более предпочтительный по разным причинам).
    Нужно завести свой счетчик вне цикла. В цикле инкрементировать значение и например, если номер поста равен 1, то вывести пост со стилем (большая картинка и т.д.), а если номер поста не равен 1, то вывести пост с другим стилем.
    Ответ написан
    Комментировать
  • Как перевести title в wordpress на странице 404 на английский?

    azerphoenix
    @azerphoenix
    Java Software Engineer
    Добрый день.
    Все зависит от того, как именно тема была создана.
    Если при создании темы учитывалась i18n & l10n, то скорее всего у вас будут pot & po файлы. В таком случае просто откройте этот файл программой PoEdit или плагином LocoTranslate и найдя нужную строку переведите ее.
    Другое дело, если тема не локализовалась (т.е. некий хардкодинг на уровне шаблона). В этом случае найдите соответствующий шаблон темы (например, 404.рнр) и найдя тег title перепишите его на английский.
    Ну или же можете локализовать тему добавив соответствующие теги обертки и потом уже на основе этих тегов создать pot, а затем уже и po & mo файлы.
    Ответ написан
    Комментировать
  • Как в слое DAO при помощи JDBC получить корректную сущность?

    azerphoenix
    @azerphoenix Куратор тега Java
    Java Software Engineer
    Добрый день.
    В Hibernate при использовании аннотации ManyToMany создаются 3 таблицы. 2 таблицы для самих сущностей, где хранится информация и 1 таблица с маппингами, где хранятся id сущностей. В данном случае с вашими таблицами все в порядке.

    У возвращаемого автора должны быть проинициализированы поля books и genres. Там должны находится
    книги которые писал автор и жанры в которых он работал. В свою очередь у каждой книги должна быть
    информация в каком жанре она написана и какие у нее авторы. А жанр должен хранить список книг относящихся к нему
    и авторов работающих в данном жанре.


    При такой работе (при сериализации данных или при вызове метода toString) вы столкнетесь с рекурсией. Например, у автора есть список книг, у книг есть авторы и каждый раз будут вызваны методы, которые будут запрашивать то авторов, которые написали эту книгу, то книги, которые был написаны этим автором. Эти вопросы при работе с Jackson решаются при помощи аннотаций JsonManagedReference & JsonBackReference или JsonIgnore. Для lombok для исключения из toString можно использовать ToString.Ignore.

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

    Если мы говорим о hibernate (jpa), то там есть таккие параметры, как FetchType (EAGER & LAZY). Так вот, если LAZY, то информация из List будет загружена только при обращении к ней. В случае EAGER информация загружается при первом же обращении к сущности.
    https://thorben-janssen.com/entity-mappings-introd...

    Возможно, что эта ссылка будет полезна для вас:
    https://stackoverflow.com/questions/21956042/mappi...
    Ответ написан
  • Как получить доступ к owner?

    azerphoenix
    @azerphoenix Куратор тега Java
    Java Software Engineer
    Добрый день.
    Вот, гляньте на структуру pojo для вашего json
    Было сгенерировано на сайте - https://www.jsonschema2pojo.org/
    -----------------------------------com.example.Example.java-----------------------------------
    
    package com.example;
    
    import java.util.List;
    import javax.annotation.Generated;
    import com.google.gson.annotations.Expose;
    import com.google.gson.annotations.SerializedName;
    
    @Generated("jsonschema2pojo")
    public class Example {
    
    @SerializedName("total_count")
    @Expose
    public Long totalCount;
    @SerializedName("incomplete_results")
    @Expose
    public Boolean incompleteResults;
    @SerializedName("items")
    @Expose
    public List<Item> items = null;
    
    }
    -----------------------------------com.example.Item.java-----------------------------------
    
    package com.example;
    
    import javax.annotation.Generated;
    import com.google.gson.annotations.Expose;
    import com.google.gson.annotations.SerializedName;
    
    @Generated("jsonschema2pojo")
    public class Item {
    
    @SerializedName("id")
    @Expose
    public Long id;
    @SerializedName("node_id")
    @Expose
    public String nodeId;
    @SerializedName("name")
    @Expose
    public String name;
    @SerializedName("full_name")
    @Expose
    public String fullName;
    @SerializedName("private")
    @Expose
    public Boolean _private;
    @SerializedName("owner")
    @Expose
    public Owner owner;
    @SerializedName("html_url")
    @Expose
    public String htmlUrl;
    @SerializedName("description")
    @Expose
    public String description;
    @SerializedName("fork")
    @Expose
    public Boolean fork;
    
    }
    -----------------------------------com.example.Owner.java-----------------------------------
    
    package com.example;
    
    import javax.annotation.Generated;
    import com.google.gson.annotations.Expose;
    import com.google.gson.annotations.SerializedName;
    
    @Generated("jsonschema2pojo")
    public class Owner {
    
    @SerializedName("login")
    @Expose
    public String login;
    @SerializedName("id")
    @Expose
    public Long id;
    @SerializedName("node_id")
    @Expose
    public String nodeId;
    @SerializedName("avatar_url")
    @Expose
    public String avatarUrl;
    @SerializedName("gravatar_id")
    @Expose
    public String gravatarId;
    @SerializedName("url")
    @Expose
    public String url;
    @SerializedName("html_url")
    @Expose
    public String htmlUrl;
    @SerializedName("followers_url")
    @Expose
    public String followersUrl;
    @SerializedName("following_url")
    @Expose
    public String followingUrl;
    @SerializedName("gists_url")
    @Expose
    public String gistsUrl;
    @SerializedName("starred_url")
    @Expose
    public String starredUrl;
    @SerializedName("subscriptions_url")
    @Expose
    public String subscriptionsUrl;
    @SerializedName("organizations_url")
    @Expose
    public String organizationsUrl;
    @SerializedName("repos_url")
    @Expose
    public String reposUrl;
    @SerializedName("events_url")
    @Expose
    public String eventsUrl;
    @SerializedName("received_events_url")
    @Expose
    public String receivedEventsUrl;
    @SerializedName("type")
    @Expose
    public String type;
    @SerializedName("site_admin")
    @Expose
    public Boolean siteAdmin;
    
    }
    Ответ написан
    Комментировать
  • Какую аннотацию лучше всего использовать для ролей ( для Hibernate ) в Spring?

    azerphoenix
    @azerphoenix Куратор тега Java
    Java Software Engineer
    Добрый день.
    Я обычно делаю это иным образом.
    1) создаю enum UserRole, UserPrivilege
    2) создаю entity Role. При необходимости можно еще добавить сет из Privilege для каждой роли
    3) Далее каждый entity содержит роль или сет ролей.
    4) сущность User связываю с сущностью UserRole

    Вот, исходники:
    Сущность User
    @Entity
    @Data
    @Table(name = "users")
    @Builder
    @AllArgsConstructor
    @NoArgsConstructor
    @EqualsAndHashCode(callSuper = false)
    public class User {
    
      //...
    
      @JsonBackReference
      @ToString.Exclude
      @ManyToMany(fetch = FetchType.EAGER)
      @JoinTable(
          name = "users_roles",
          joinColumns = @JoinColumn(name = "user_id"),
          inverseJoinColumns = @JoinColumn(name = "role_id"))
      private Set<Role> roles;
    
    }


    Сущность Role
    @Entity
    @Data
    @EqualsAndHashCode(callSuper = false)
    @Table(name = "roles")
    public class Role implements GrantedAuthority {
    
      @Id
      @GeneratedValue(strategy = GenerationType.SEQUENCE)
      private Long roleId;
    
      @JsonBackReference
      @ToString.Exclude
      @ManyToMany(mappedBy = "roles")
      private Collection<User> users;
    
      @JsonBackReference
      @ToString.Exclude
      @ManyToMany
      @JoinTable(
          name = "roles_privileges",
          joinColumns = @JoinColumn(name = "role_id"),
          inverseJoinColumns = @JoinColumn(name = "privilege_id"))
      private Collection<Privilege> privileges;
    
      @Enumerated(EnumType.STRING)
      private UserRole name;
    
      public Role() {
        super();
      }
    
      public Role(UserRole name) {
        super();
        this.name = name;
      }
    
      @Override
      public String getAuthority() {
        return name.name();
      }
    }


    enum UserRole
    public enum UserRole {
      USER,
      ADMIN
    }


    сущность Privilege
    @Entity
    @Data
    @EqualsAndHashCode(callSuper = false)
    @Table(name = "privileges")
    public class Privilege {
    
      
    
      @Enumerated(EnumType.STRING)
      private UserPrivilege name;
    
      @JsonBackReference
      @ToString.Exclude
      @ManyToMany(mappedBy = "privileges")
      private Collection<Role> roles;
    
    
    }


    enum UserPrivilege
    public enum UserPrivilege {
      ADMIN_PRIVILEGE,
      READ_PRIVILEGE,
      WRITING_COMMENTS_PRIVILEGE
    }
    Ответ написан
    6 комментариев