HttpsURLConnection和POST

时间:2010-12-07 12:09:52

标签: java python

前段时间我在python中编写了这个程序,使用https登录了一个网站,获取了一些信息并注销了。 该计划非常简单:

class Richiesta(object):

def __init__(self,url,data):
    self.url = url
    self.data = ""
    self.content = ""
    for k, v in data.iteritems():
        self.data += str(k)+"="+str(v)+"&"
    if(self.data == ""):
        self.req = urllib2.Request(self.url)
    else:
        self.req = urllib2.Request(self.url,self.data)
    self.req.add_header('User-Agent', 'Mozilla/5.0 (Windows NT 5.1; rv:2.0b6) Gecko/20100101 Firefox/4.0b6')
    self.req.add_header('Referer', baseurl+'/www/')
    self.req.add_header('Cookie', cookie )

def leggi(self):
    while(self.content == ""):
        try:
            r = urllib2.urlopen(self.req)
        except urllib2.HTTPError, e:
            print("Errore del server, nuovo tentativo tra 15 secondi")
            time.sleep(15)                
        except urllib2.URLError, e:
            print("Problema di rete, proverò a riconnettermi tra 20 secondi")
            time.sleep(20)
        else:
                self.content = r.read().decode('utf-8')
def login(username,password):
    global cookie
    print("Inizio la procedura di login")
    url = "https://example.com/auth/Authenticate"
    data = {"login":"1","username":username,"password":password}
    f = Richiesta(url,data)
    f.leggi() 

现在,出于某种原因,我必须在java中翻译它。直到现在,这就是我写的:

import java.net.*;
import java.security.Security.*;
import java.io.*;
import javax.net.ssl.*;

public class SafeReq {
    String baseurl = "http://www.example.com";
    String useragent = "Mozilla/5.0 (Windows NT 5.1; rv:2.0b6) Gecko/20100101 Firefox/4.0b6";
    String content = "";

    public SafeReq(String s, String sid, String data) throws MalformedURLException {
        try{
            URL url = new URL(s);
            HttpsURLConnection request = ( HttpsURLConnection ) url.openConnection();

            request.setUseCaches(false);
            request.setDoOutput(true);
            request.setDoInput(true);

            request.setFollowRedirects(true);
            request.setInstanceFollowRedirects(true);

            request.setRequestProperty("User-Agent",useragent);
            request.setRequestProperty("Referer","http://www.example.com/www/");
            request.setRequestProperty("Cookie","sid="+sid);
            request.setRequestProperty("Origin","http://www.example.com");
            request.setRequestProperty("Content-Type","application/x-www-form-urlencoded");
            request.setRequestProperty("Content-length",String.valueOf(data.length()));

            request.setRequestMethod("POST");
            OutputStreamWriter post = new OutputStreamWriter(request.getOutputStream());
            post.write(data);
            post.flush();

            BufferedReader in = new BufferedReader(new InputStreamReader(request.getInputStream()));
            String inputLine;
            while ((inputLine = in.readLine()) != null) {
                content += inputLine;
            }
            post.close();
            in.close();
        } catch (IOException e){
            e.printStackTrace();
        }
    }

    public String leggi(){
        return content;
    }
}

问题是,登录不起作用,当我尝试获取需要记录的页面时,我收到“再次登录”消息。 这两个类似乎完全相同,我无法理解为什么我不能让第二个工作......任何想法?

2 个答案:

答案 0 :(得分:1)

你从哪里获得sid?根据症状,我猜想您的会话cookie未正确传递到服务器

有关可能的解决方案,请参阅此问题:Cookies turned off with Java URLConnection

一般情况下,我建议您使用HttpClient来实现Java中的HTTP会话(比简单的一次性GET或POST更复杂)。请参阅code examples(我猜“基于表单的登录”示例适用于您的情况)。

答案 1 :(得分:0)

将来有人在寻找这个,请看HtmlUnit。 这个answer有一个很好的例子。