Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/351.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java Selenium 3.3.1:NodeClassFound(com.google.common.base.Function)_Java_Maven_Selenium - Fatal编程技术网

Java Selenium 3.3.1:NodeClassFound(com.google.common.base.Function)

Java Selenium 3.3.1:NodeClassFound(com.google.common.base.Function),java,maven,selenium,Java,Maven,Selenium,我遇到了一个最奇怪的问题,即Selenium 3.3.1,在尝试启动ChromeDriver(或FirefoxDriver)时,使用最简单的代码: 编辑:添加了完整的类 import java.util.concurrent.TimeUnit; import org.openqa.selenium.WebDriver; import org.openqa.selenium.chrome.ChromeDriver; public class App { public static voi

我遇到了一个最奇怪的问题,即Selenium 3.3.1,在尝试启动
ChromeDriver
(或
FirefoxDriver
)时,使用最简单的代码:

编辑:添加了完整的类

import java.util.concurrent.TimeUnit;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.chrome.ChromeDriver;

public class App {
    public static void main(String[] args) {
        // testCrawl();
        seleniumGetDoc();
    }

    public static void seleniumGetDoc() {
        System.setProperty("webdriver.chrome.driver", "path/to/chromedriver");
        WebDriver driver = new ChromeDriver(); //here something goes terribly wrong
        driver.manage().timeouts().implicitlyWait(15, TimeUnit.SECONDS);
        driver.get("https://google.com/");
        String htmlContent = driver.getPageSource();
        System.out.println(driver.getCurrentUrl());
    }
}
在我的pom中具有以下依赖项:

    <dependency>
        <groupId>org.seleniumhq.selenium</groupId>
        <artifactId>selenium-java</artifactId>
        <version>3.3.1</version>
    </dependency>
    <!-- https://mvnrepository.com/artifact/org.seleniumhq.selenium/selenium-server -->
    <dependency>
        <groupId>org.seleniumhq.selenium</groupId>
        <artifactId>selenium-server</artifactId>
        <version>3.3.1</version>
    </dependency>
尽管如此,当降级我的selenium版本时,它可以与以下依赖项正常工作:

   <dependency>
        <groupId>org.seleniumhq.selenium</groupId>
        <artifactId>selenium-java</artifactId>
        <version>2.45.0</version>
    </dependency>
    <dependency>
        <groupId>org.seleniumhq.selenium</groupId>
        <artifactId>selenium-server</artifactId>
        <version>3.0.1</version>
    </dependency>
<dependencies>
    <!-- https://mvnrepository.com/artifact/org.jsoup/jsoup -->
    <dependency>
        <groupId>org.jsoup</groupId>
        <artifactId>jsoup</artifactId>
        <version>1.10.2</version>
    </dependency>

    <dependency>
        <groupId>org.seleniumhq.selenium</groupId>
        <artifactId>selenium-java</artifactId>
        <version>3.3.1</version>
    </dependency>
    <dependency>
        <groupId>org.seleniumhq.selenium</groupId>
        <artifactId>selenium-server</artifactId>
        <version>3.3.1</version>
    </dependency>

    <dependency>
        <groupId>org.apache.logging.log4j</groupId>
        <artifactId>log4j-api</artifactId>
        <version>2.8</version>
    </dependency>
    <dependency>
        <groupId>org.apache.logging.log4j</groupId>
        <artifactId>log4j-core</artifactId>
        <version>2.8</version>
    </dependency>
    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>4.12</version>
        <scope>test</scope>
    </dependency>
</dependencies>
同样在运行
mvn dependency:tree
时,maven指出只有selenium java依赖
com.google.guava:guava:jar:21.0:compile

编辑添加我的依赖关系树:

[INFO] org.linkedin.crawler:main:jar:0.0.1-SNAPSHOT
[INFO] +- org.jsoup:jsoup:jar:1.10.2:compile
[INFO] +- org.seleniumhq.selenium:selenium-java:jar:3.3.1:compile
[INFO] |  +- org.seleniumhq.selenium:selenium-chrome-driver:jar:3.3.1:compile
[INFO] |  |  \- org.seleniumhq.selenium:selenium-remote-driver:jar:3.3.1:compile
[INFO] |  |     +- org.seleniumhq.selenium:selenium-api:jar:3.3.1:compile
[INFO] |  |     +- cglib:cglib-nodep:jar:3.2.4:compile
[INFO] |  |     +- org.apache.commons:commons-exec:jar:1.3:compile
[INFO] |  |     +- com.google.code.gson:gson:jar:2.8.0:compile
[INFO] |  |     +- com.google.guava:guava:jar:21.0:compile
[INFO] |  |     +- org.apache.httpcomponents:httpclient:jar:4.5.2:compile
[INFO] |  |     |  \- org.apache.httpcomponents:httpcore:jar:4.4.4:compile
[INFO] |  |     \- net.java.dev.jna:jna-platform:jar:4.1.0:compile
[INFO] |  |        \- net.java.dev.jna:jna:jar:4.1.0:compile
[INFO] |  +- org.seleniumhq.selenium:selenium-edge-driver:jar:3.3.1:compile
[INFO] |  +- org.seleniumhq.selenium:selenium-firefox-driver:jar:3.3.1:compile
[INFO] |  +- org.seleniumhq.selenium:selenium-ie-driver:jar:3.3.1:compile
[INFO] |  +- org.seleniumhq.selenium:selenium-opera-driver:jar:3.3.1:compile
[INFO] |  +- org.seleniumhq.selenium:selenium-safari-driver:jar:3.3.1:compile
[INFO] |  +- com.codeborne:phantomjsdriver:jar:1.4.0:compile
[INFO] |  \- org.seleniumhq.selenium:htmlunit-driver:jar:2.24:compile
[INFO] |     +- org.seleniumhq.selenium:selenium-support:jar:3.3.1:compile (version selected from constraint [2.53.0,4.0.0))
[INFO] |     |  \- org.hamcrest:hamcrest-library:jar:1.3:compile
[INFO] |     \- net.sourceforge.htmlunit:htmlunit:jar:2.24:compile
[INFO] |        +- xalan:xalan:jar:2.7.2:compile
[INFO] |        |  \- xalan:serializer:jar:2.7.2:compile
[INFO] |        +- org.apache.commons:commons-lang3:jar:3.5:compile
[INFO] |        +- org.apache.httpcomponents:httpmime:jar:4.5.2:compile
[INFO] |        +- commons-codec:commons-codec:jar:1.10:compile
[INFO] |        +- net.sourceforge.htmlunit:htmlunit-core-js:jar:2.23:compile
[INFO] |        +- net.sourceforge.htmlunit:neko-htmlunit:jar:2.24:compile
[INFO] |        |  \- xerces:xercesImpl:jar:2.11.0:compile
[INFO] |        |     \- xml-apis:xml-apis:jar:1.4.01:compile
[INFO] |        +- net.sourceforge.cssparser:cssparser:jar:0.9.21:compile
[INFO] |        |  \- org.w3c.css:sac:jar:1.3:compile
[INFO] |        +- commons-io:commons-io:jar:2.5:compile
[INFO] |        +- commons-logging:commons-logging:jar:1.2:compile
[INFO] |        \- org.eclipse.jetty.websocket:websocket-client:jar:9.2.20.v20161216:compile
[INFO] |           +- org.eclipse.jetty:jetty-util:jar:9.2.20.v20161216:compile
[INFO] |           +- org.eclipse.jetty:jetty-io:jar:9.2.20.v20161216:compile
[INFO] |           \- org.eclipse.jetty.websocket:websocket-common:jar:9.2.20.v20161216:compile
[INFO] |              \- org.eclipse.jetty.websocket:websocket-api:jar:9.2.20.v20161216:compile
[INFO] +- org.seleniumhq.selenium:selenium-server:jar:3.3.1:compile
[INFO] |  +- com.beust:jcommander:jar:1.48:compile
[INFO] |  +- net.jcip:jcip-annotations:jar:1.0:compile
[INFO] |  +- org.seleniumhq.selenium:jetty-repacked:jar:9.4.1.v20170120:compile
[INFO] |  |  \- javax.servlet:javax.servlet-api:jar:3.1.0:compile
[INFO] |  \- org.yaml:snakeyaml:jar:1.15:compile
[INFO] +- org.apache.logging.log4j:log4j-api:jar:2.8:compile
[INFO] +- org.apache.logging.log4j:log4j-core:jar:2.8:compile
[INFO] \- junit:junit:jar:4.12:test
[INFO]    \- org.hamcrest:hamcrest-core:jar:1.3:compile
更新:它与3.3.1版的
selenium服务器
selenium java
3.0.1版一起工作,从
selenium java
version>3.1.x开始出现上述相同错误

编辑添加我的完整pom:

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>org.main.groupid</groupId>
    <artifactId>main</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <packaging>jar</packaging>

    <name>main</name>
    <url>http://maven.apache.org</url>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <maven.compiler.source>1.8</maven.compiler.source>
        <maven.compiler.target>1.8</maven.compiler.target>
    </properties>

    <build>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-dependency-plugin</artifactId>
                <version>3.0.0</version>
                <executions>
                    <execution>
                        <id>copy-dependencies</id>
                        <phase>package</phase>
                        <goals>
                            <goal>copy-dependencies</goal>
                        </goals>
                        <configuration>
                            <outputDirectory>${project.build.directory}/lib/</outputDirectory>
                            <overWriteReleases>false</overWriteReleases>
                            <overWriteSnapshots>false</overWriteSnapshots>
                            <overWriteIfNewer>true</overWriteIfNewer>
                        </configuration>
                    </execution>
                </executions>
            </plugin>
            <plugin>
                <!-- Build an executable JAR -->
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-jar-plugin</artifactId>
                <version>3.0.2</version>
                <configuration>
                    <archive>
                        <manifest>
                            <addClasspath>true</addClasspath>
                            <classpathPrefix>lib/</classpathPrefix>
                            <mainClass>my.main.Class</mainClass>
                        </manifest>
                    </archive>
                    <excludes>
                        <exclude>**/*log4j*</exclude>
                    </excludes>
                </configuration>
            </plugin>


        </plugins>
    </build>

    <dependencies>
        <dependency>
            <groupId>org.jsoup</groupId>
            <artifactId>jsoup</artifactId>
            <version>1.10.2</version>
        </dependency>
        <dependency>
            <groupId>org.seleniumhq.selenium</groupId>
            <artifactId>selenium-java</artifactId>
            <version>3.3.1</version>
        </dependency>
        <dependency>
            <groupId>org.seleniumhq.selenium</groupId>
            <artifactId>selenium-server</artifactId>
            <version>3.3.1</version>
        </dependency>



        <dependency>
            <groupId>org.apache.logging.log4j</groupId>
            <artifactId>log4j-api</artifactId>
            <version>2.8</version>
        </dependency>
        <dependency>
            <groupId>org.apache.logging.log4j</groupId>
            <artifactId>log4j-core</artifactId>
            <version>2.8</version>
        </dependency>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.12</version>
            <scope>test</scope>
        </dependency>
    </dependencies>
</project>

4.0.0
org.main.groupid
主要的
0.0.1-快照
罐子
主要的
http://maven.apache.org
UTF-8
1.8
1.8
org.apache.maven.plugins
maven依赖插件
3.0.0
复制依赖项
包裹
复制依赖项
${project.build.directory}/lib/
假的
假的
真的
org.apache.maven.plugins
maven jar插件
3.0.2
真的
解放党/
我的主课
**/*log4j*
org.jsoup
jsoup
1.10.2
org.seleniumhq.selenium
硒爪哇
3.3.1
org.seleniumhq.selenium
硒服务器
3.3.1
org.apache.logging.log4j
log4japi
2.8
org.apache.logging.log4j
log4j型芯
2.8
朱尼特
朱尼特
4.12
测试

很有趣。留下这个作为回答,因为它太长了,无法发表评论。我试图复制你的问题,它对我来说很好。您是否在类路径的某个位置添加了其他内容?您是从IDE运行还是从命令行的maven命令运行?另外,您使用的chrome版本是什么?您的chrome版本是否有正确的chromedriver版本

我使用了以下测试代码:

package com.foo;

import org.junit.Test;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.chrome.ChromeDriver;
import java.util.concurrent.TimeUnit;

public class SeleniumTest {

    @Test
    public void testFoo() throws Exception {
        System.setProperty("webdriver.chrome.driver", "MY_CHROMEDRIVER_PATH");
        WebDriver driver = new ChromeDriver();
        driver.manage().timeouts().implicitlyWait(15, TimeUnit.SECONDS);
        driver.get("https://google.com/");
        String htmlContent = driver.getPageSource();
        System.out.println(driver.getCurrentUrl());
        System.out.println(htmlContent);
        Thread.sleep(2_000);
        driver.quit();
    }
}
这个pom文件:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>com.foo</groupId>
    <artifactId>selenium-test</artifactId>
    <version>1.0-SNAPSHOT</version>

    <dependencies>
        <dependency>
            <groupId>org.jsoup</groupId>
            <artifactId>jsoup</artifactId>
            <version>1.10.2</version>
        </dependency>
        <dependency>
            <groupId>org.seleniumhq.selenium</groupId>
            <artifactId>selenium-java</artifactId>
            <version>3.3.1</version>
        </dependency>
        <dependency>
            <groupId>org.seleniumhq.selenium</groupId>
            <artifactId>selenium-server</artifactId>
            <version>3.3.1</version>
        </dependency>
        <dependency>
            <groupId>org.apache.logging.log4j</groupId>
            <artifactId>log4j-api</artifactId>
            <version>2.8</version>
        </dependency>
        <dependency>
            <groupId>org.apache.logging.log4j</groupId>
            <artifactId>log4j-core</artifactId>
            <version>2.8</version>
        </dependency>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.12</version>
            <scope>test</scope>
        </dependency>
    </dependencies>
</project>

4.0.0
com.foo
硒试验
1.0-快照
org.jsoup
jsoup
1.10.2
org.seleniumhq.selenium
硒爪哇
3.3.1
org.seleniumhq.selenium
硒服务器
3.3.1
org.apache.logging.log4j
log4japi
2.8
org.apache.logging.log4j
log4j型芯
2.8
朱尼特
朱尼特
4.12
测试

很有趣。留下这个作为回答,因为它太长了,无法发表评论。我试图复制你的问题,它对我来说很好。您是否在类路径的某个位置添加了其他内容?您是从IDE运行还是从命令行的maven命令运行?另外,您使用的chrome版本是什么?您的chrome版本是否有正确的chromedriver版本

我使用了以下测试代码:

package com.foo;

import org.junit.Test;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.chrome.ChromeDriver;
import java.util.concurrent.TimeUnit;

public class SeleniumTest {

    @Test
    public void testFoo() throws Exception {
        System.setProperty("webdriver.chrome.driver", "MY_CHROMEDRIVER_PATH");
        WebDriver driver = new ChromeDriver();
        driver.manage().timeouts().implicitlyWait(15, TimeUnit.SECONDS);
        driver.get("https://google.com/");
        String htmlContent = driver.getPageSource();
        System.out.println(driver.getCurrentUrl());
        System.out.println(htmlContent);
        Thread.sleep(2_000);
        driver.quit();
    }
}
这个pom文件:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>com.foo</groupId>
    <artifactId>selenium-test</artifactId>
    <version>1.0-SNAPSHOT</version>

    <dependencies>
        <dependency>
            <groupId>org.jsoup</groupId>
            <artifactId>jsoup</artifactId>
            <version>1.10.2</version>
        </dependency>
        <dependency>
            <groupId>org.seleniumhq.selenium</groupId>
            <artifactId>selenium-java</artifactId>
            <version>3.3.1</version>
        </dependency>
        <dependency>
            <groupId>org.seleniumhq.selenium</groupId>
            <artifactId>selenium-server</artifactId>
            <version>3.3.1</version>
        </dependency>
        <dependency>
            <groupId>org.apache.logging.log4j</groupId>
            <artifactId>log4j-api</artifactId>
            <version>2.8</version>
        </dependency>
        <dependency>
            <groupId>org.apache.logging.log4j</groupId>
            <artifactId>log4j-core</artifactId>
            <version>2.8</version>
        </dependency>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.12</version>
            <scope>test</scope>
        </dependency>
    </dependencies>
</project>

4.0.0
com.foo
硒试验
1.0-快照
org.jsoup
jsoup
1.10.2
org.seleniumhq.selenium
硒爪哇
3.3.1
org.seleniumhq.selenium
硒服务器
3.3.1
org.apache.logging.log4j
log4japi
2.8
org.apache.logging.log4j
log4j型芯
2.8
朱尼特
朱尼特
4.12
测试

我的类路径中有两个不同版本的guava.jar导致了这个问题,从我的类路径中删除旧版本就解决了这个问题。

我的类路径中有两个不同版本的guava.jar导致了这个问题,从我的类路径中删除旧版本就解决了这个问题。

我也有类似的问题,并将其缩小到包括Selenium 3.3.1单机版和HTMLUnit驱动程序单机版2.21。原来我根本不需要HTMLUnit罐子。它已经包含在3.3.1依赖项中。(如果我没记错的话,上一个版本没有包含HTMLUnit,这就是我之前单独添加它的原因……这可以解释>3.01部分。)


现在,我不使用SeleniumJava部分。。。只有独立服务器,但看起来您有两个HTMLUnit版本。。。dep列表中的2.24和2.23,因此它可能是一个类似的问题。

我遇到了类似的问题,并将其缩小到包括Selenium 3.3.1 Standalone和HTMLUnit driver Standalone 2.21。原来我根本不需要HTMLUnit罐子。已经是了