Compiler-Fehler Ein weiteres Java Problem

Olli447

Mitglied
Hallo Community,

ich versuche gerade mit Java ein Programm zu erstellen, welches bei Ausführung eine Textdatei ausließt und den Inhalt in gewissen Unterteilungen als einzelne Themen eines bestimmten Forums (phpbb3.1.X) veröffentlicht. Schnell bin ich auf dieses Thema gestoßen. Ich versuche nun das Programm aus diesem Post zu reproduzieren.
Dazu verwende ich folgenden Quelltext:

Java:
package ---.poster.org;

import java.util.ArrayList;
import java.util.List;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

import org.apache.commons.lang.StringEscapeUtils;
import org.apache.http.HttpResponse;
import org.apache.http.HttpStatus;
import org.apache.http.NameValuePair;
import org.apache.http.client.entity.UrlEncodedFormEntity;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.client.params.ClientPNames;
import org.apache.http.client.params.CookiePolicy;
import org.apache.http.entity.mime.HttpMultipartMode;
import org.apache.http.entity.mime.MultipartEntity;
import org.apache.http.entity.mime.content.StringBody;
import org.apache.http.impl.client.BasicCookieStore;
import org.apache.http.impl.client.DefaultHttpClient;
import org.apache.http.message.BasicNameValuePair;
import org.apache.http.params.CoreProtocolPNames;
import org.apache.http.util.EntityUtils;

public class PhpBB3Client {

	private final String url;

	private final DefaultHttpClient httpClient;

	private final BasicCookieStore cookieStore = new BasicCookieStore();

	private static final Pattern pSID = Pattern.compile("<input\\s+type=\"hidden\"\\s+name=\"sid\"\\s+value=\"([a-zA-Z0-9]+)\"\\s+/>",
			Pattern.CASE_INSENSITIVE | Pattern.MULTILINE);

	private static final Pattern pREDIRECT = Pattern.compile("<input\\s+type=\"hidden\"\\s+name=\"redirect\"\\s+value=\"(\\S+)\"\\s+/>",
			Pattern.CASE_INSENSITIVE | Pattern.MULTILINE);

	private static final Pattern pCREATION_TIME = Pattern.compile("<input\\s+type=\"hidden\"\\s+name=\"creation_time\"\\s+value=\"(\\d+)\"\\s+/>",
			Pattern.CASE_INSENSITIVE | Pattern.MULTILINE);

	private static final Pattern pFORM_TOKEN = Pattern.compile("<input\\s+type=\"hidden\"\\s+name=\"form_token\"\\s+value=\"([a-zA-Z0-9]+)\"\\s+/>",
			Pattern.CASE_INSENSITIVE | Pattern.MULTILINE);

	private static final Pattern pPOST_ACTION=Pattern.compile("<form\\s+id=\"postform\"\\s+method=\"post\"\\s+action=\"(.+)\"\\s+enctype=\"multipart/form-data\"\\s*>",
			Pattern.CASE_INSENSITIVE | Pattern.MULTILINE);

	private static final Pattern pLAST_CLICK = Pattern.compile("<input\\s+type=\"hidden\"\\s+name=\"lastclick\"\\s+value=\"(\\d+)\"\\s+/>",
			Pattern.CASE_INSENSITIVE | Pattern.MULTILINE);

	public PhpBB3Client (final String url) {
		this.url = url+(url.endsWith("/") ? "" : "/");

		httpClient = new DefaultHttpClient();
		httpClient.setCookieStore(cookieStore);
		httpClient.getParams().setBooleanParameter(CoreProtocolPNames.USE_EXPECT_CONTINUE, false);
		httpClient.getParams().setParameter(ClientPNames.COOKIE_POLICY, CookiePolicy.BROWSER_COMPATIBILITY);
	}

	public void login(final String username, final String password) {

		try {
			final String postURL=url + "ucp.php?mode=login";
			final HttpGet get = new HttpGet(postURL);

			HttpResponse response = httpClient.execute(get);
			if (response.getStatusLine().getStatusCode() != HttpStatus.SC_OK) {
				throw new IllegalStateException("Expected 200, got: " + response.getStatusLine().getStatusCode());
			}

			String content = EntityUtils.toString(response.getEntity());

			Matcher m = pSID.matcher(content);
			if(!m.find()) {
				throw new IllegalStateException("Could not parse SID.");
			}
			final String sid = m.group(1);

			m = pREDIRECT.matcher(content);
			if(!m.find()) {
				throw new IllegalStateException("Could not parse \"redirect\".");
			}
			final String redirect=m.group(1);

			final List<NameValuePair> formparams = new ArrayList<NameValuePair>();
			formparams.add(new BasicNameValuePair("username", username));
			formparams.add(new BasicNameValuePair("password", password));
			formparams.add(new BasicNameValuePair("autologin", "on"));
			formparams.add(new BasicNameValuePair("viewonline", "on"));
			formparams.add(new BasicNameValuePair("viewonline", "on"));
			formparams.add(new BasicNameValuePair("sid", sid));
			formparams.add(new BasicNameValuePair("login", "Login"));
			formparams.add(new BasicNameValuePair("redirect", redirect));	

			final UrlEncodedFormEntity loginPost = new UrlEncodedFormEntity(formparams, "UTF-8");
			HttpPost httpPost = new HttpPost(postURL);
			httpPost.setEntity(loginPost);

			response = httpClient.execute(httpPost);
			if (response.getStatusLine().getStatusCode() != HttpStatus.SC_OK) {
				throw new IllegalStateException("Expected 200, got: " + response.getStatusLine().getStatusCode());
			}

			response.getEntity().consumeContent();	

		} catch (final Throwable t) {
			throw new RuntimeException("Could not login! ", t);
		}
	}

	public void newTopic(final long forumId, final String subject, final String message ) {
		try {

			final String postURL = url + "posting.php?mode=post&f=" + forumId;
			final HttpGet get = new HttpGet(postURL);

			HttpResponse response = httpClient.execute(get);
			if (response.getStatusLine().getStatusCode() != HttpStatus.SC_OK) {
				throw new IllegalStateException("Expected 200, got: " + response.getStatusLine().getStatusCode());
			}

			String content = EntityUtils.toString(response.getEntity());

			Matcher m = pCREATION_TIME.matcher(content);
			if(!m.find()) {
				throw new IllegalStateException("Could not parse creation_time."+content);
			}
			final String creationTime = m.group(1);

			m = pFORM_TOKEN.matcher(content);
			if(!m.find()) {
				throw new IllegalStateException("Could not parse form_token.");
			}
			final String formToken=m.group(1);

			m = pLAST_CLICK.matcher(content);
			if(!m.find()) {
				throw new IllegalStateException("Could not parse last_click.");
			}
			final String lastClick=m.group(1);

			m = pPOST_ACTION.matcher(content);
			if(!m.find()) {
				throw new IllegalStateException("Could not parse post_action.");
			}
			String postAction=m.group(1);
			if(postAction.startsWith("./")) {
				postAction=postAction.substring(2, postAction.length());
			}
			postAction=StringEscapeUtils.unescapeHtml(postAction);

			final MultipartEntity mpe = new MultipartEntity(HttpMultipartMode.BROWSER_COMPATIBLE);
			mpe.addPart("icon", new StringBody("0"));
			mpe.addPart("subject", new StringBody(subject));
			mpe.addPart("addbbcode20", new StringBody("100"));
			mpe.addPart("message", new StringBody(message));
			mpe.addPart("lastclick", new StringBody(""+(Integer.valueOf(lastClick)-3000)));
			mpe.addPart("post", new StringBody("Submit"));
			mpe.addPart("attach_sig", new StringBody("on"));
			mpe.addPart("topic_type", new StringBody("0"));
			mpe.addPart("topic_time_limit", new StringBody("0"));
			mpe.addPart("creation_time", new StringBody(creationTime));
			mpe.addPart("form_token", new StringBody(formToken));

			final HttpPost httpPost = new HttpPost(url+postAction);
			httpPost.setHeader("Referer", postURL);
			httpPost.setEntity(mpe);

			response = httpClient.execute(httpPost);
			response.getEntity().consumeContent();

		} catch (final Throwable t) {
			throw new RuntimeException("Could not post new Thread to forum "+forumId, t);
		}
	}

	public static void main(String[] args) {
		final PhpBB3Client client = new PhpBB3Client("XXX.de");
		client.login("XXX", "XXXX");
		client.newTopic(12, "Test", "Hello world! blablablablaba"+System.currentTimeMillis());
	}
}

die entsprechenden JAR Verzeichnisse mit den Apache Bibliotekten liegen in dem Projektordner, allerdings nicht im src Ordner, sondern eine Ebene davor.
Wenn ich das Programm nun starte schmeißt mir Java diese Fehlermeldung entgegen:

Java:
Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/commons/logging/LogFactory
	at org.apache.http.impl.client.AbstractHttpClient.<init>(AbstractHttpClient.java:182)
	at org.apache.http.impl.client.DefaultHttpClient.<init>(DefaultHttpClient.java:150)
	at ---.poster.org.PhpBB3Client.<init>(PhpBB3Client.java:55)
	at ---.poster.org.PhpBB3Client.main(PhpBB3Client.java:179)
Caused by: java.lang.ClassNotFoundException: org.apache.commons.logging.LogFactory
	at java.net.URLClassLoader$1.run(Unknown Source)
	at java.net.URLClassLoader$1.run(Unknown Source)
	at java.security.AccessController.doPrivileged(Native Method)
	at java.net.URLClassLoader.findClass(Unknown Source)
	at java.lang.ClassLoader.loadClass(Unknown Source)
	at sun.misc.Launcher$AppClassLoader.loadClass(Unknown Source)
	at java.lang.ClassLoader.loadClass(Unknown Source)
	... 4 more

Könnt ihr mir helfen? Eventuell hab ihr ja auch Anregungen wie ihr so etwas umsetzen würdet ;-)

LG

Oliver
 
Zuletzt bearbeitet:

Olli447

Mitglied
Ja dem Fehler habe ich bereits "hinterher" gegoogelt, nur macht das für mich keinen Sinn :bahnhof: . Das würde dann doch bedeuten, dass die offizelle "Quell-jar" fehlerhaft ist ???:L . Ich kann doch schlecht die benötigte Klasse selber schreiben, oder?
Auch verstehe ich nicht so ganz warum der Compiler versucht diese Klasse zu laden. Ich kann nichts entdecken, was das logging auslösen würde, oder habe ich eine Befehlzeile übersehen (sprich bin zu blind)?

Warscheinlich sehe ich mal wieder den Wald vor lauter Bäumen nicht :)

Grüße
Oliver
 

Joose

Top Contributor
Ja dem Fehler habe ich bereits "hinterher" gegoogelt, nur macht das für mich keinen Sinn :bahnhof: . Das würde dann doch bedeuten, dass die offizelle "Quell-jar" fehlerhaft ist ???:L . Ich kann doch schlecht die benötigte Klasse selber schreiben, oder?

Nein, aber diese "Quell-Jar" kann weiterer JARs benötigen, welche dir vielleicht fehlen :)
Sprich du solltest kontrollieren welche Abhängigkeiten dieses JAR hat, welche dir fehlen.

Auch verstehe ich nicht so ganz warum der Compiler versucht diese Klasse zu laden. Ich kann nichts entdecken, was das logging auslösen würde, oder habe ich eine Befehlzeile übersehen (sprich bin zu blind)?

Code:
Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/commons/logging/LogFactory
at org.apache.http.impl.client.AbstractHttpClient.<init>(AbstractHttpClient.java:182)
at org.apache.http.impl.client.DefaultHttpClient.<init>(DefaultHttpClient.java:150)
at ---.poster.org.PhpBB3Client.<init>(PhpBB3Client.java:55)
at ---.poster.org.PhpBB3Client.main(PhpBB3Client.java:179)

Da steht doch ein StackTrace der sagt dir wo der Fehler passiert.
Du selbst rufst in deinem Code das Logging vielleicht nicht auf, aber die Klasse "PhpBB3Client" macht dies, bzw. basiert auf Code der dieses Logging aufruft!
 
Zuletzt bearbeitet:


Schreibe deine Antwort... und nutze den </> Button, wenn du Code posten möchtest...
Ähnliche Java Themen
  Titel Forum Antworten Datum
G Mit einen Java Porgramm ein weiteres Programm öffnen Java Basics - Anfänger-Themen 6
B Programm beendet sich nicht und weiteres seltsames Verhalten Java Basics - Anfänger-Themen 9
E weiteres Routenproblem Java Basics - Anfänger-Themen 4
1 Ein weiteres Lotto programm Java Basics - Anfänger-Themen 6
E Fragen zu Klassenhierarchien und Weiteres Java Basics - Anfänger-Themen 17
E Weiteres Vier Gewinnt-Spiel Java Basics - Anfänger-Themen 2
B Variable auf Typ prüfen (weiteres Problem) Java Basics - Anfänger-Themen 16
J Probleme mit drucken aus Java Java Basics - Anfänger-Themen 3
Gokul Java chart library suggestion for web application? Java Basics - Anfänger-Themen 2
D wie kann ich gcc aus einer .java datei heraus aufrufen? Java Basics - Anfänger-Themen 2
S Text Formatierung in Java Java Basics - Anfänger-Themen 2
B Erste Schritte yaml parsen in Java Java Basics - Anfänger-Themen 19
C Methoden Umlaute in Java Java Basics - Anfänger-Themen 18
W Java-PRogramm liest als EXE-File Nicht USB, jedoch aus NetBeans Java Basics - Anfänger-Themen 45
W Methoden java map ersatz für c++map Java Basics - Anfänger-Themen 3
M Erste Schritte Java Primzahltester Java Basics - Anfänger-Themen 4
A csv Reader für Java? Java Basics - Anfänger-Themen 27
K Java - Enums Java Basics - Anfänger-Themen 30
tomzen Java Unterstützung für exel dateien installieren. Java Basics - Anfänger-Themen 2
Rookar java.lang.NoClassDefFoundError: org/json/JSONException Java Basics - Anfänger-Themen 2
Rookar Mit Button andere java öffnen Java Basics - Anfänger-Themen 4
F Java Object to Hashmap ? Java Basics - Anfänger-Themen 6
I Backend in Java und Ansicht von Dateien in statische HTML Seiten? Java Basics - Anfänger-Themen 15
R Input/Output Verwendung des Euro-Zeichens in Java Java Basics - Anfänger-Themen 7
I Push Nachrichten von JAVA EE App an Mobile App Java Basics - Anfänger-Themen 3
H .java Dateien in Eclipse einbinden und ausführen Java Basics - Anfänger-Themen 1
onlyxlia Schlüsselworte Was meint man mit "einen Typ" in Java erstellen? Java Basics - Anfänger-Themen 2
O Java Kara geschweifte Klammern Java Basics - Anfänger-Themen 2
G Mausrad logitech kann links und rechts klick wie in java abragen. Java Basics - Anfänger-Themen 15
XWing Java Klssenproblem Java Basics - Anfänger-Themen 4
R Umgebungsvariable java -cp gibt immer Java-Hilfe... Java Basics - Anfänger-Themen 3
farbenlos Csv Datei in Java einlesen Java Basics - Anfänger-Themen 18
F TableModelListener: java.lang.ArrayIndexOutOfBoundsException: 132 Java Basics - Anfänger-Themen 3
G Java 8 - Support-Ende Java Basics - Anfänger-Themen 7
T Java Weihnachtsbaum + Rahmen Java Basics - Anfänger-Themen 1
N Will mit Java anfangen Java Basics - Anfänger-Themen 13
Ü Java Array - Buchstaben als Zahlen ausgeben Java Basics - Anfänger-Themen 22
M Java Iterator Verständnisfrage Java Basics - Anfänger-Themen 6
M Java Mail Programm Java Basics - Anfänger-Themen 4
Sniper1000 Java 391 für Windows Java Basics - Anfänger-Themen 37
G Java long- in int-Variable umwandeln Java Basics - Anfänger-Themen 6
JaZuDemNo Java im Studium Java Basics - Anfänger-Themen 7
E Java Programm zur anzeige, ob Winter- oder Sommerzeit herrscht Java Basics - Anfänger-Themen 62
I QR code in Java selber generieren Java Basics - Anfänger-Themen 5
V Java-Ausnahmebehandlung: Behandlung geprüfter Ausnahmen Java Basics - Anfänger-Themen 1
krgewb Java Streams Java Basics - Anfänger-Themen 10
A Überwältigt von der komplexen Java Welt Java Basics - Anfänger-Themen 29
O Mehrfachvererbung auf Spezifikations- und Implementierungsebene in Java. Interfaces Java Basics - Anfänger-Themen 19
John_Sace Homogene Realisierung von Generics in Java ? Java Basics - Anfänger-Themen 19
P Meldung aus Java-Klasse in Thread an aufrufende Klasse Java Basics - Anfänger-Themen 1
R mit Java API arbeiten Java Basics - Anfänger-Themen 9
P JDK installieren Probleme bei der Java-Installation Java Basics - Anfänger-Themen 8
S Java: Wie sortiere ich eine ArrayList benutzerdefinierter Objekte nach einem bestimmten Attribut? Java Basics - Anfänger-Themen 2
Timo12345 JNLP File mit Java öffnen Java Basics - Anfänger-Themen 2
S Video Editierung mit Java.._ Java Basics - Anfänger-Themen 2
F Einstelungen in Java - CursorBlinkRate Java Basics - Anfänger-Themen 10
A PHP $_POST["name"] in Java Java Basics - Anfänger-Themen 3
vivansai21 Is there a oneliner to create a SortedSet filled with one or multiple elements in Java? Java Basics - Anfänger-Themen 9
Athro-Hiro Weißes Bild in Java erstellen Java Basics - Anfänger-Themen 3
Arjunreddy Can someone please tell me how to use a debugger in BlueJ(a Java environment) Java Basics - Anfänger-Themen 1
M Java assoziationen (UML) Java Basics - Anfänger-Themen 8
H Excel-Tabellen mit Java erstellen Java Basics - Anfänger-Themen 4
Simon16 Java ArrayListe von einer Klasse sortieren Java Basics - Anfänger-Themen 2
P Wie kann ich in meinem Java Programm etwas dauerhaft speichern? Java Basics - Anfänger-Themen 5
H Nutzt Eclipse alle CPU-Threads beim Ausführen von Java-Programmen? Java Basics - Anfänger-Themen 4
xXGrowGuruXx Java einstieg, leichte sache 0 verstanden Java Basics - Anfänger-Themen 7
A java.sql.SQLException: Data type mismatch. Java Basics - Anfänger-Themen 1
H Java-Programm zur Ausgabe von Zuständen Java Basics - Anfänger-Themen 80
N Java Spiel Figur auf dem Hintergrundbild bewegen. Java Basics - Anfänger-Themen 11
G Kann Java-Programm nicht als jar aufrufen, auch als EXE nicht Java Basics - Anfänger-Themen 19
N Java Taschenrechner hat Jemand vlt einen Tipp dafür wie ich jetzt die buttons verbinden kann und das Ergebnis auf dem textfield anzeigen lassen kann Java Basics - Anfänger-Themen 13
A Lerngruppe Java Java Basics - Anfänger-Themen 2
G Help me in the Java Program Java Basics - Anfänger-Themen 2
L Java- Vererbung Java Basics - Anfänger-Themen 4
LimDul Suche Java Stream Tutorial Java Basics - Anfänger-Themen 2
_so_far_away_ Ich möchte Java lernen Java Basics - Anfänger-Themen 11
benny1993 Java Programm erstellen für ein Fußball-Turnier Java Basics - Anfänger-Themen 3
M Datentypen While-Schleife eine Java Methode erstellen Java Basics - Anfänger-Themen 3
V Bild per Java Script austauschen Java Basics - Anfänger-Themen 7
MoxMorris this Keyword in Java Java Basics - Anfänger-Themen 14
D Wie kann man in Java nach Arrays auf Duplikate prüfen Java Basics - Anfänger-Themen 12
wolei JAVA Zeitdifferenz feststellen. Java Basics - Anfänger-Themen 4
DiyarcanZeren Rekursion in Java Java Basics - Anfänger-Themen 5
wolei Java generic interface in a generic class Java Basics - Anfänger-Themen 6
monsterherz Ablauf der Erstellung eines Java Programmes Java Basics - Anfänger-Themen 17
monsterherz Circle.java:5: error: <identifier> expected Java Basics - Anfänger-Themen 2
julian-fr Wie kann ich am besten Java lernen? Java Basics - Anfänger-Themen 17
A Java-Properties und -RessourceBundles Java Basics - Anfänger-Themen 5
lrnz22 Java-Basics-Aufgabe Java Basics - Anfänger-Themen 8
R Java kann nicht installiert werden Java Basics - Anfänger-Themen 8
marcelnedza Finde meinen Fehler in einer Methode nicht, Java Karol Java Basics - Anfänger-Themen 15
G In ein java Dokument Ton einbinden Java Basics - Anfänger-Themen 1
C was heisst es wenn java ']' erwartet ? Java Basics - Anfänger-Themen 2
KeinJavaFreak Erste Schritte Programm "Java(TM) Platform SE binary " nicht vorhanden Java Basics - Anfänger-Themen 1
KeinJavaFreak Erste Schritte Java "Executable Jar File" nicht vorhanden Java Basics - Anfänger-Themen 1
melisax Java 2D-Array Tabelle Java Basics - Anfänger-Themen 4
melisax Java Array Wert an bestimmtem Index angeben Java Basics - Anfänger-Themen 14
J Java Testklasse Java Basics - Anfänger-Themen 5
P Java Selenium . Parameterized.Parameters erzeugt eine Fehlermeldung Java Basics - Anfänger-Themen 14
W Java-Code mit Array Java Basics - Anfänger-Themen 14

Ähnliche Java Themen

Neue Themen


Oben