Вземете HTML низ от уеб страница в Bukkit Plugin

Опитвам се да създам плъгин за minecraft bukkit сървъри. Целта е да се прочете низът на първия ред на html страница. Ако резултатът е True, той ще изпълни команда.

Ето кода, който имам в момента:

import java.net.URLConnection;
import java.util.Scanner;
import java.util.logging.Logger;

import org.bukkit.ChatColor;
import org.bukkit.command.Command;
import org.bukkit.command.CommandSender;
import org.bukkit.entity.Player;
import org.bukkit.plugin.java.JavaPlugin;

public class main extends JavaPlugin{
public final Logger logger = Logger.getLogger("Minecraft");

public void onEnable(){
    logger.info("[First] Has Been Enabled.");
}

public void onDisable(){
    logger.info("[First] Has Been Disabled.");
}

public boolean onCommand(CommandSender sender, Command command, String commandLabel, String[] args) {
    Player player = (Player) sender;
    if(commandLabel.equalsIgnoreCase("hello")){
        player.sendMessage(ChatColor.GOLD + "Hello");
    }
    else if(commandLabel.equalsIgnoreCase("world")){
        player.sendMessage(ChatColor.GOLD + "World");
    }
    else if(commandLabel.equalsIgnoreCase("coolman")){
        player.setPlayerListName("coolman");
    }
    else if(commandLabel.equalsIgnoreCase("vote")){
        String sourceLine = null;

        // The URL address of the page to open.
        URL address = new URL("http://www.koolflashgames.com/test.php");

        // Open the address and create a BufferedReader with the source code.
        InputStreamReader pageInput = new InputStreamReader(address.openStream());
        BufferedReader source = new BufferedReader(pageInput);

        // Append each new HTML line into one string. Add a tab character.
        try {
            sourceLine = source.readLine();
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        if(sourceLine == "False"){
            player.sendMessage("Thanks for voting!");
        }

    }
    return false;

}

}

Създава следната грешка в дневника:

2012-11-02 16:18:30 [SEVERE] null
org.bukkit.command.CommandException: Unhandled exception executing command 'vote' in        plugin first v1.0
at org.bukkit.command.PluginCommand.execute(PluginCommand.java:46)
at org.bukkit.command.SimpleCommandMap.dispatch(SimpleCommandMap.java:180)
at org.bukkit.craftbukkit.CraftServer.dispatchCommand(CraftServer.java:502)
at net.minecraft.server.NetServerHandler.handleCommand(NetServerHandler.java:915)
at net.minecraft.server.NetServerHandler.chat(NetServerHandler.java:828)
at net.minecraft.server.NetServerHandler.a(NetServerHandler.java:810)
at net.minecraft.server.Packet3Chat.handle(Packet3Chat.java:44)
at net.minecraft.server.NetworkManager.b(NetworkManager.java:282)
at net.minecraft.server.NetServerHandler.d(NetServerHandler.java:111)
at net.minecraft.server.ServerConnection.b(SourceFile:35)
at net.minecraft.server.DedicatedServerConnection.b(SourceFile:30)
at net.minecraft.server.MinecraftServer.q(MinecraftServer.java:561)
at net.minecraft.server.DedicatedServer.q(DedicatedServer.java:213)
at net.minecraft.server.MinecraftServer.p(MinecraftServer.java:474)
at net.minecraft.server.MinecraftServer.run(MinecraftServer.java:406)
at net.minecraft.server.ThreadServerApplication.run(SourceFile:539)
Caused by: java.lang.NullPointerException
at java.io.Reader.<init>(Unknown Source)
at java.io.InputStreamReader.<init>(Unknown Source)
at me.storminmormon30.first.main.onCommand(main.java:43)
at org.bukkit.command.PluginCommand.execute(PluginCommand.java:44)
... 15 more

person arennaker    schedule 02.11.2012    source източник
comment
Изглежда или сте променили кода след грешката, или не сте качили целия файл, защото ред 43 е коментар....   -  person TheJavaCoder16    schedule 01.07.2014


Отговори (2)


Изглежда, че грешката е някъде другаде: Необработено изключение изпълнява команда 'vote'
Не виждам тази команда в кодовия фрагмент, който сте дали

person BlueCacti    schedule 02.11.2012

Трябва да разделите всяка команда в неин собствен клас и да се регистрирате в plugin.yml. Това, което бих направил, е в метода onEnable(), задайте нещо подобно:

getCommand("command").setExecutor(new CommandExecutor());

Това ще раздели всички команди в техния собствен клас, което ще работи по-добре и бих го предложил.

Проблемът с вашия код изглежда като NPE във вашия клас main на ред 43 (това е във вашия onEnable() метод)

person Rmarmorstein    schedule 27.10.2013