Commit cfed860f authored by yihua.huang's avatar yihua.huang

Merge branch 'master' of github.com:code4craft/webmagic

parents 2189aab6 14910335
...@@ -83,6 +83,15 @@ public class UrlUtils { ...@@ -83,6 +83,15 @@ public class UrlUtils {
return domain; return domain;
} }
public static String removePort(String domain) {
int portIndex = domain.indexOf(":");
if (portIndex != -1) {
return domain.substring(0, portIndex);
}else {
return domain;
}
}
/** /**
* allow blank space in quote * allow blank space in quote
*/ */
......
...@@ -6,6 +6,7 @@ import us.codecraft.webmagic.Request; ...@@ -6,6 +6,7 @@ import us.codecraft.webmagic.Request;
import us.codecraft.webmagic.Spider; import us.codecraft.webmagic.Spider;
import us.codecraft.webmagic.SpiderListener; import us.codecraft.webmagic.SpiderListener;
import us.codecraft.webmagic.utils.Experimental; import us.codecraft.webmagic.utils.Experimental;
import us.codecraft.webmagic.utils.UrlUtils;
import javax.management.*; import javax.management.*;
import java.lang.management.ManagementFactory; import java.lang.management.ManagementFactory;
...@@ -103,7 +104,8 @@ public class SpiderMonitor { ...@@ -103,7 +104,8 @@ public class SpiderMonitor {
} }
protected void registerMBean(SpiderStatusMXBean spiderStatus) throws MalformedObjectNameException, InstanceAlreadyExistsException, MBeanRegistrationException, NotCompliantMBeanException { protected void registerMBean(SpiderStatusMXBean spiderStatus) throws MalformedObjectNameException, InstanceAlreadyExistsException, MBeanRegistrationException, NotCompliantMBeanException {
ObjectName objName = new ObjectName(jmxServerName + ":name=" + spiderStatus.getName()); // ObjectName objName = new ObjectName(jmxServerName + ":name=" + spiderStatus.getName());
ObjectName objName = new ObjectName(jmxServerName + ":name=" + UrlUtils.removePort(spiderStatus.getName()));
mbeanServer.registerMBean(spiderStatus, objName); mbeanServer.registerMBean(spiderStatus, objName);
} }
......
package us.codecraft.webmagic.monitor;
import org.junit.Test;
import us.codecraft.webmagic.Page;
import us.codecraft.webmagic.Site;
import us.codecraft.webmagic.Spider;
import us.codecraft.webmagic.processor.PageProcessor;
import javax.management.JMException;
/**
* @author jerry_shenchao@163.com
*/
public class SeedUrlWithPortTest {
@Test
public void testSeedUrlWithPort() throws JMException {
Spider spider = Spider.create(new TempProcessor()).addUrl("http://www.hndpf.org:8889/");
SpiderMonitor.instance().register(spider);
spider.run();
}
}
class TempProcessor implements PageProcessor {
@Override
public void process(Page page) {
}
@Override
public Site getSite() {
return Site.me();
}
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment