Anonymous Quiz
5%
Set
80%
List
13%
Map
2%
Queue
👍7❤1
Предоставляется возможность уведомления объектов, находящихся в сессии, о том, что сессия становится недействительной или заканчивается. Для этого объекты могут реализовывать интерфейс
HttpSessionBindingListener или HttpSessionListener.Использование HttpSessionBindingListener
Позволяет объектам узнавать, когда они добавляются или удаляются из сессии.
Методы интерфейса HttpSessionBindingListener
valueBound(HttpSessionBindingEvent event): Вызывается, когда объект добавляется в сессию.valueUnbound(HttpSessionBindingEvent event): Вызывается, когда объект удаляется из сессии или когда сессия становится недействительной.import javax.servlet.http.HttpSessionBindingEvent;
import javax.servlet.http.HttpSessionBindingListener;
public class MySessionObject implements HttpSessionBindingListener {
@Override
public void valueBound(HttpSessionBindingEvent event) {
// Код, который выполняется при добавлении объекта в сессию
System.out.println("Object bound to session: " + event.getSession().getId());
}
@Override
public void valueUnbound(HttpSessionBindingEvent event) {
// Код, который выполняется при удалении объекта из сессии или при завершении сессии
System.out.println("Object unbound from session: " + event.getSession().getId());
}
}
Добавление объекта в сессию
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import java.io.IOException;
@WebServlet("/addObject")
public class AddObjectServlet extends HttpServlet {
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
HttpSession session = request.getSession();
MySessionObject myObject = new MySessionObject();
session.setAttribute("myObject", myObject);
response.getWriter().println("Object added to session.");
}
}
Использование HttpSessionListener
Позволяет отслеживать события создания и уничтожения сессии на уровне приложения.
Методы интерфейса HttpSessionListener
sessionCreated(HttpSessionEvent se): Вызывается при создании сессии.sessionDestroyed(HttpSessionEvent se): Вызывается при уничтожении сессии.import javax.servlet.annotation.WebListener;
import javax.servlet.http.HttpSessionEvent;
import javax.servlet.http.HttpSessionListener;
@WebListener
public class MySessionListener implements HttpSessionListener {
@Override
public void sessionCreated(HttpSessionEvent se) {
// Код, который выполняется при создании новой сессии
System.out.println("Session created: " + se.getSession().getId());
}
@Override
public void sessionDestroyed(HttpSessionEvent se) {
// Код, который выполняется при завершении сессии
System.out.println("Session destroyed: " + se.getSession().getId());
}
}
Регистрация слушателей
Если вы не используете аннотации, вы можете зарегистрировать слушателей в файле
web.xml.<web-app ...>
<listener>
<listener-class>com.example.MySessionListener</listener-class>
</listener>
</web-app>
Чтобы уведомить объект в сессии о том, что сессия стала недействительной или закончилась, объект может реализовывать интерфейс
HttpSessionBindingListener. Для отслеживания событий создания и уничтожения сессий на уровне приложения используется интерфейс HttpSessionListener. Оба интерфейса позволяют выполнять необходимые действия при изменении состояния сессий и управлять ресурсами эффективно.Please open Telegram to view this post
VIEW IN TELEGRAM
👍10❤1👾1
Anonymous Quiz
25%
JVM — среда выполнения, JDK — набор инстр. для разработки, JRE — библ. классов
13%
JVM — компилятор, JDK — среда выполнения, JRE — набор инстр. для разработки
6%
JVM — набор инстр. для разработки, JDK — библ. классов, JRE — среда выполнения
56%
JVM — среда выполнения, JDK — набор инстр. для разработки, JRE — среда выполнения и библ. классов
👍6
Для обеспечения доступа к сервлетам только для пользователей с действительной сессией и правильными учетными данными существует несколько подходов. Один из эффективных способов — это использование фильтров (Servlet Filters) для проверки сессии перед обработкой запроса сервлетом.
Использование Servlet Filters для проверки сессии
Позволяют перехватывать запросы к сервлетам и выполнять необходимые проверки или обработки до передачи запроса сервлету. Вы можете создать фильтр для проверки наличия и корректности сессии пользователя.
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.FilterServletRequest;
import javax.servlet.FilterServletResponse;
import javax.servlet.annotation.WebFilter;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import java.io.IOException;
@WebFilter("/*") // Применение фильтра ко всем запросам
public class SessionValidationFilter implements Filter {
@Override
public void init(FilterConfig filterConfig) throws ServletException {
// Инициализация фильтра (если необходимо)
}
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
HttpServletRequest httpRequest = (HttpServletRequest) request;
HttpServletResponse httpResponse = (HttpServletResponse) response;
HttpSession session = httpRequest.getSession(false); // false означает не создавать новую сессию, если она отсутствует
// Проверка наличия сессии и атрибутов сессии (например, логин пользователя)
if (session == null || session.getAttribute("user") == null) {
// Перенаправление на страницу логина, если сессия недействительна
httpResponse.sendRedirect(httpRequest.getContextPath() + "/login");
} else {
// Продолжение цепочки фильтров и передача запроса сервлету
chain.doFilter(request, response);
}
}
@Override
public void destroy() {
// Очистка ресурсов фильтра (если необходимо)
}
}
<web-app ...>
<filter>
<filter-name>SessionValidationFilter</filter-name>
<filter-class>com.example.SessionValidationFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>SessionValidationFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
</web-app>
Использование декларативной безопасности
Позволяет ограничивать доступ к ресурсам на основе ролей пользователей, что тоже может помочь в контроле доступа к сервлетам.
<web-app ...>
<security-constraint>
<web-resource-collection>
<web-resource-name>Protected Area</web-resource-name>
<url-pattern>/protected/*</url-pattern>
</web-resource-collection>
<auth-constraint>
<role-name>USER</role-name>
</auth-constraint>
</security-constraint>
<login-config>
<auth-method>FORM</auth-method>
<form-login-config>
<form-login-page>/login.html</form-login-page>
<form-error-page>/login-error.html</form-error-page>
</form-login-config>
</login-config>
<security-role>
<role-name>USER</role-name>
</security-role>
</web-app>
Для обеспечения доступа к сервлетам только для пользователей с действительной сессией наиболее эффективным способом является использование Servlet Filters для проверки сессии. Фильтры позволяют централизованно управлять доступом к ресурсам и обеспечивать безопасность, а также можно использовать декларативную безопасность в web.xml для управления доступом на основе ролей.
Please open Telegram to view this post
VIEW IN TELEGRAM
❤4🤯2👍1
Anonymous Quiz
0%
Определение переменной
1%
Метод в программе
90%
Описание объекта с его состоянием и поведением
9%
Тип данных
❤4👍2
 Спросят с вероятностью 6%
Для обеспечения Transport Layer Security (TLS) в веб-приложении используются протоколы HTTPS (HTTP over TLS/SSL), которые обеспечивают защищенное соединение между клиентом и сервером. Это защищает данные от перехвата и подмены во время передачи. Внедрение его включает несколько шагов:
Для использования HTTPS на вашем веб-сервере, вам потребуется SSL/TLS сертификат, который можно получить у сертификационного центра (CA). Некоторые популярные CA включают:
В зависимости от вашего веб-сервера (Apache, Nginx, Tomcat и т.д.), процесс настройки будет различаться.
Apache HTTP Server
Убедитесь, что модуль
mod_ssl установлен и включен.sudo a2enmod ssl
sudo systemctl restart apache2
Отредактируйте файл конфигурации виртуального хоста (например,
/etc/apache2/sites-available/your-site.conf):<VirtualHost *:443>
ServerName example.com
DocumentRoot /var/www/html
SSLEngine on
SSLCertificateFile /path/to/your_certificate.crt
SSLCertificateKeyFile /path/to/your_private.key
SSLCertificateChainFile /path/to/chain_file.crt
<Directory /var/www/html>
Options Indexes FollowSymLinks
AllowOverride All
Require all granted
</Directory>
</VirtualHost>
sudo systemctl restart apache2
Nginx
Отредактируйте файл конфигурации вашего сайта (например,
/etc/nginx/sites-available/your-site): server {
listen 443 ssl;
server_name example.com;
ssl_certificate /path/to/your_certificate.crt;
ssl_certificate_key /path/to/your_private.key;
root /var/www/html;
index index.html index.htm;
location / {
try_files $uri $uri/ =404;
}
}
server {
listen 80;
server_name example.com;
return 301 https://$host$request_uri;
}
Перезапуск Nginx:
sudo systemctl restart nginx
Apache Tomcat
Отредактируйте файл
server.xml (например, conf/server.xml):<Connector port="8443" protocol="org.apache.coyote.http11.Http11NioProtocol"
maxThreads="150" SSLEnabled="true">
<SSLHostConfig>
<Certificate certificateKeystoreFile="conf/your_keystore.jks"
type="RSA" />
</SSLHostConfig>
</Connector>
Создайте keystore и получите сертификат от CA, затем импортируйте сертификат в keystore:
keytool -genkey -alias tomcat -keyalg RSA -keystore your_keystore.jks
keytool -import -alias tomcat -file your_certificate.crt -keystore your_keystore.jks
Перезапуск Tomcat:
sudo systemctl restart tomcat
Рекомендуется перенаправлять все HTTP-запросы на HTTPS для обеспечения полной безопасности. Примеры для различных серверов:
Apache HTTP Server
Внутри виртуального хоста для порта 80 добавьте перенаправление:
<VirtualHost *:80>
ServerName example.com
Redirect permanent / https://example.com/
</VirtualHost>
Для обеспечения Transport Layer Security (TLS) вашего веб-приложения:
Secure для защиты данных сессий.Эти шаги помогут вам защитить данные пользователя и предотвратить перехват и подмену данных во время передачи.
Please open Telegram to view this post
VIEW IN TELEGRAM
👍8❤2🤯1
Настройка подключения к базе данных и журналирования в сервлете
Шаг 1: Настройка пула соединений к базе данных
Использование пула соединений (например, Apache DBCP) позволяет эффективно управлять соединениями, улучшая производительность и стабильность приложения.
<dependencies>
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-dbcp2</artifactId>
<version>2.9.0</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.26</version>
</dependency>
</dependencies>
import org.apache.commons.dbcp2.BasicDataSource;
public class DatabaseUtil {
private static BasicDataSource dataSource;
static {
dataSource = new BasicDataSource();
dataSource.setUrl("jdbc:mysql://localhost:3306/your_database");
dataSource.setUsername("your_username");
dataSource.setPassword("your_password");
dataSource.setMinIdle(5);
dataSource.setMaxIdle(10);
dataSource.setMaxOpenPreparedStatements(100);
}
public static Connection getConnection() throws SQLException {
return dataSource.getConnection();
}
}
Шаг 2: Настройка логирования (SLF4J и Logback)
<dependencies>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.7.32</version>
</dependency>
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-classic</artifactId>
<version>1.2.6</version>
</dependency>
</dependencies>
<configuration>
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss} %-5level %logger{36} - %msg%n</pattern>
</encoder>
</appender>
<root level="debug">
<appender-ref ref="STDOUT" />
</root>
</configuration>
Шаг 3: Подключение к базе данных и логирование в сервлете
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.*;
import java.io.*;
import java.sql.*;
import org.slf4j.*;
@WebServlet("/databaseServlet")
public class DatabaseServlet extends HttpServlet {
private static final Logger logger = LoggerFactory.getLogger(DatabaseServlet.class);
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws IOException {
response.setContentType("text/html");
try (PrintWriter out = response.getWriter();
Connection connection = DatabaseUtil.getConnection();
PreparedStatement statement = connection.prepareStatement("SELECT * FROM your_table");
ResultSet resultSet = statement.executeQuery()) {
while (resultSet.next()) {
out.println("<p>" + resultSet.getString("your_column") + "</p>");
}
} catch (SQLException e) {
logger.error("Database connection error", e);
response.getWriter().println("<p>Error connecting to the database</p>");
}
}
}
Для организации подключения к базе данных и обеспечения журналирования в сервлете:
Please open Telegram to view this post
VIEW IN TELEGRAM
🤯4👍2
Спецификация Servlet 3.0, выпущенная как часть Java EE 6, внесла множество новых особенностей и улучшений в Java Servlet API. Основные нововведения включают поддержку аннотаций, асинхронную обработку запросов, облегчение настройки сервлетов и фильтров, а также улучшенную безопасность. Рассмотрим эти особенности подробнее:
Введены аннотации, которые позволяют конфигурировать сервлеты, фильтры и слушатели без необходимости редактирования файла
web.xml. Это значительно упрощает процесс разработки и улучшает читаемость кода.import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
@WebServlet("/example")
public class ExampleServlet extends HttpServlet {
// Реализация сервлета
}
@WebFilter: для регистрации фильтра.import javax.servlet.annotation.WebFilter;
import javax.servlet.Filter;
@WebFilter("/*")
public class ExampleFilter implements Filter {
// Реализация фильтра
}
@WebListener: для регистрации слушателя.import javax.servlet.annotation.WebListener;
import javax.servlet.ServletContextListener;
@WebListener
public class ExampleListener implements ServletContextListener {
// Реализация слушателя
}
Servlet 3.0 добавляет поддержку асинхронной обработки запросов, что позволяет сервлетам обрабатывать долгосрочные задачи, не блокируя основной поток. Это полезно для улучшения производительности и масштабируемости.
import java.io.IOException;
import javax.servlet.AsyncContext;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
@WebServlet(urlPatterns = "/asyncExample", asyncSupported = true)
public class AsyncExampleServlet extends HttpServlet {
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
final AsyncContext asyncContext = request.startAsync();
asyncContext.start(() -> {
try {
// Долгосрочная задача
Thread.sleep(5000);
response.getWriter().println("Asynchronous processing complete.");
asyncContext.complete();
} catch (Exception e) {
e.printStackTrace();
}
});
}
}
Servlet 3.0 позволяет динамически добавлять сервлеты, фильтры и слушатели программно в
ServletContextListener или в любое другое место, где доступен ServletContext.import javax.servlet.ServletContext;
import javax.servlet.ServletContextEvent;
import javax.servlet.ServletContextListener;
import javax.servlet.ServletRegistration;
public class DynamicServletRegistrationListener implements ServletContextListener {
@Override
public void contextInitialized(ServletContextEvent sce) {
ServletContext context = sce.getServletContext();
ServletRegistration.Dynamic registration = context.addServlet("dynamicServlet", new ExampleServlet());
registration.addMapping("/dynamic");
}
@Override
public void contextDestroyed(ServletContextEvent sce) {
// Очистка ресурсов (если необходимо)
}
}
Servlet 3.0 ввел множество полезных особенностей, таких как поддержка аннотаций для конфигурации сервлетов, фильтров и слушателей, асинхронная обработка запросов для улучшения производительности, динамическое добавление компонентов, улучшенная безопасность и общая легкость настройки. Эти нововведения значительно упростили разработку и повысили гибкость и масштабируемость веб-приложений.
Please open Telegram to view this post
VIEW IN TELEGRAM
👍6🤯1
Доступны несколько способов аутентификации пользователей, чтобы обеспечить безопасность веб-приложений. Вот основные из них:
Базовая аутентификация использует заголовок HTTP для передачи имени пользователя и пароля в закодированном виде Base64.
<security-constraint>
<web-resource-collection>
<web-resource-name>Protected Area</web-resource-name>
<url-pattern>/protected/*</url-pattern>
</web-resource-collection>
<auth-constraint>
<role-name>USER</role-name>
</auth-constraint>
</security-constraint>
<login-config>
<auth-method>BASIC</auth-method>
<realm-name>MyRealm</realm-name>
</login-config>
<security-role>
<role-name>USER</role-name>
</security-role>
Этот метод позволяет создать пользовательский интерфейс для аутентификации с помощью HTML-форм.
<security-constraint>
<web-resource-collection>
<web-resource-name>Protected Area</web-resource-name>
<url-pattern>/protected/*</url-pattern>
</web-resource-collection>
<auth-constraint>
<role-name>USER</role-name>
</auth-constraint>
</security-constraint>
<login-config>
<auth-method>FORM</auth-method>
<form-login-config>
<form-login-page>/login.html</form-login-page>
<form-error-page>/login-error.html</form-error-page>
</form-login-config>
</login-config>
<security-role>
<role-name>USER</role-name>
</security-role>
Используется сертификат клиента для аутентификации.
<security-constraint>
<web-resource-collection>
<web-resource-name>Protected Area</web-resource-name>
<url-pattern>/protected/*</url-pattern>
</web-resource-collection>
<auth-constraint>
<role-name>USER</role-name>
</auth-constraint>
</security-constraint>
<login-config>
<auth-method>CLIENT-CERT</auth-method>
</login-config>
<security-role>
<role-name>USER</role-name>
</security-role>
Важные моменты
Доступные методы аутентификации для сервлетов включают:
Выбор метода зависит от требований безопасности и удобства пользователей вашего веб-приложения.
Please open Telegram to view this post
VIEW IN TELEGRAM
🤯3🔥1🤔1
Java Server Pages (JSP) — это технология, которая позволяет создавать динамически генерируемые веб-страницы на стороне сервера с использованием Java. Страницы комбинируют HTML, XML или другие виды данных с Java кодом для создания веб-контента, который может взаимодействовать с пользователями, обрабатывать данные и взаимодействовать с серверными ресурсами.
Особенности
Основные элементы
<% ... %>
<%
String message = "Hello, World!";
%>
<p><%= message %></p>
<%= ... %>
<p>Current time: <%= new java.util.Date() %></p>
<%@ ... %>
<%@ page contentType="text/html;charset=UTF-8" %>
${ ... }
<p>User: ${user.name}</p>
<jsp:include page="header.jsp" />
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<noscript>JSP Example</noscript>
</head>
<body>
<h1>Welcome to JSP!</h1>
<%
String username = "John Doe";
%>
<p>Hello, <%= username %></p>
<p>Current time: <%= new java.util.Date() %></p>
</body>
</html>
Важные моменты
Java Server Pages (JSP) — это технология для создания динамически генерируемых веб-страниц на стороне сервера, которая позволяет смешивать HTML с Java кодом. Страницы компилируются в сервлеты, что обеспечивает высокую производительность и гибкость в разработке веб-приложений. Основные элементы включают скриптлеты, выражения, директивы, выражения языка JSP (EL) и теги. Является важным компонентом архитектуры MVC и широко используется для создания интерактивных и динамичных веб-приложений.
Please open Telegram to view this post
VIEW IN TELEGRAM
👍10🤔1👀1
Anonymous Quiz
9%
Тип данных для создания числовых констант
3%
Класс для работы с коллекциями
87%
Тип данных для определения набора именованных значений
1%
Класс для работы с потоками
👍5😁5❤1
Java Server Pages (JSP) является мощной технологией для создания динамически генерируемых веб-страниц на стороне сервера. Предоставляет множество преимуществ и решает ряд задач, которые делают его необходимым в разработке веб-приложений:
Позволяет создавать веб-страницы, контент которых может изменяться в зависимости от запросов пользователя, данных из базы данных или других серверных ресурсов.
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<noscript>Dynamic Content</noscript>
</head>
<body>
<h1>Welcome, <%= request.getParameter("username") %>!</h1>
</body>
</html>
Используется в архитектуре для разделения бизнес-логики (которая обрабатывается сервлетами или другими компонентами) и представления (отображение данных пользователю).
@WebServlet("/greeting")
public class GreetingServlet extends HttpServlet {
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
String name = request.getParameter("name");
request.setAttribute("name", name);
request.getRequestDispatcher("/greeting.jsp").forward(request, response);
}
}
<html>
<head><noscript>Greeting</noscript></head>
<body>
<h1>Hello, ${name}!</h1>
</body>
</html>
Может легко интегрироваться с JavaBeans, EJB и другими серверными компонентами для управления данными и бизнес-логикой.
<jsp:useBean id="user" class="com.example.User" scope="request"/>
<p>Username: <jsp:getProperty name="user" property="username"/></p>
Упрощает доступ к данным и позволяет использовать упрощенный синтаксис для работы с атрибутами запросов, сессий и других областей.
<p>Current user: ${user.username}</p>Позволяет использовать теги и фрагменты JSP (JSP include и tag libraries) для создания модульных и повторно используемых компонентов.
<%@ include file="header.jsp" %>
<%@ include file="footer.jsp" %>
Страницы по синтаксису похожи на HTML, что делает их доступными для веб-дизайнеров и разработчиков с минимальным опытом программирования на Java.
Страницы компилируются в сервлеты, что обеспечивает высокую производительность и возможность кэширования для последующих запросов.
Является частью спецификации Java EE, что обеспечивает соответствие стандартам и хорошую интеграцию с другими технологиями Java EE.
JSP нужен для создания динамически генерируемых веб-страниц, разделения логики и представления (MVC), интеграции с JavaBeans и другими компонентами, упрощенного доступа к данным с помощью EL, повторного использования компонентов и модульности, а также обеспечения высокой производительности и соответствия международным стандартам. Делает разработку веб-приложений удобной и эффективной, предоставляя мощные инструменты для создания интерактивного и динамичного контента.
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥3👍1
Anonymous Quiz
6%
Шаблон проектирования
81%
Компонентная модель для создания многократно используемых компонентов
9%
Фреймворк для разработки веб-приложений
4%
Библиотека для работы с XML
🤯9😁5👍1
Java Server Pages (JSP) является мощной технологией для создания динамически генерируемых веб-страниц на стороне сервера. Предоставляет множество преимуществ и решает ряд задач, которые делают его необходимым в разработке веб-приложений:
add(), remove(), size(), isEmpty() и iterator(), которые должны быть реализованы всеми коллекциями.ArrayList, LinkedList и Vector.HashSet, LinkedHashSet и TreeSet.LinkedList реализует как List, так и Queue. Также есть PriorityQueue для элементов, которые должны обрабатываться в порядке приоритета.Collection интерфейса. Описывает структуру для хранения пар ключ/значение. Ключи уникальны, а значения могут дублироваться. Реализации включают HashMap, LinkedHashMap, TreeMap и Hashtable.HashSet, сохраняя порядок вставки элементов.HashMap, сохраняя порядок вставки ключей.Иерархия коллекций обеспечивает унифицированный способ работы с различными типами данных. Она предоставляет гибкость для выбора подходящей структуры данных в зависимости от требований к производительности, порядку элементов и уникальности значений. Использование этих коллекций позволяет разработчикам эффективно хранить, извлекать, удалять и обрабатывать данные в Java-приложениях.
Please open Telegram to view this post
VIEW IN TELEGRAM
❤10🤯5👍3🔥1
Anonymous Quiz
76%
System.exit()
9%
Runtime.exit()
5%
Program.terminate()
10%
Application.shutdown()
❤1👍1
SOLID — это акроним, представляющий пять основных принципов ООП и дизайна, направленных на повышение гибкости, масштабируемости и поддерживаемости ПО. Они помогает избежать проблемы с проектированием, такие как жесткая зависимость между компонентами программы и сложности в внесении изменений или добавлении новых функций.
class UserSettings {
void changeEmail(User user) {
if(checkAccess(user)) {
// Изменение email пользователя
}
}
boolean checkAccess(User user) {
// Проверка прав доступа
return true;
}
}Здесь класс
UserSettings нарушает SRP, если бы в нем также были методы для управления пользователями. Лучше вынести метод checkAccess в отдельный класс.SOLID принципы направлены на создание гибкой, масштабируемой архитектуры, которая легко поддается изменениям и развитию. Используя эти принципы, можно создавать системы, которые легче понимать, поддерживать и расширять.
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥16👍10🎉1
Anonymous Quiz
4%
Библиотека для работы с сетевыми соединениями
94%
Библиотека для работы с базами данных
1%
Библиотека для работы с графическим интерфейсом
1%
Библиотека для работы с файловой системой
🤯20😁3❤2👍2
Иерархия исключений организована в виде дерева наследования, где все классы исключений являются потомками класса Throwable. Он делится на два основных подкласса: Error и Exception.
От него напрямую наследуются классы Error и Exception. Этот класс содержит методы для получения сообщения об ошибке, локализованного сообщения, причины исключения и стека вызовов, а также методы для подавления исключений и работы со стеком вызовов.
Error описывает серьёзные ошибки, возникающие на уровне виртуальной машины и библиотеки языка, из-за которых приложение обычно не может восстановиться. Примеры включают OutOfMemoryError и StackOverflowError. Ошибки этого типа обычно не предназначены для обработки приложением.
Являются непроверяемыми исключениями. Они обозначают ошибки, такие как неверное приведение типов (ClassCastException), обращение по нулевой ссылке (NullPointerException) и выход за пределы массива (ArrayIndexOutOfBoundsException). Эти исключения не требуют обязательной обработки в блоке try-catch.
Требуют обязательной обработки в блоке try-catch или должны быть объявлены в сигнатуре метода с помощью throws. Они бозначают условия, с которыми приложение может предвидеть и справиться. Примеры включают IOException, FileNotFoundException и ClassNotFoundException.
Иерархия исключений обеспечивает структурированный и гибкий способ обработки ошибок и исключительных ситуаций в приложениях. Позволяет различать серьёзные проблемы системного уровня, с которыми приложение не может справиться.
Please open Telegram to view this post
VIEW IN TELEGRAM
👍18🔥8
Anonymous Quiz
2%
public
12%
private
37%
protected
49%
default
😁16👀3❤1👍1
Object - суперкласс для всех классов. Все объекты, включая массивы, наследуют методы этого класса. Они предоставляют функции, которые доступны для любого объекта. Вот основные методы:
clone() - создает и возвращает копию объекта. Метод защищенный, поэтому его можно вызвать только внутри класса объекта или в классах потомках.equals(Object obj) - определяет равенство между двумя объектами. По умолчанию, этот метод сравнивает ссылки на объекты.finalize() - вызывается перед удалением объекта сборщиком мусора. Метод устарел.getClass() - возвращает Class, который представляет класс данного объекта. Можно использовать для получения имени во время выполнения.hashCode() - возвращает хеш-код, который используется для оптимизации хранения в структурах данных.notify() - пробуждает один поток, который ожидает на объекте (вызвавший wait()). Этот метод должен вызываться в синхронизированном контексте.notifyAll() - пробуждает все ожидающие потоки. Должен вызываться в синхронизированном контексте.toString() - возвращает строковое представление. По умолчанию, возвращает класс и хеш-код, но часто переопределяется для предоставления более информативного представления.wait() - заставляет текущий поток ожидать, пока другой поток не вызовет notify() или notifyAll(). Существуют перегруженные версии wait(long timeout) и wait(long timeout, int nanos), позволяющие указать максимальное время ожидания.Эти методы предоставляют основу для механизмов, таких как сравнение объектов, их клонирование, уведомление и ожидание в многопоточных средах, а также для работы с хеш-таблицами. Играют важную роль в проектировании и реализации Java-программ.
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥10❤3👍3
Anonymous Quiz
65%
Runnable
33%
Thread
2%
Callable
1%
Future
🤯5👍3❤2