Bonjour,
J'essaye tant bien que mal de me connecter à un site de jeu en ligne (travian) afin d'y faire de l'analyse d'informations pour faciliter le gameplay.
Pour ce faire, je dois lire puis parser les codes source html des différentes pages du jeu.
La lecture du code source n'est pas un problème, par contre il est nécessaire de s'authentifier au jeu avec un pseudo et un pass afin de pouvoir accéder aux pages qui m'intéressent.
Après quelques recherches je suis tombé sur HttpClient 4.3 pour utiliser le protocole Http
http://hc.apache.org/httpcomponents-...-ga/index.html
Mais pas moyen d'arriver à le faire fonctionner malgré les différents exemples
L'exemple utilisant httpget, j'ai testé avec httppost également sans résultats.
Alors la question : Que faut-il adapter/rajouter à cet exemple censé fonctionner pour me connecter au jeu et accéder aux pages de mon compte?
Sachant que j'appelle la fonction de lecture de code source sur la page d'accueil post-connection du jeu et ce, après l'appel de la fonction d'authentification.
Le code de la fonction d'authentification avec mes modif en commentaire :
J'ai déplacé le code dans une fonction à moi, le main appelle cette fonction, puis la fonction de lecture de code source.
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43 package org.apache.http.examples.client; import org.apache.http.auth.AuthScope; import org.apache.http.auth.UsernamePasswordCredentials; import org.apache.http.client.CredentialsProvider; import org.apache.http.client.methods.CloseableHttpResponse; import org.apache.http.client.methods.HttpGet; import org.apache.http.impl.client.BasicCredentialsProvider; import org.apache.http.impl.client.CloseableHttpClient; import org.apache.http.impl.client.HttpClients; import org.apache.http.util.EntityUtils; /** * A simple example that uses HttpClient to execute an HTTP request against * a target site that requires user authentication. */ public class ClientAuthentication { public static void main(String[] args) throws Exception { CredentialsProvider credsProvider = new BasicCredentialsProvider(); credsProvider.setCredentials( new AuthScope("localhost", 443), /* ("", AuthScope.ANY_PORT)*/ new UsernamePasswordCredentials("username", "password")); /* monPseudo, monMDP */ CloseableHttpClient httpclient = HttpClients.custom() .setDefaultCredentialsProvider(credsProvider) .build(); try { HttpGet httpget = new HttpGet("http://localhost/"); /* monURL;*/ System.out.println("Executing request " + httpget.getRequestLine()); CloseableHttpResponse response = httpclient.execute(httpget); try { System.out.println("----------------------------------------"); System.out.println(response.getStatusLine()); EntityUtils.consume(response.getEntity()); } finally { response.close(); } } finally { httpclient.close(); } } }
Le résultat du code est toujours le même, peu importe le pseudo et le pass donnés, et la lecture de la page me renvoi toujours les sources de la page de connexion.
Résultat :
Executing request POST http://ts8.travian.fr/dorf1.php HTTP/1.1
----------------------------------------
HTTP/1.1 200 OK
Si vous avez une solution d'authentification fonctionnelle, même qui n'utilise pas HttpClient, je suis preneur
Partager