java中user无法解析为类型,无法解析为一种类型

I am trying to use HTTP Authentication in my JSP code. But I am getting error on MyAuthenticator cannot be resolved to a type. Is the sytax correct for the code that I have writtent in jsp page. Any suggestions will be appreciated..

pageEncoding="ISO-8859-1"%>

String urlToQuery = request.getParameter("url");

System.out.println(" " +urlToQuery);

//URL url = new URL(urlToQuery);

//InputStream in = conn.getInputStream();

String urlString = "";

String username = "";

String password = "";

Authenticator.setDefault(new MyAuthenticator(username, password));

URL url = new URL(urlToQuery);

URLConnection conn = url.openConnection();

InputStream content = (InputStream) url.getContent();

BufferedReader in = new BufferedReader(new InputStreamReader(content));

String line;

while ((line = in.readLine()) != null) {

System.out.println(line);

}

System.out.println("Done.");

class MyAuthenticator extends Authenticator {

private String username, password;

public MyAuthenticator(String user, String pass) {

username = user;

password = pass;

}

protected PasswordAuthentication getPasswordAuthentication() {

System.out.println("Requesting Host : " + getRequestingHost());

System.out.println("Requesting Port : " + getRequestingPort());

System.out.println("Requesting Prompt : " + getRequestingPrompt());

System.out.println("Requesting Protocol: " + getRequestingProtocol());

System.out.println("Requesting Scheme : " + getRequestingScheme());

System.out.println("Requesting Site : " + getRequestingSite());

return new PasswordAuthentication(username, password.toCharArray());

}

}

%>

解决方案

leads JSP to treat the code contents as statements. Therefore you class becomes a local class following the same scope rules as local variables (that is, you must declare the class earlier than using it). I didn't test it, but if you rewrite your code to:

pageEncoding="ISO-8859-1"%>

class MyAuthenticator extends Authenticator {

private String username, password;

public MyAuthenticator(String user, String pass) {

username = user;

password = pass;

}

protected PasswordAuthentication getPasswordAuthentication() {

System.out.println("Requesting Host : " + getRequestingHost());

System.out.println("Requesting Port : " + getRequestingPort());

System.out.println("Requesting Prompt : " + getRequestingPrompt());

System.out.println("Requesting Protocol: " + getRequestingProtocol());

System.out.println("Requesting Scheme : " + getRequestingScheme());

System.out.println("Requesting Site : " + getRequestingSite());

return new PasswordAuthentication(username, password.toCharArray());

}

}

String urlToQuery = request.getParameter("url");

System.out.println(" " +urlToQuery);

//URL url = new URL(urlToQuery);

//InputStream in = conn.getInputStream();

String urlString = "";

String username = "";

String password = "";

Authenticator.setDefault(new MyAuthenticator(username, password));

URL url = new URL(urlToQuery);

URLConnection conn = url.openConnection();

InputStream content = (InputStream) url.getContent();

BufferedReader in = new BufferedReader(new InputStreamReader(content));

String line;

while ((line = in.readLine()) != null) {

System.out.println(line);

}

System.out.println("Done.");

%>

Then MyAuthenticator should be resolvable in your code.

Consider moving the Java class to a separate file to make your code more readable.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值