📄 updatenotificationpingsclient.java
字号:
/* * Copyright (c) 2003-2006, Simon Brown * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are met: * * - Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * - Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in * the documentation and/or other materials provided with the * distribution. * * - Neither the name of Pebble nor the names of its contributors may * be used to endorse or promote products derived from this software * without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE * POSSIBILITY OF SUCH DAMAGE. */package net.sourceforge.pebble.webservice;import net.sourceforge.pebble.domain.Blog;import org.apache.commons.logging.Log;import org.apache.commons.logging.LogFactory;import org.apache.xmlrpc.AsyncCallback;import org.apache.xmlrpc.XmlRpcClient;import java.io.IOException;import java.net.URL;import java.util.Hashtable;import java.util.Vector;/** * A simple client to ping (notify) sites like weblogs.com when this blog has * been updated. * * @author Simon Brown */public class UpdateNotificationPingsClient { /** the log used by this class */ private static Log log = LogFactory.getLog(UpdateNotificationPingsClient.class); /** the name of the method to call via XML-RPC */ private static final String WEBLOGS_METHOD_NAME = "weblogUpdates.ping"; /** * Sends a weblogUpdates.ping indicating this the specified blog has * recently been updated. This version sends the blog's home URL. * * @param blog the Blog representing the updated blog * @param sites the list of sites (URLs) to ping */ public void sendUpdateNotificationPing(Blog blog, String[] sites) { sendUpdateNotificationPing(blog, blog.getUrl(), sites); } /** * Sends a weblogUpdates.ping indicating this the specified blog has * recently been updated. This version sends an arbitrary URL. * * @param blog the Blog representing the updated blog * @param url the URL to send the ping for * @param sites the list of sites (URLs) to ping */ public void sendUpdateNotificationPing(Blog blog, String url, String[] sites) { try { for (String site : sites) { log.info("Sending XML-RPC ping to " + site); blog.info("Sending XML-RPC ping to " + site); XmlRpcClient xmlrpc = new XmlRpcClient(site); Vector params = new Vector(); params.addElement(blog.getName()); params.addElement(url); xmlrpc.executeAsync(WEBLOGS_METHOD_NAME, params, new UpdateNotificationPingsAsyncCallback(blog)); } } catch (IOException ioe) { log.error(ioe.getMessage(), ioe); } } /** * A callback class used to log the result/error message. */ class UpdateNotificationPingsAsyncCallback implements AsyncCallback { private Blog blog; public UpdateNotificationPingsAsyncCallback(Blog blog) { this.blog = blog; } /** * Called if the XML-RPC was successful. * * @param o the resulting Object * @param url the original URL * @param method the original method name */ public void handleResult(Object o, URL url, String method) { Hashtable result = (Hashtable)o; if (result != null) { log.info("Result of XML-RPC ping to " + method + " at " + url + " was " + result.get("flerror") + ", " + result.get("message")); blog.info("Result of XML-RPC ping to " + method + " at " + url + " was " + result.get("flerror") + ", " + result.get("message")); } } /** * Called if the XML-RPC was not successful. * * @param e the resulting Exception * @param url the original URL * @param method the original method name */ public void handleError(Exception e, URL url, String method) { log.error("Exception when calling " + method + " at " + url, e); } }}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -