我有一个预定的作业类,实现了Quartz Job类,我想从中调用一个Servlet类来更新数据库表中的标志,然后将电子邮件发送到适当的电子邮件列表。
我得到java.net.ConnectException
。虽然通过在浏览器中输入URL或在JSP页面中输入JavaScript来正确调用servlet。
我的Java类如下:
public class ExpirationJob implements Job {
org.apache.log4j.Logger log = org.apache.log4j.Logger.getLogger("ExpirationJob.class");
public void execute(JobExecutionContext context)
throws JobExecutionException {
try {
URL serv = new URL("http://localhost:8080/app/emailExpirationServlet");
URLConnection sr = serv.openConnection();
sr.connect();
InputStream is = sr.getInputStream();
InputStreamReader isr = new InputStreamReader(is);
BufferedReader in = new BufferedReader(isr);
String inputLine;
int i =0;
while ((inputLine = in.readLine()) != null)
i = i +1;
log.debug("Input line: " + inputLine);
in.close();
} catch (MalformedURLException e) {
log.debug("Error while calling the emailExpirationServlet -- MalformedURLException: "+ e.getMessage());
e.printStackTrace();
} catch (IOException e) {
log.debug("Error while calling the emailExpirationServlet -- IOException: "+ e.getMessage());
e.printStackTrace();
}
}
}
我的servlet代码是:
public class emailExpireServlet extends HttpServlet {
private static final String CONTENT_TYPE = "text/html; charset=UTF-8";
org.apache.log4j.Logger log = org.apache.log4j.Logger.getLogger("emailExpireServlet.class");
public void init(ServletConfig config) throws ServletException {
super.init(config);
log.debug("Initializing emailExpireServlet");
}
public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
request.setCharacterEncoding("UTF-8");
response.setContentType("text/html;charset=UTF-8");
response.setDateHeader("Expires", 0);
response.setHeader("Cache-Control", "no-cache");
log.debug("Starting emailExpireServlet");
//do some business logic here - I have commented it out to rule out any other blocking issue
response.setStatus(200);
response.getOutputStream().print("Invoked emailExpireServlet! Status is OK");
}
public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
doGet(request, response);
}
}
我得到的例外是:
java.net.ConnectException: Connection refused: connect
at java.net.PlainSocketImpl.socketConnect(Native Method)
at java.net.PlainSocketImpl.doConnect(PlainSocketImpl.java:333)
at java.net.PlainSocketImpl.connectToAddress(PlainSocketImpl.java:195)
at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:182)
at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:366)
at java.net.Socket.connect(Socket.java:525)
at java.net.Socket.connect(Socket.java:475)
at sun.net.NetworkClient.doConnect(NetworkClient.java:163)
at sun.net.www.http.HttpClient.openServer(HttpClient.java:394)
at sun.net.www.http.HttpClient.openServer(HttpClient.java:529)
at sun.net.www.http.HttpClient.<init>(HttpClient.java:233)
at sun.net.www.http.HttpClient.New(HttpClient.java:306)
at sun.net.www.http.HttpClient.New(HttpClient.java:323)
at sun.net.www.protocol.http.HttpURLConnection.getNewHttpClient(HttpURLConnection.java:860)
at sun.net.www.protocol.http.HttpURLConnection.plainConnect(HttpURLConnection.java:801)
at sun.net.www.protocol.http.HttpURLConnection.connect(HttpURLConnection.java:726)
at schedulers.ExpirationJob.execute(Unknown Source)
at org.quartz.core.JobRunShell.run(JobRunShell.java:213)
at org.quartz.simpl.SimpleThreadPool$WorkerThread.run(SimpleThreadPool.java:557)
我正在使用Tomcat 5.5。
我见过很多其他相关帖子但没有帮助,我也尝试了HttpClient
,但同样的例外情况。
有谁能弄明白问题是什么?
web.xml
上的servlet配置是:
<servlet>
<servlet-name>emailExpireServlet</servlet-name>
<servlet-class>emailExpireServlet</servlet-class>
</servlet>
...
<servlet-mapping>
<servlet-name>emailExpireServlet</servlet-name>
<url-pattern>/emailExpireServlet</url-pattern>
</servlet-mapping>
答案 0 :(得分:2)
您应该重构代码,将此功能从servlet中移出,并进入可以从servlet和预定作业中访问的公共类。
答案 1 :(得分:0)
URLConnection
打开指向URL引用的资源的通信链接,如果尚未建立此类连接。
URL.openConnection()
返回一个URLConnection
对象,表示与URL引用的远程对象的连接。
每次都会打开一个新连接,方法是调用此URL的协议处理程序的openConnection
方法。