У меня есть приложение, которое размещает файловый сервер в функции main(), оно работает очень хорошо, когда приложение находится в основном рабочем процессе в качестве текущего действия, используемого пользователем, но мне нужно, чтобы оно работало в фоновом режиме с выключенным экраном. На самом деле в фоновом режиме он тоже работал, но только пока батарея заряжалась. Я пробовал использовать блокировку Power Manager, но это не дало эффекта, более того, автоматический перезапуск не работал в фоновом режиме.
Мне нужно, чтобы это приложение работало в фоновом режиме, в том числе с выключенным экраном, даже когда аккумулятор не находится в состоянии зарядки.
Кроме того, мне нужно, чтобы оно автоматически перезапускалось в случае исключения или других сбоев.
package com.example.serverquestion;
import android.app.Application;
import android.content.Intent;
import android.os.Bundle;
import android.os.PowerManager;
import android.view.WindowManager;
import androidx.annotation.NonNull;
import androidx.appcompat.app.AppCompatActivity;
import androidx.core.content.ContextCompat;
import com.example.serverquestion.databinding.ActivityMainBinding;
import java.io.IOException;
import java.net.ServerSocket;
import java.net.Socket;
//
public class MainActivity extends AppCompatActivity {
private ActivityMainBinding binding;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
//It didn't work while in background process:
Thread.setDefaultUncaughtExceptionHandler(new Thread.UncaughtExceptionHandler(){
@Override
public void uncaughtException(@NonNull Thread t, @NonNull Throwable e) {
final Application app = getApplication();
Intent launchIntentForPackage = app.getPackageManager().getLaunchIntentForPackage(app.getPackageName());
if (launchIntentForPackage != null) {
launchIntentForPackage.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP | Intent.FLAG_ACTIVITY_CLEAR_TASK);
ContextCompat.startActivity(app, launchIntentForPackage, null);
System.exit(2);
}
}
});
binding = ActivityMainBinding.inflate(getLayoutInflater());
setContentView(binding.getRoot());
getWindow().addFlags(WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON);
main(null);
}
private static void main(String[] args){
new Thread(){
public void run() {
try {
ServerSocket server = new ServerSocket(8081);
while(true) {
new SocketInitializator(server.accept()).start();
}
} catch(IOException e){
e.printStackTrace();
}
}
}.start();
}
private static class SocketInitializator extends Thread {
private final Socket socket;
SocketInitializator(Socket socket){
this.socket = socket;
}
public void run() {
try {
byte[] request_bytes = new byte[socket.getInputStream().available()];
socket.getInputStream().read(request_bytes);
String request = new String(request_bytes);
if(request.contains("exception")){//127.0.0.1:8081/exception to test restart in case of failure
throw new IllegalArgumentException("Server must restart automatically after exception");
}
String response = "HTTP/1.1 200 Ok\r\n\r\nHello World!";
socket.getOutputStream().write(response.getBytes("UTF-8"));
socket.close();
} catch(IOException e){
e.printStackTrace();
}
}
}
}
Это не помогло сохранить процесс, пока он не находится в состоянии зарядки аккумулятора и когда экран выключен:
//
@Override
protected void onCreate(Bundle savedInstanceState) {
...
PowerManager powerManager = (PowerManager) getSystemService(POWER_SERVICE);
PowerManager.WakeLock wakeLock = powerManager.newWakeLock(PowerManager.PARTIAL_WAKE_LOCK, "MainActivity::MyWakelockTag");
wakeLock.acquire();
...
}
Я пытался выполнить main() в службе переднего плана, но ничего не произошло
@Override
protected void onCreate(Bundle savedInstanceState) {
...
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
Intent serviceIntent = new Intent(this, MyForegroundService.class);
startForegroundService(serviceIntent); // For Android 8.0 (API 26) and above
}
...
}
package com.example.serverquestion;
import android.app.Notification;
import android.app.NotificationChannel;
import android.app.NotificationManager;
import android.app.Service;
import android.content.Intent;
import android.os.Build;
import android.os.IBinder;
import androidx.core.app.NotificationCompat;
import java.io.IOException;
import java.net.ServerSocket;
import java.net.Socket;
/*
AndroidManifest.xml:
*/
public class MyForegroundService extends Service {
private static final String CHANNEL_ID = "ForegroundServiceChannel";
@Override
public void onCreate() {
super.onCreate();
createNotificationChannel();
}
@Override
public int onStartCommand(Intent intent, int flags, int startId) {
// Create a notification
Notification notification = new NotificationCompat.Builder(this, CHANNEL_ID)
.setContentTitle("Foreground Service")
.setContentText("This service is running in the foreground.")
.setSmallIcon(android.R.drawable.ic_dialog_info)
.build();
// Start the service in the foreground
startForeground(1, notification);
System.out.println("test"); //That line of code was not reached
main(null);
return START_NOT_STICKY; // Or START_STICKY based on your use case
}
@Override
public IBinder onBind(Intent intent) {
// This service is not bound, so return null
return null;
}
@Override
public void onDestroy() {
super.onDestroy();
// Cleanup resources if needed
}
private void createNotificationChannel() {
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
NotificationChannel serviceChannel = new NotificationChannel(
CHANNEL_ID,
"Foreground Service Channel",
NotificationManager.IMPORTANCE_DEFAULT
);
NotificationManager manager = getSystemService(NotificationManager.class);
if (manager != null) {
manager.createNotificationChannel(serviceChannel);
}
}
}
private static void main(String[] args){
new Thread(){
public void run() {
try {
ServerSocket server = new ServerSocket(8081);
while(true) {
new SocketInitializator(server.accept()).start();
}
} catch(IOException e){
e.printStackTrace();
}
}
}.start();
}
private static class SocketInitializator extends Thread {
private final Socket socket;
SocketInitializator(Socket socket){
this.socket = socket;
}
public void run() {
try {
byte[] request_bytes = new byte[socket.getInputStream().available()];
socket.getInputStream().read(request_bytes);
String request = new String(request_bytes);
if(request.contains("exception")){
throw new IllegalArgumentException("Server must restart automatically after exception");
}
String response = "HTTP/1.1 200 Ok\r\n\r\nHello World!";
socket.getOutputStream().write(response.getBytes("UTF-8"));
socket.close();
} catch(IOException e){
e.printStackTrace();
}
}
}
}
Подробнее здесь: https://stackoverflow.com/questions/797 ... tion-or-ot
Запуск приложения в фоновом режиме и автоматический перезапуск в случае исключения или других сбоев. ⇐ Android
Форум для тех, кто программирует под Android
1760331257
Anonymous
У меня есть приложение, которое размещает файловый сервер в функции main(), оно работает очень хорошо, когда приложение находится в основном рабочем процессе в качестве текущего действия, используемого пользователем, но мне нужно, чтобы оно работало в фоновом режиме с выключенным экраном. На самом деле в фоновом режиме он тоже работал, но только пока батарея заряжалась. Я пробовал использовать блокировку Power Manager, но это не дало эффекта, более того, автоматический перезапуск не работал в фоновом режиме.
Мне нужно, чтобы это приложение работало в фоновом режиме, в том числе с выключенным экраном, даже когда аккумулятор не находится в состоянии зарядки.
Кроме того, мне нужно, чтобы оно автоматически перезапускалось в случае исключения или других сбоев.
package com.example.serverquestion;
import android.app.Application;
import android.content.Intent;
import android.os.Bundle;
import android.os.PowerManager;
import android.view.WindowManager;
import androidx.annotation.NonNull;
import androidx.appcompat.app.AppCompatActivity;
import androidx.core.content.ContextCompat;
import com.example.serverquestion.databinding.ActivityMainBinding;
import java.io.IOException;
import java.net.ServerSocket;
import java.net.Socket;
//
public class MainActivity extends AppCompatActivity {
private ActivityMainBinding binding;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
//It didn't work while in background process:
Thread.setDefaultUncaughtExceptionHandler(new Thread.UncaughtExceptionHandler(){
@Override
public void uncaughtException(@NonNull Thread t, @NonNull Throwable e) {
final Application app = getApplication();
Intent launchIntentForPackage = app.getPackageManager().getLaunchIntentForPackage(app.getPackageName());
if (launchIntentForPackage != null) {
launchIntentForPackage.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP | Intent.FLAG_ACTIVITY_CLEAR_TASK);
ContextCompat.startActivity(app, launchIntentForPackage, null);
System.exit(2);
}
}
});
binding = ActivityMainBinding.inflate(getLayoutInflater());
setContentView(binding.getRoot());
getWindow().addFlags(WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON);
main(null);
}
private static void main(String[] args){
new Thread(){
public void run() {
try {
ServerSocket server = new ServerSocket(8081);
while(true) {
new SocketInitializator(server.accept()).start();
}
} catch(IOException e){
e.printStackTrace();
}
}
}.start();
}
private static class SocketInitializator extends Thread {
private final Socket socket;
SocketInitializator(Socket socket){
this.socket = socket;
}
public void run() {
try {
byte[] request_bytes = new byte[socket.getInputStream().available()];
socket.getInputStream().read(request_bytes);
String request = new String(request_bytes);
if(request.contains("exception")){//127.0.0.1:8081/exception to test restart in case of failure
throw new IllegalArgumentException("Server must restart automatically after exception");
}
String response = "HTTP/1.1 200 Ok\r\n\r\nHello World!";
socket.getOutputStream().write(response.getBytes("UTF-8"));
socket.close();
} catch(IOException e){
e.printStackTrace();
}
}
}
}
Это не помогло сохранить процесс, пока он не находится в состоянии зарядки аккумулятора и когда экран выключен:
//
@Override
protected void onCreate(Bundle savedInstanceState) {
...
PowerManager powerManager = (PowerManager) getSystemService(POWER_SERVICE);
PowerManager.WakeLock wakeLock = powerManager.newWakeLock(PowerManager.PARTIAL_WAKE_LOCK, "MainActivity::MyWakelockTag");
wakeLock.acquire();
...
}
Я пытался выполнить main() в службе переднего плана, но ничего не произошло
@Override
protected void onCreate(Bundle savedInstanceState) {
...
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
Intent serviceIntent = new Intent(this, MyForegroundService.class);
startForegroundService(serviceIntent); // For Android 8.0 (API 26) and above
}
...
}
package com.example.serverquestion;
import android.app.Notification;
import android.app.NotificationChannel;
import android.app.NotificationManager;
import android.app.Service;
import android.content.Intent;
import android.os.Build;
import android.os.IBinder;
import androidx.core.app.NotificationCompat;
import java.io.IOException;
import java.net.ServerSocket;
import java.net.Socket;
/*
AndroidManifest.xml:
*/
public class MyForegroundService extends Service {
private static final String CHANNEL_ID = "ForegroundServiceChannel";
@Override
public void onCreate() {
super.onCreate();
createNotificationChannel();
}
@Override
public int onStartCommand(Intent intent, int flags, int startId) {
// Create a notification
Notification notification = new NotificationCompat.Builder(this, CHANNEL_ID)
.setContentTitle("Foreground Service")
.setContentText("This service is running in the foreground.")
.setSmallIcon(android.R.drawable.ic_dialog_info)
.build();
// Start the service in the foreground
startForeground(1, notification);
System.out.println("test"); //That line of code was not reached
main(null);
return START_NOT_STICKY; // Or START_STICKY based on your use case
}
@Override
public IBinder onBind(Intent intent) {
// This service is not bound, so return null
return null;
}
@Override
public void onDestroy() {
super.onDestroy();
// Cleanup resources if needed
}
private void createNotificationChannel() {
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
NotificationChannel serviceChannel = new NotificationChannel(
CHANNEL_ID,
"Foreground Service Channel",
NotificationManager.IMPORTANCE_DEFAULT
);
NotificationManager manager = getSystemService(NotificationManager.class);
if (manager != null) {
manager.createNotificationChannel(serviceChannel);
}
}
}
private static void main(String[] args){
new Thread(){
public void run() {
try {
ServerSocket server = new ServerSocket(8081);
while(true) {
new SocketInitializator(server.accept()).start();
}
} catch(IOException e){
e.printStackTrace();
}
}
}.start();
}
private static class SocketInitializator extends Thread {
private final Socket socket;
SocketInitializator(Socket socket){
this.socket = socket;
}
public void run() {
try {
byte[] request_bytes = new byte[socket.getInputStream().available()];
socket.getInputStream().read(request_bytes);
String request = new String(request_bytes);
if(request.contains("exception")){
throw new IllegalArgumentException("Server must restart automatically after exception");
}
String response = "HTTP/1.1 200 Ok\r\n\r\nHello World!";
socket.getOutputStream().write(response.getBytes("UTF-8"));
socket.close();
} catch(IOException e){
e.printStackTrace();
}
}
}
}
Подробнее здесь: [url]https://stackoverflow.com/questions/79788787/run-applicaion-in-backgrund-and-restart-automatically-in-case-of-exception-or-ot[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия