Selenium webdriver Selenium org.openqa.Selenium.logging.LoggingHandler

Selenium webdriver Selenium org.openqa.Selenium.logging.LoggingHandler,selenium-webdriver,java-8,Selenium Webdriver,Java 8,因此,我正在使用Java8尝试创建一个简单的Selenium项目,但在loggingHandler方面出现了错误。我在网上搜索了一个答案,但我找到解决方案的唯一一个帖子是降低依赖项的等级。任何协助都将不胜感激 import org.junit.runner.RunWith; import org.openqa.selenium.By; import org.openqa.selenium.WebDriver; import org.openqa.selenium.chrome.ChromeDri

因此,我正在使用Java8尝试创建一个简单的Selenium项目,但在loggingHandler方面出现了错误。我在网上搜索了一个答案,但我找到解决方案的唯一一个帖子是降低依赖项的等级。任何协助都将不胜感激

import org.junit.runner.RunWith;
import org.openqa.selenium.By;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.chrome.ChromeDriver;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;
import org.testng.annotations.AfterTest;
import org.testng.annotations.BeforeTest;
import org.testng.annotations.Test;

import java.io.*;
import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.TimeUnit;


@RunWith(SpringRunner.class)
@SpringBootTest
public class AutoDrive {
    @Test
    public void findElementbyXpath() {
      System.setProperty("webdriver.chrome.driver", "/Users/xxxx/dev/demo/src/main/resources/chromedriver");
    WebDriver driver = new ChromeDriver();

    driver.manage().timeouts().implicitlyWait(10, TimeUnit.SECONDS);
    driver.get("http:www.google.com");

    //Maximizes the browser window
    driver.manage().window().maximize();

    for (String word : sampleList) {
        //find text field
        driver.findElement(By.name("typeahead-combine")).sendKeys(word);
        //wait for results
        driver.manage().timeouts().implicitlyWait(10, TimeUnit.SECONDS);
    }
    //close browser
    driver.close();
    driver.quit();
}
我有以下依赖项:

<dependency>
    <groupId>org.seleniumhq.selenium</groupId>
    <artifactId>selenium-java</artifactId>
    <version>3.8.1</version>
</dependency>
<dependency>
    <groupId>org.seleniumhq.selenium</groupId>
    <artifactId>selenium-api</artifactId>
    <version>3.8.1</version>
</dependency>
<dependency>
    <groupId>org.seleniumhq.selenium</groupId>
    <artifactId>selenium-support</artifactId>
    <version>3.8.1</version>
</dependency>
<dependency>
    <groupId>org.seleniumhq.selenium</groupId>
    <artifactId>selenium-server</artifactId>
    <version>3.8.1</version>
</dependency>
<dependency>
    <groupId>org.seleniumhq.selenium</groupId>
    <artifactId>selenium-chrome-driver</artifactId>
    <version>3.8.1</version>
</dependency>

您可以将selenium api的版本更改为3.14.0


您是否尝试创建一个新项目并执行相同的操作?当您仅使用WebDriver的基本功能时,为什么需要在POM文件中添加这么多依赖项。我认为这对于您的工作org.seleniumhq.selenium java 3.8.1来说已经足够了
java.lang.NoClassDefFoundError: org/openqa/selenium/logging/LoggingHandler
    at com.example.demo.AutoComplete.findElementbyXpath(AutoComplete.java:60)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)
    at org.testng.internal.MethodInvocationHelper.invokeMethod(MethodInvocationHelper.java:80)
    at org.testng.internal.Invoker.invokeMethod(Invoker.java:714)
    at org.testng.internal.Invoker.invokeTestMethod(Invoker.java:901)
    at org.testng.internal.Invoker.invokeTestMethods(Invoker.java:1231)
    at org.testng.internal.TestMethodWorker.invokeTestMethods(TestMethodWorker.java:127)
    at org.testng.internal.TestMethodWorker.run(TestMethodWorker.java:111)
    at org.testng.TestRunner.privateRun(TestRunner.java:767)
    at org.testng.TestRunner.run(TestRunner.java:617)
    at org.testng.SuiteRunner.runTest(SuiteRunner.java:334)
    at org.testng.SuiteRunner.runSequentially(SuiteRunner.java:329)
    at org.testng.SuiteRunner.privateRun(SuiteRunner.java:291)
    at org.testng.SuiteRunner.run(SuiteRunner.java:240)
    at org.testng.SuiteRunnerWorker.runSuite(SuiteRunnerWorker.java:52)
    at org.testng.SuiteRunnerWorker.run(SuiteRunnerWorker.java:86)
    at org.testng.TestNG.runSuitesSequentially(TestNG.java:1198)
    at org.testng.TestNG.runSuitesLocally(TestNG.java:1123)
    at org.testng.TestNG.run(TestNG.java:1031)
    at org.testng.IDEARemoteTestNG.run(IDEARemoteTestNG.java:72)
    at org.testng.RemoteTestNGStarter.main(RemoteTestNGStarter.java:123)

    Caused by: java.lang.ClassNotFoundException: 
    org.openqa.selenium.logging.LoggingHandler
    at java.net.URLClassLoader.findClass(URLClassLoader.java:381)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:335)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
    ... 24 more