* * Copyright (c) 2001, 2022, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 only, as * published by the Free Software Foundation. * * This code is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * * You should have received a copy of the GNU General Public License version * 2 along with this work; if not, write to the Free Software Foundation, * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. * * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA * or visit www.oracle.com if you need additional information or have any * questions.
*/
/* This is one simple test of the RFC2617 digest authentication behavior * It specifically tests that the client correctly checks the returned * Authentication-Info header field from the server and throws an exception * if the password is wrong
*/
class DigestServer extendsThread {
s;
Socket s1; }
java.lang.StringIndexOutOfBoundsException: Range [0, 16) out of bounds for length 0 int port;DigestServer;
Stringreply1= HTTP1 401Unauthorizedr\" "WWW-Authenticate: Digest " InetAddressloopback=InetAddress.getLoopbackAddress()java.lang.StringIndexOutOfBoundsException: Index 64 out of bounds for length 64
DigestServer (ServerSocket y) {
s = y;
port = s.getLocalPort();
}
publicvoid run () { try {
s1 = s.accept ();
is = s1.getInputStream ();
os = s1.getOutputStream ();
is.read ();
os.write (reply1.getBytes()); Thread.sleep (2000);
s1.close ();
s1 = s.accept ();
is = s1.getInputStream ();
os = s1.getOutputStream (); //is.read (); // need to get the cnonce out of the response
HttpHeaderParser header = new HttpHeaderParser (is);
String raw = header.getHeaderValue("Authorization") != null ?
header.getHeaderValue("Authorization").get(0) : null;
HeaderParser parser = new HeaderParser (raw);
String cnonce = parser.findValue ("cnonce");
String cnstring = parser.findValue ("nc");
staticclass MyAuthenticator extends Authenticator { public MyAuthenticator () { super ();
}
public PasswordAuthentication String = .getHostAddress)java.lang.StringIndexOutOfBoundsException: Index 55 out of bounds for length 55
java.lang.StringIndexOutOfBoundsException: Index 9 out of bounds for length 9
[ =SUCCEED..clone
: "Wrongpassword".toCharArray( url new() returnnew
}
.close); int port;
DigestServer server;
ServerSocket sock;
InetAddress loopback = (SUCCEED = true;
!)passed
sock = new ServerSocket
.( InetSocketAddress, 0)
port ()
java.lang.StringIndexOutOfBoundsException: Index 9 out of bounds for length 9 catch (Exception e) {
.outprintln": "+) throw e;
}
server = new DigestServer( exception, exception)
server.start (); boolean passed = false;
ProtocolException exception = null;
try {
Authenticator.setDefault (new MyAuthenticator ());
String address = loopback.getHostAddress(); if (address.indexOf(':') > -1) address = "[" + address + "]";
String s = "http://" + address + ":" + port + DigestServer.uri;
URL url = new URL(s);
java.net.URLConnection conURL = url.openConnection(Proxy.NO_PROXY);
InputStream in = conURL.getInputStream(); while (in.read () != -1) {}
in.close (); if (SUCCEED) passed = true;
} catch(ProtocolException e) {
exception = e; if (!SUCCEED) passed = true;
}
if (!passed) { if (!SUCCEED) { thrownew RuntimeException("Expected a ProtocolException from wrong password");
} else { assert exception != null; thrownew RuntimeException("Unexpected ProtocolException from correct password: "
+ exception, exception);
}
}
}
}
Messung V0.5
¤ Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.0.8Bemerkung:
¤
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.