Jump to content
  • Home
  • Files
  • Docs
Topics
  • All Content

  • This Topic
  • This Forum

  • Advanced Search
  • Existing user? Sign In  

    Sign In



    • Not recommended on shared computers


    • Forgot your password?

  • Sign Up
  • All Activity
  • Home
  • Mod Developer Central
  • Modder Support
  • ForgeGradle
  • Listening to the server console
Currently Supported: 1.16.X (Latest) and 1.15.X (LTS)
Sign in to follow this  
Followers 1
anonymusdennis

Listening to the server console

By anonymusdennis, February 15 in ForgeGradle

  • Reply to this topic
  • Start new topic

Recommended Posts

anonymusdennis    0

anonymusdennis

anonymusdennis    0

  • Tree Puncher
  • anonymusdennis
  • Members
  • 0
  • 17 posts
Posted February 15

Every time a message in the server console is displayed what i want to do is to get this message as a String... I don't want to change the message i know that wouldn't be possible but i want to get the Message and reformat it and then send it to my http server..... (my website is supposed to give me an server console and so far i got messages from users but not messages from the server or any message the players might get in chat which are not by a player)

 

If there in an better way then trying to listen to the log4j instance i would rather use that, but currently I don't even get how to listen to the log4j instance....

 

please help I have no clue of what i am doing....

  • Quote

Share this post


Link to post
Share on other sites

diesieben07    7688

diesieben07

diesieben07    7688

  • Reality Controller
  • diesieben07
  • Forum Team
  • 7688
  • 56257 posts
Posted February 15

First, please note that you really need to ask permission from your users first before you do this, especially in the EU, because of GDPR (Note: I am not a lawyer, this is not legal advise).

 

You can use System.setOut to modify where System.out goes. Here is an example that changes it to point to a file: https://www.geeksforgeeks.org/redirecting-system-out-println-output-to-a-file-in-java/.

  • Confused 1
  • Quote

Share this post


Link to post
Share on other sites

anonymusdennis    0

anonymusdennis

anonymusdennis    0

  • Tree Puncher
  • anonymusdennis
  • Members
  • 0
  • 17 posts
Posted February 15

I don't want to put it in a File I want to resend the message directly via websockets

 

  • Quote

Share this post


Link to post
Share on other sites

anonymusdennis    0

anonymusdennis

anonymusdennis    0

  • Tree Puncher
  • anonymusdennis
  • Members
  • 0
  • 17 posts
Posted February 15 (edited)

just like an external server console

I dont Really get how to use youre solution while not deleting all the output of the server console 

this method of seems to leave me two choices: either never using the server console (cmd) again because there won't be any output anymore ... did i get that right?

If i set my own conloe output, won't then the original System.out vanish?

please help i don't want to overwrite my server's root console 

thats because i don't want the user to input any commands ....

I want them to only communicate....

please help!

 

Edited February 15 by anonymusdennis
  • Quote

Share this post


Link to post
Share on other sites

anonymusdennis    0

anonymusdennis

anonymusdennis    0

  • Tree Puncher
  • anonymusdennis
  • Members
  • 0
  • 17 posts
Posted February 15

Am i doing this right?

 

//in server Start event:
System.setOut(new PrintStream(new consolesub(System.out)));
//-------
private static class consolesub extends OutputStream {
            PrintStream original;
            public consolesub(PrintStream out) {
                original = out;
            }

            public consolesub() {
                super();
            }

            @Override
            public void write(byte[] b) throws IOException {
                original.write(b);
                super.write(b);
            }

            @Override
            public void write(byte[] b, int off, int len) throws IOException {
                original.write(b,off,len);
                super.write(b, off, len);
            }

            @Override
            public void flush() throws IOException {
                original.flush();
                super.flush();
            }

            @Override
            public void close() throws IOException {
                original.close();
                super.close();
            }

            @Override
            public void write(int b) throws IOException {
                original.write(b);
            }
        }

 

  • Quote

Share this post


Link to post
Share on other sites

diesieben07    7688

diesieben07

diesieben07    7688

  • Reality Controller
  • diesieben07
  • Forum Team
  • 7688
  • 56257 posts
Posted February 15
29 minutes ago, anonymusdennis said:

I don't want to put it in a File I want to resend the message directly via websockets

 

Of course... you need to put in some effort of your own... I just showed you what you needed to change where System.out goes. Now it is your job to do what schools call transfer of knowledge and combine this newly learned thing ("how to change where System.out goes") with what you already know ("how to send stuff to my server).

 

30 minutes ago, anonymusdennis said:

I dont Really get how to use youre solution while not deleting all the output of the server console

You first need to capture the current System.out value and your replacement need to not only write to your server but also to the previous System.out value.

  • Like 1
  • Quote

Share this post


Link to post
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

    • Insert image from URL
×
  • Desktop
  • Tablet
  • Phone
Sign in to follow this  
Followers 1
Go To Topic Listing



  • Recently Browsing

    No registered users viewing this page.

  • Posts

    • Centmap
      Forge Mods Folder

      By Centmap · Posted 21 minutes ago

      so i created a "1.16.5" folder in the folder "mod" as usual but it doesn't use the mods. Can anyone help me ?
    • Skyriis
      [SOLVED][1.16.5] Adding a Button to KeyBindings

      By Skyriis · Posted 1 hour ago

      That worked.   Here is my solution @SubscribeEvent public static void onOpenGui(final GuiScreenEvent.InitGuiEvent.Post event) { if (!(event.getGui() instanceof ControlsScreen)) return; final ControlsScreen controlsScreen = (ControlsScreen) event.getGui(); final KeyBindingList replacement = new KeyBindingListReplacement(controlsScreen, event.getGui().getMinecraft()); final KeyBindingList old = ObfuscationReflectionHelper.getPrivateValue(ControlsScreen.class, controlsScreen, "field_146494_r"); controlsScreen.getEventListeners().remove(old); ObfuscationReflectionHelper.setPrivateValue(ControlsScreen.class, controlsScreen, replacement, "field_146494_r"); try { Method addChildMethod = ObfuscationReflectionHelper.findMethod(Screen.class, "func_230481_d_", IGuiEventListener.class); addChildMethod.setAccessible(true); addChildMethod.invoke(controlsScreen, replacement); addChildMethod.setAccessible(false); } catch (IllegalAccessException | InvocationTargetException e) { e.printStackTrace(); } }  
    • DrCowiber
      Failed To Start Minecraft Server

      By DrCowiber · Posted 1 hour ago

      im using this run.sh file, which contains: java -Xmx6G -Xms6G -jar minecraft_server.1.16.5.jar --nogui Edit: When I first posted about this I was using the serverRun.jar, which the first log file I posted is what the output was
    • Tez
      [1.15.2] Couln't not resolve dependency: net.minecraftforge:forge:1.15.2-31.2.0:userdev

      By Tez · Posted 1 hour ago

      I'm new to mod coding so i've watch tutorial in youtube in setup workspace step i got this error , i've try many solutions to fix but it still not working try update gradle to 6.8.3 but still not working try update java and still not working too here's my stacktrace: Stacktrace
    • diesieben07
      Failed To Start Minecraft Server

      By diesieben07 · Posted 1 hour ago

      Please show how exactly you are starting the server.
  • Topics

    • Centmap
      0
      Forge Mods Folder

      By Centmap
      Started 21 minutes ago

    • Skyriis
      8
      [SOLVED][1.16.5] Adding a Button to KeyBindings

      By Skyriis
      Started 23 hours ago

    • DrCowiber
      8
      Failed To Start Minecraft Server

      By DrCowiber
      Started 20 hours ago

    • Tez
      0
      [1.15.2] Couln't not resolve dependency: net.minecraftforge:forge:1.15.2-31.2.0:userdev

      By Tez
      Started 1 hour ago

    • Mysterious minecrafter
      1
      game keeps crashing while initializings

      By Mysterious minecrafter
      Started 3 hours ago

  • Who's Online (See full list)

    • GermanBucket
    • sleepier
    • Zeher_Monkey
    • Skyriis
    • Uncreative
    • NullDev
    • Centmap
    • smitokyo
    • xBenjihdx
  • All Activity
  • Home
  • Mod Developer Central
  • Modder Support
  • ForgeGradle
  • Listening to the server console
  • Theme

Copyright © 2019 ForgeDevelopment LLC · Ads by Longitude Ads LLC Powered by Invision Community