2011-07-05 2 views
1

서버에서 응답을 다시 보내려고합니다. 그래서 내가 한 일은 서버가 인증을 필요로하고 서버에서 응답을 얻었 기 때문에 인증을 위해 코드에서 사용자 이름과 암호를 전달했습니다. 그래서 SMSESSION 쿠키를 설정할 수있는 방법이 있습니다. 그 사용자가 코드에서 사용자 이름과 암호를 전달하는 대신에 .. 사용자가 이미 자신의 사용자 이름과 암호로 브라우저에 로그인했다고 가정하십시오. 이건 내 아래 코드입니다 .. 내가 그 부분을 주석으로 사용자 이름과 비밀 번호 .. 그리고 그 중 하나는 잘 작동 ..하지만 대신 사용자 이름과 비밀 번호를 통과, 나는 그 사용자의 SMSESSION 쿠키를 설정하려면 이미 로그인 해당 브라우저에 .. 그래서 쿠키를 설정하는 코드를 추가하지만 내가 응답을 다시 얻으려면 SMSESSION 쿠키를 설정하십시오.

Access Denied Error 




<%@ page language="java" import=" 
org.apache.http.HttpEntity, 
org.apache.http.HttpResponse, 
org.apache.http.auth.AuthScope, 
org.apache.http.auth.UsernamePasswordCredentials, 
org.apache.http.client.methods.HttpPost, 
org.apache.http.client.methods.HttpGet, 
org.apache.http.impl.client.DefaultHttpClient, 
org.apache.http.util.EntityUtils, 
java.io.InputStream, 
java.io.InputStreamReader, 
java.io.BufferedReader, 
java.security.KeyStore, 
java.io.FileInputStream, 
java.io.File, 
org.apache.http.conn.ssl.SSLSocketFactory, 
org.apache.http.conn.scheme.Scheme, 
javax.net.ssl.HostnameVerifier, 
org.apache.http.impl.conn.SingleClientConnManager, 
javax.net.ssl.HttpsURLConnection, 
org.apache.http.conn.scheme.SchemeRegistry, 
javax.net.ssl.SSLContext, 
java.security.cert.X509Certificate, 
javax.net.ssl.X509TrustManager, 
javax.net.ssl.TrustManager, 
org.apache.http.conn.ClientConnectionManager, 
java.security.cert.CertificateException, 
org.apache.http.conn.scheme.Scheme" 
contentType="text/html; charset=ISO-8859-1" 
pageEncoding="ISO-8859-1"%> 

<% 
String a_Url = request.getParameter("url") ; 

DefaultHttpClient httpclient = new DefaultHttpClient(); 


/* 
    httpclient.getCredentialsProvider().setCredentials(
      new AuthScope(AuthScope.ANY_HOST, AuthScope.ANY_PORT, null), 
      new UsernamePasswordCredentials("test", "pass")); 
*/ 



    Cookie[] cookies = request.getCookies(); 
    boolean foundCookie = false; 
    // System.out.println(" hello " +cookies); 
    for(int i = 0; i < cookies.length; i++) { 
     Cookie c = cookies[i]; 
     //System.out.println(" " +c); 
     if (c.getName().equals("SMSESSION")) { 
      System.out.println("sm = " + c.getValue()); 
      foundCookie = true; 
     } 
    } 

    if (foundCookie) { 
     //System.out.println(foundCookie); 
     Cookie c = new Cookie("SMSESSION", "3jHUz3BcnWfVfgWH806Sro9Qs9obgTS6gp+b71d86HcPpupyZ8kcSI48KBpxcLT0DlTxnaKjP4Mgdn8iQFRkyJ1Uyji83qupvMy8zaD0b83h+5edOqF4GrDiXUDqzRBhwJ9wHMmswbf4As6gcu6aJDOoppI1pCoeA+yoLHpxMYi+B3VM1IZhOKiVkKb2+IrQwhvLCxMKy3oF/ew2gctmJ6AVfe/cA053niXPERjWW111cJhJMViFd/fP7YuxLuLZNzqBEBAdSBoK8YorzGwUTX0DDUTI7QJF9OGdeGETpmddHzE4u3hdqMZxrIdAYQc6zDLOf5I5MoMie7WnQVIu5gH8xa3b37BDk3rVuf4orOcaahv/UlrHPRRjIUtaWal1sAZXBHpYgQKH4wd3nNtPthW0hBAlxXQnGgHqZvJvQH4jLWlTV9uwC2q1hbMHrmo9zXCNO7uIxK6o0PyTYW6UhdVmcYtoHn/+mAX3dW3PRYAUM7ItAdIfsPV6LAs+bLiVexDf2P9E2ub4zF+ZSN+3AUSssMLiGKCOnWQ/IQyB8WOngkMa9Qc58pZv8g8E5Lxm5g/udiGbhqK24kYauJ8cUI4JtTW+JJKqwoqTbnwwdbTqdSenyNnrEnbH13CDowNxbSgJZeSUw2Z51ELARrXp+N5kGokLr+YXxwsgmvoXQxxo/5y9Lgn1RKtc4QAJiWjQNzDOFX2HoiFw+oWUXgrET8qTHHVOj+v9auqyxS0cPgcXj8wQmjJrUH+tYGlQmCdF2CCt5Ywf12Jaev+wfNcVb447fAmTR7LJTgtb/D5U15YqAMYZg36tVrPkx1MhP37XbEYLsCcpfdDO4FUVKb5t7zl0rTAhUvbCF3/Wn6V/0LjJ58UGl4GEhIF2y4K+vFJSkL7qJ+2ufVi9hfXu5362QKCtqqXt0LihgjmH9z0Mgg1Brfgl0jVPuO44os0KBKzfCuhFMzEK9oorNVpgWrVWED+yiBNO0B2JA4lurdsFFAwOcx3ZFyhJ1TC2jUYJpIBW "); 
     c.setMaxAge(24*60*60); 
     response.addCookie(c); 
    }  


    HttpGet httpget = new HttpGet(a_Url); 



    System.out.println("executing request" + httpget.getRequestLine()); 
    HttpResponse res = httpclient.execute(httpget); 

    HttpEntity entity = res.getEntity(); 

    System.out.println("----------------------------------------"); 
    System.out.println(res.getStatusLine()); 
    if (entity != null) { 

     System.out.println("Response content length: " + entity.getContentLength()); 
     InputStream input = entity.getContent(); 
     BufferedReader reader = new BufferedReader(new InputStreamReader(input)); 
     String ln = ""; 
     while((ln = reader.readLine()) != null) { 
      out.println("" + ln); 
     } 
     entity.consumeContent(); 
    } 
    EntityUtils.consume(entity); 

%> 

을 얻고있다 그리고 응답 헤더에 나는이 무엇입니까, 작동하지 않습니다 : -

Response Headers 
Content-Type text/html; charset=iso-8859-1 
Expires Thu, 01 Jan 1970 00:00:00 GMT 
Set-Cookie SMSESSION="3jHUz3BcnWfVfgWH806Sro9Qs9obgTS6gp+b71d86HcPpupyZ8kcSI48KBpxcLT0DlTxnaKjP4Mgdn8iQFRkyJ1Uyji83qupvMy8zaD0b83h+5edOqF4GrDiXUDqzRBhwJ9wHMmswbf4As6gcu6aJDOoppI1pCoeA+yoLHpxMYi+B3VM1IZhOKiVkKb2+IrQwhvLCxMKy3oF/ew2gctmJ6AVfe/cA053niXPERjWW111cJhJMViFd/fP7YuxLuLZNzqBEBAdSBoK8YorzGwUTX0DDUTI7QJF9OGdeGETpmddHzE4u3hdqMZxrIdAYQc6zDLOf5I5MoMie7WnQVIu5gH8xa3b37BDk3rVuf4orOcaahv/UlrHPRRjIUtaWal1sAZXBHpYgQKH4wd3nNtPthW0hBAlxXQnGgHqZvJvQH4jLWlTV9uwC2q1hbMHrmo9zXCNO7uIxK6o0PyTYW6UhdVmcYtoHn/+mAX3dW3PRYAUM7ItAdIfsPV6LAs+bLiVexDf2P9E2ub4zF+ZSN+3AUSssMLiGKCOnWQ/IQyB8WOngkMa9Qc58pZv8g8E5Lxm5g/udiGbhqK24kYauJ8cUI4JtTW+JJKqwoqTbnwwdbTqdSenyNnrEnbH13CDowNxbSgJZeSUw2Z51ELARrXp+N5kGokLr+YXxwsgmvoXQxxo/5y9Lgn1RKtc4QAJiWjQNzDOFX2HoiFw+oWUXgrET8qTHHVOj+v9auqyxS0cPgcXj8wQmjJrUH+tYGlQmCdF2CCt5Ywf12Jaev+wfNcVb447fAmTR7LJTgtb/D5U15YqAMYZg36tVrPkx1MhP37XbEYLsCcpfdDO4FUVKb5t7zl0rTAhUvbCF3/Wn6V/0LjJ58UGl4GEhIF2y4K+vFJSkL7qJ+2ufVi9hfXu5362QKCtqqXt0LihgjmH9z0Mgg1Brfgl0jVPuO44os0KBKzfCuhFMzEK9oorNVpgWrVWED+yiBNO0B2JA4lurdsFFAwOcx3ZFyhJ1TC2jUYJpIBW";Expires=Wed, 06-Jul-11 16:57:11 GMT 
Content-Length 2786 
Server Jetty(6.1.21) 

어떤 제안 것이다 감사합니다 ...

답변

1

SMSESSION은 사용되는 시스템 쿠키입니다 Siteminder. 너는 그걸로 어지럽히거나해서는 안된다.

Siteminder를 사용하는 응용 프로그램 인 경우 Siteminder는 사용자의 인증 프로세스를 처리합니다.
사용자가 Siteminder에 의해 인증되면 애플리케이션의 Siteminder 에이전트는 사용자에 대한 정보가 포함될 특정 HTTP 헤더 (특히 SM_USER)를 추가합니다.
요청에서 해당 정보를 가져 오면됩니다.

1

SMSESSION 쿠키는 주기적으로 변경되므로 위 코드에서와 같이 정적으로 설정할 수 없습니다. Java를 사용하고 있으므로 SiteMinder 용 Java SDK

을 살펴볼 수 있습니다.