Java | Вопросы собесов
11.4K subscribers
33 photos
2 videos
1.11K links
Download Telegram
🤔 Какие есть типы EL операторов?

JSP Expression Language (EL) поддерживает различные типы операторов, которые позволяют выполнять разнообразные операции на данных. Эти операторы включают в себя арифметические, логические, операторы сравнения, условные операторы и операторы доступа к свойствам и коллекциям.

Ставь 👍 если знал ответ и 🔥 если нет
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥21👀3👍2
📌 Как из одного сервлета вызвать другой сервлет?

💬 Спрашивают в 6 % собеседований

Для вызова одного сервлета из другого в Java можно использовать интерфейс RequestDispatcher, который позволяет перенаправлять запросы (forward) или включать содержимое другого сервлета (include). Это делается внутри сервлета-инициатора с использованием метода getRequestDispatcher(String path) или getNamedDispatcher(String name) для получения объекта RequestDispatcher.

🤔 Основные методы:

1️⃣ `forward(ServletRequest request, ServletResponse response)`: Перенаправляет запрос и ответ от одного сервлета к другому ресурсу на сервере. В этом случае URL в браузере не меняется, и клиент не видит перенаправления.

2️⃣ `include(ServletRequest request, ServletResponse response)`: Включает содержимое другого ресурса в ответ текущего запроса. Это позволяет комбинировать вывод нескольких ресурсов.

🤔 Примеры использования `RequestDispatcher`:

1️⃣ Перенаправление запроса (forward):
import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.RequestDispatcher;

public class FirstServlet extends HttpServlet {
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// Логика обработки запроса
String username = request.getParameter("username");
request.setAttribute("user", username);

// Перенаправление запроса на другой сервлет
RequestDispatcher dispatcher = request.getRequestDispatcher("SecondServlet");
dispatcher.forward(request, response);
}
}


2️⃣ Включение содержимого другого сервлета (include):
import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.RequestDispatcher;

public class MainServlet extends HttpServlet {
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// Включение заголовка
RequestDispatcher dispatcher = request.getRequestDispatcher("HeaderServlet");
dispatcher.include(request, response);

// Основной контент
response.getWriter().println("<h1>Main Content</h1>");

// Включение подвала
dispatcher = request.getRequestDispatcher("FooterServlet");
dispatcher.include(request, response);
}
}


3️⃣ Пример сервлета, к которому идет перенаправление или включение:
import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

public class SecondServlet extends HttpServlet {
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// Получаем атрибут из запроса
String username = (String) request.getAttribute("user");

// Логика обработки
response.setContentType("text/html");
response.setCharacterEncoding("UTF-8");
response.getWriter().println("Hello, " + username);
}
}


🤔 Основные шаги для вызова одного сервлета из другого:

1️⃣ Получить объект `RequestDispatcher`:

Через HttpServletRequest: request.getRequestDispatcher("SecondServlet").

Через ServletContext: getServletContext().getRequestDispatcher("/SecondServlet").

2️⃣ Использовать метод `forward` или `include` объекта `RequestDispatcher`:

dispatcher.forward(request, response): Перенаправляет запрос.

dispatcher.include(request, response): Включает содержимое.

🤔 Итог:

Чтобы вызвать один сервлет из другого, используйте RequestDispatcher с методами forward или include для передачи управления или включения содержимого другого сервлета в ответ.

🔥 ТОП ВОПРОСОВ С СОБЕСОВ

🔒 База собесов | 🔒 База тестовых
Please open Telegram to view this post
VIEW IN TELEGRAM
👍71🤯1
Please open Telegram to view this post
VIEW IN TELEGRAM
👍133👾1
Java | Вопросы собесов pinned «👾 1715 вопросов собесов на Java Developer 🔒 База реальных собесов 🔒 База тестовых заданий 👾 Список менторов 👩‍💻 Java ├ Вакансии ├ LeetCode ответы └ Тесты 🖥 Python ├ Вопросы собесов ├ Вакансии ├ LeetCode ответы └ Тесты 🖥 Frontend ├ Вопросы собесов ├ Вакансии…»
📌 Для чего используются атрибуты сервлетов и как происходит работа с ними?

Атрибуты сервлетов используются для передачи данных между сервлетами, JSP и другими компонентами в рамках одного запроса, сессии или контекста приложения.

🤔 Виды атрибутов и их использование:

1️⃣ Атрибуты запроса (Request Attributes):

Используются: Для передачи данных между сервлетами и JSP в рамках одного запроса.
Методы: request.setAttribute("name", value), request.getAttribute("name").
     request.setAttribute("message", "Hello");
RequestDispatcher dispatcher = request.getRequestDispatcher("otherServlet");
dispatcher.forward(request, response);


2️⃣ Атрибуты сессии (Session Attributes):

Используются: Для хранения данных на время сессии пользователя.
Методы: session.setAttribute("name", value), session.getAttribute("name").
     HttpSession session = request.getSession();
session.setAttribute("user", "JohnDoe");


3️⃣ Атрибуты контекста (Context Attributes):

Используются: Для данных, доступных всем сервлетам и JSP в приложении.
Методы: context.setAttribute("name", value), context.getAttribute("name").
     ServletContext context = getServletContext();
context.setAttribute("globalData", "Important Data");


🔥 ТОП ВОПРОСОВ С СОБЕСОВ

🔒 База собесов | 🔒 База тестовых
Please open Telegram to view this post
VIEW IN TELEGRAM
🤯2🔥1
📌В чем отличия GenericServlet и HttpServlet?

💬 Спрашивают в 6 % собеседований

GenericServlet и HttpServlet — это два класса в Java Servlet API, которые служат основой для создания сервлетов. Они различаются по своему предназначению и областям применения.

🤔 Основные отличия:

1️⃣ Назначение:

`GenericServlet`: Это абстрактный класс, который предоставляет базовую реализацию интерфейса Servlet и может быть использован для создания сервлетов, работающих с любыми протоколами, не ограничиваясь HTTP.

`HttpServlet`: Это класс, предназначенный специально для создания сервлетов, работающих с протоколом HTTP. Он расширяет GenericServlet и добавляет методы, специфичные для обработки HTTP-запросов.

2️⃣ Методы:

`GenericServlet`: Определяет базовые методы, такие как init(), service(), destroy(), getServletConfig(), и getServletInfo().
     public abstract class GenericServlet implements Servlet, ServletConfig, Serializable {
public abstract void service(ServletRequest req, ServletResponse res) throws ServletException, IOException;
}


`HttpServlet`: Добавляет методы для обработки конкретных типов HTTP-запросов, таких как doGet(), doPost(), doPut(), doDelete(), и doHead().
     public class HttpServlet extends GenericServlet {
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException;
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException;
// Другие методы...
}


3️⃣ Обработка запросов:

`GenericServlet`: Требует реализации метода service(), который должен обрабатывать все виды запросов.
     public class MyGenericServlet extends GenericServlet {
@Override
public void service(ServletRequest req, ServletResponse res) throws ServletException, IOException {
// Обработка запросов
}
}


`HttpServlet`: Позволяет переопределить методы для каждого типа HTTP-запроса (GET, POST, PUT и т.д.), что упрощает обработку запросов.
     public class MyHttpServlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
// Обработка GET-запроса
}

@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
// Обработка POST-запроса
}
}


🤔 Когда использовать:

`GenericServlet`: Используется, когда необходимо создать сервлет, который может работать с любым протоколом, не ограничиваясь HTTP. Это редко встречается в современных веб-приложениях, где HTTP является основным протоколом.

`HttpServlet`: Используется для создания HTTP-сервлетов, что является наиболее распространенным случаем. Этот класс предоставляет удобные методы для обработки различных типов HTTP-запросов и является стандартом для веб-приложений.

🤔 Итог:

GenericServlet — базовый класс для создания сервлетов, работающих с любыми протоколами, требует реализации метода service().

HttpServlet — специализированный класс для HTTP-сервлетов, предоставляет методы для обработки конкретных типов HTTP-запросов (GET, POST и т.д.), что упрощает разработку веб-приложений.

🔥 ТОП ВОПРОСОВ С СОБЕСОВ

🔒 База собесов | 🔒 База тестовых
Please open Telegram to view this post
VIEW IN TELEGRAM
4🤯1
📌 Почему HttpServlet класс объявлен как абстрактный?

💬 Спрашивают в 6 % собеседований

Класс HttpServlet объявлен как абстрактный, потому что он предназначен для предоставления базовой функциональности для создания HTTP-сервлетов, но не должен использоваться напрямую. Вместо этого разработчики должны расширять этот класс и переопределять методы, такие как doGet(), doPost(), doPut(), и т.д., для реализации конкретного поведения сервлета. Вот основные причины, почему HttpServlet объявлен абстрактным:

🤔 Основные причины, почему `HttpServlet` абстрактный:

1️⃣ Базовая функциональность:

HttpServlet предоставляет базовую реализацию методов, необходимых для обработки HTTP-запросов. Он реализует метод service(), который определяет логику маршрутизации запросов к соответствующим методам (doGet(), doPost(), и т.д.), но сами методы оставляет для переопределения.

2️⃣ Принуждение к переопределению:

Методы doGet(), doPost() и другие объявлены как защищенные и пустые. Это означает, что при создании нового HTTP-сервлета разработчик должен явно переопределить хотя бы один из этих методов для реализации необходимой логики.

Например:
     public class MyServlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// Реализация обработки GET-запросов
}
}


3️⃣ Предотвращение инстанцирования:

Объявление HttpServlet абстрактным предотвращает его прямое инстанцирование. Это делает невозможным создание экземпляра HttpServlet без предоставления конкретной реализации методов обработки запросов.

Например:
     HttpServlet servlet = new HttpServlet(); // Ошибка, так как HttpServlet абстрактный


4️⃣ Обеспечение расширяемости:

HttpServlet разработан с учетом того, что его будут расширять. Объявление класса абстрактным подчеркивает, что он предназначен для расширения, а не для использования как есть.

Это позволяет разработчикам создавать свои собственные сервлеты с минимальными усилиями, просто расширяя класс HttpServlet и переопределяя необходимые методы.

🤔 Пример:
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;

public class MyHttpServlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws IOException {
response.setContentType("text/html");
response.getWriter().println("<h1>Hello, World!</h1>");
}

@Override
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws IOException {
// Реализация обработки POST-запросов
}
}


🤔 Итог:

Класс HttpServlet объявлен абстрактным, чтобы обеспечить базовую функциональность для обработки HTTP-запросов, принудить разработчиков переопределять конкретные методы для создания своих собственных сервлетов и предотвратить создание экземпляров базового класса без реализации конкретной логики.

🔥 ТОП ВОПРОСОВ С СОБЕСОВ

🔒 База собесов | 🔒 База тестовых
Please open Telegram to view this post
VIEW IN TELEGRAM
👍5🤯1
📌 Какие основные методы присутствуют в классе HttpServlet?

💬 Спрашивают в 6 % собеседований

🤔 Основные методы в классе `HttpServlet`:

1️⃣ `doGet(HttpServletRequest req, HttpServletResponse resp)`: Обработка GET-запросов.

2️⃣ `doPost(HttpServletRequest req, HttpServletResponse resp)`: Обработка POST-запросов.

3️⃣ `doPut(HttpServletRequest req, HttpServletResponse resp)`: Обработка PUT-запросов.

4️⃣ `doDelete(HttpServletRequest req, HttpServletResponse resp)`: Обработка DELETE-запросов.

5️⃣ `doHead(HttpServletRequest req, HttpServletResponse resp)`: Обработка HEAD-запросов.

6️⃣ `doOptions(HttpServletRequest req, HttpServletResponse resp)`: Обработка OPTIONS-запросов.

7️⃣ `doTrace(HttpServletRequest req, HttpServletResponse resp)`: Обработка TRACE-запросов.

8️⃣ `service(HttpServletRequest req, HttpServletResponse resp)`: Маршрутизация запросов к соответствующим методам.

🔥 ТОП ВОПРОСОВ С СОБЕСОВ

🔒 База собесов | 🔒 База тестовых
Please open Telegram to view this post
VIEW IN TELEGRAM
👍71🤯1
📌 Какой метод HTTP не является неизменяемым?

💬 Спрашивают в 6 % собеседований

Метод HTTP, который не является неизменяемым, — это POST.

🤔 Почему метод POST не является неизменяемым:

Изменяемый: Метод POST предназначен для отправки данных к серверу для создания или обновления ресурса. В отличие от неизменяемых методов, таких как GET, POST может изменять состояние сервера, например, добавлять новые записи в базу данных или изменять существующие.

Тело запроса: POST-запросы включают данные в теле запроса, которые сервер обрабатывает для выполнения операций, изменяющих состояние.

Идэмпотентность: POST не является идэмпотентным, что означает, что повторное выполнение одного и того же POST-запроса может привести к разным результатам, например, к созданию нескольких одинаковых ресурсов.

🤔 Пример использования POST:
<form action="/submit" method="post">
<input type="text" name="username">
<input type="password" name="password">
<button type="submit">Submit</button>
</form>


🤔 Итог:

Метод POST не является неизменяемым, так как он используется для операций, изменяющих состояние сервера, таких как создание или обновление ресурсов.

🔥 ТОП ВОПРОСОВ С СОБЕСОВ

🔒 База собесов | 🔒 База тестовых
Please open Telegram to view this post
VIEW IN TELEGRAM
👍151
📌 Какие есть методы отправки данных с клиента на сервер?

💬 Спрашивают в 6 % собеседований

🤔 Основные методы отправки данных с клиента на сервер:

1️⃣ GET

Описание: Отправляет данные в URL запроса.

Использование: Получение данных без изменения состояния сервера.

Пример:
     <form action="/search" method="get">
<input type="text" name="query">
<button type="submit">Search</button>
</form>


2️⃣ POST

Описание: Отправляет данные в теле запроса.

Использование: Создание или обновление ресурсов на сервере.

Пример:
     <form action="/submit" method="post">
<input type="text" name="username">
<input type="password" name="password">
<button type="submit">Submit</button>
</form>


3️⃣ PUT

Описание: Отправляет данные для замены существующего ресурса.

Использование: Обновление ресурса целиком.

Пример:
     fetch('/update', {
method: 'PUT',
headers: {
'Content-Type': 'application/json'
},
body: JSON.stringify({ id: 1, name: 'Updated Name' })
});


4️⃣ DELETE

Описание: Отправляет запрос на удаление ресурса.

Использование: Удаление ресурса на сервере.

Пример:
     fetch('/delete/1', {
method: 'DELETE'
});


5️⃣ PATCH

Описание: Отправляет данные для частичного обновления ресурса.

Использование: Частичное обновление ресурса.

Пример:
     fetch('/update', {
method: 'PATCH',
headers: {
'Content-Type': 'application/json'
},
body: JSON.stringify({ name: 'Partially Updated Name' })
});


6️⃣ OPTIONS

Описание: Запрашивает информацию о поддерживаемых методах и опциях для ресурса.

Использование: Определение возможностей сервера.

Пример:
     fetch('/resource', {
method: 'OPTIONS'
});


🤔 Итог:

Методы отправки данных с клиента на сервер включают GET, POST, PUT, DELETE, PATCH и OPTIONS. Каждый из них используется для различных целей: от получения данных до создания, обновления и удаления ресурсов.

🔥 ТОП ВОПРОСОВ С СОБЕСОВ

🔒 База собесов | 🔒 База тестовых
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥9👍6
📌 В чем разница между методами GET и POST?

💬 Спрашивают в 6 % собеседований

🤔 Основные различия между методами GET и POST:

1️⃣ Расположение данных:

GET: Данные передаются в URL строки запроса. Это ограничивает объем данных и делает их видимыми в адресной строке.

POST: Данные передаются в теле HTTP-запроса, что позволяет отправлять большие объемы данных и скрывать их от посторонних глаз.

2️⃣ Размер данных:

GET: Ограничен длиной URL (в некоторых браузерах и серверах может быть ограничение около 2000 символов).

POST: Не имеет ограничений на размер данных (ограничения могут накладываться только сервером).

3️⃣ Идэмпотентность:

GET: Идэмпотентен, что означает, что повторное выполнение запроса не изменяет состояние сервера. Используется для запросов, которые не изменяют данные.

POST: Не является идэмпотентным, повторный запрос может привести к созданию или изменению данных на сервере.

4️⃣ Кэширование:

GET: Может быть кэширован браузером или прокси-сервером, что позволяет повторно использовать результаты запросов.

POST: Обычно не кэшируется, так как используется для изменения состояния сервера.

5️⃣ Безопасность:

GET: Данные видны в URL, что делает их менее безопасными для передачи чувствительной информации (например, паролей).

POST: Данные передаются в теле запроса, что делает их менее видимыми, но все равно требует использования HTTPS для защиты данных.

6️⃣ Использование:

GET: Используется для получения данных с сервера, например, запросы на получение HTML-страниц или результатов поиска.

POST: Используется для отправки данных на сервер, например, формы для регистрации пользователей, загрузки файлов и т.д.

🤔 Примеры использования:

1️⃣ GET:
<form action="/search" method="get">
<input type="text" name="query">
<button type="submit">Search</button>
</form>


URL после отправки: https://example.com/search?query=something

2️⃣ POST:
<form action="/submit" method="post">
<input type="text" name="username">
<input type="password" name="password">
<button type="submit">Submit</button>
</form>


Данные передаются в теле запроса, URL не меняется.

🤔 Итог:

GET: Используется для получения данных, передает данные в URL, ограничен размером данных, кэшируется, идэмпотентен, менее безопасен для чувствительной информации.

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

🔥 ТОП ВОПРОСОВ С СОБЕСОВ

🔒 База собесов | 🔒 База тестовых
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥13👍52
🤔 В чем разница между PrintWriter и ServletOutputStream?

PrintWriter и ServletOutputStream — это два класса в Java Servlet API, используемых для записи данных в ответ сервлета, но они имеют разные предназначения и используются в разных ситуациях.

🚩Основные различия между `PrintWriter` и `ServletOutputStream`:

Тип данных:
🟠`PrintWriter`: Используется для записи текстовых данных. Поддерживает методы для работы с символами и строками.
🟠`ServletOutputStream`: Используется для записи бинарных данных. Поддерживает методы для работы с байтами.

Применение:
🟠`PrintWriter`: Идеально подходит для отправки текстовых данных, таких как HTML, XML, или JSON. Он предоставляет методы для удобной записи строк и символов.
     response.setContentType("text/html");
PrintWriter out = response.getWriter();
out.println("<html><body><h1>Hello, World!</h1></body></html>");


🟠`ServletOutputStream`: Предназначен для отправки бинарных данных, таких как изображения, PDF-файлы или другие байтовые потоки. Он предоставляет методы для записи массивов байтов и отдельных байтов.
     response.setContentType("application/pdf");
ServletOutputStream out = response.getOutputStream();
byte[] pdfData = ...; // получить PDF данные
out.write(pdfData);


Комбинирование:
🟠`PrintWriter`: Нельзя использовать одновременно с ServletOutputStream в одном запросе, так как оба метода открывают ответный поток в разных режимах (символьный и байтовый).
🟠`ServletOutputStream`: Нельзя использовать одновременно с PrintWriter по той же причине.

Методы получения:
🟠`PrintWriter`: PrintWriter writer = response.getWriter();
🟠`ServletOutputStream`: ServletOutputStream outputStream = response.getOutputStream();

🚩Примеры:

Использование PrintWriter:
import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.PrintWriter;

public class TextServlet extends HttpServlet {
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
response.setContentType("text/html");
PrintWriter out = response.getWriter();
out.println("<html><body><h1>Hello, World!</h1></body></html>");
}
}


Использование ServletOutputStream:
import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.ServletOutputStream;

public class BinaryServlet extends HttpServlet {
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
response.setContentType("application/pdf");
ServletOutputStream out = response.getOutputStream();
byte[] pdfData = ...; // получить PDF данные
out.write(pdfData);
}
}


Ставь 👍 и забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
👍6🤯1