2017-02-28 109 views
-1

我想读取属性文件,并得到了以下给出的错误卡住了。我写了一个Scala包,其中我试图读取属性文件并调用abc.scala program.Any帮助将不胜感激。线程“主”异常java.lang.NoSuchMethodError:org.apache.commons.beanutils.PropertyUtilsBean

文件: - xyz.properties

driver = "oracle.jdbc.driver.OracleDriver" 
url = "jdbc:oracle:thin:@xxxx:1521/xxxx.xxxx" 
username = "xxx" 
password = "xxx" 
input_file = "C:\\Users\\xxx\\test\\src\\main\\resources\\xxxx.xlsx" 

build.sbt

name := "xxx.xxxx.xxxxx" 

scalaVersion := "2.10.6" 

ivyScala := ivyScala.value map{ _.copy(overrideScalaVersion = true) } 


libraryDependencies ++= Seq(
"org.apache.spark" %% "spark-core" % "2.1.0", 
"com.databricks" %% "spark-csv" % "1.5.0", 
"org.apache.commons" % "commons-configuration2" % "2.1.1", 
"commons-beanutils" % "commons-beanutils" % "1.9.3", 
"org.apache.spark" %% "spark-sql" % "2.1.0", 
"org.scala-lang" % "scala-xml" % "2.11.0-M4" ) 

package com.xxx.zzzz.xxx1 

     import java.io.File 
     import org.apache.commons.configuration2.builder.fluent.{Configurations, Parameters} 


     object Configuration { 

      var config = new Configurations() 
      var configs = config.properties(new File("xyz.properties")) 

      var inputFile = configs.getString("input") 
      var userName = configs.getString("user_name") 
      var password = configs.getString("passwd") 
      var driver = configs.getString("driver") 
      var url = configs.getString("Url") 

     } 

主程序abc.scala

import org.apache.spark.{SparkConf, SparkContext} 
import org.apache.spark.sql.SQLContext 
import package com.xxx.zzzz.xxx1.Configurations 
import org.apache.commons.beanutils.PropertyUtils 


object ItalyPanelData { 
    def main(args: Array[String]): Unit = { 

     //Logger.getRootLogger().setLevel(Level.OFF) 

     println("Inside main program"+ Configuration.driver) 
     //Set the properties for spark to connect the oracle database 
     val dbProp = new java.util.Properties 
     dbProp.setProperty("driver", Configuration.driver) 
     dbProp.setProperty("user", Configuration.userName) 
     dbProp.setProperty("password", Configuration.password) 


     //Create a connection to connect spark 
     val conf = new SparkConf().setAppName("Simple Application").setMaster("local") 
     val sc = new SparkContext(conf) 
     val sqlContext = new SQLContext(sc) 

    //exception handlying 
    try { 
     //Create dataframe boject 
     val df = sqlContext.read 
     .option("location", Configuration.inputFile)  //Initiating input path 
     .option("sheetName", "xyz")      //Give the SheetName 
     .option("useHeader", "true")      //It takes the header name from excel sheet 
     .option("treatEmptyValuesAsNulls", "true") 
     .option("inferSchema", "true") 
     .option("addColorColumns", "false") 
     .load() 
     // Write into oracale database 
     df.write.mode("append").jdbc(Configuration.url, "xyz", dbProp) 
    } 
    catch { 

     case e: Throwable => e.printStackTrace(); 
    } 

     } 
} 

错误

Exception in thread "main" java.lang.NoSuchMethodError: org.apache.commons.beanutils.PropertyUtilsBean.addBeanIntrospector(Lorg/apache/commons/beanutils/BeanIntrospector;)V 
at org.apache.commons.configuration2.beanutils.BeanHelper.initBeanUtilsBean(BeanHelper.java:631) 
at org.apache.commons.configuration2.beanutils.BeanHelper.<clinit>(BeanHelper.java:89) 
at java.lang.Class.forName0(Native Method) 
at java.lang.Class.forName(Class.java:264) 
at com.sun.proxy.$Proxy0.<clinit>(Unknown Source) 
at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) 
at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62) 
at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45) 
at java.lang.reflect.Constructor.newInstance(Constructor.java:423) 
at java.lang.reflect.Proxy.newProxyInstance(Proxy.java:739) 
at org.apache.commons.configuration2.builder.fluent.Parameters.createParametersProxy(Parameters.java:294) 
at org.apache.commons.configuration2.builder.fluent.Parameters.fileBased(Parameters.java:185) 
at org.apache.commons.configuration2.builder.fluent.Configurations.fileParams(Configurations.java:602) 
at org.apache.commons.configuration2.builder.fluent.Configurations.fileParams(Configurations.java:614) 
at org.apache.commons.configuration2.builder.fluent.Configurations.fileBasedBuilder(Configurations.java:132) 
at org.apache.commons.configuration2.builder.fluent.Configurations.propertiesBuilder(Configurations.java:238) 
at org.apache.commons.configuration2.builder.fluent.Configurations.properties(Configurations.java:282) 
at com.rxcorp.italy.config.Configuration$.<init>(Configuration.scala:8) 
at com.rxcorp.italy.config.Configuration$.<clinit>(Configuration.scala) 
at com.rxcorp.paneldataloading.ItalyPanelData$.main(abc.scala:12) 
+0

只是想知道:我的答案是否帮助你到底?如果是这样,请考虑在某些时候接受。 – GhostCat

回答

3

此类异常表示版本不兼容。

含义:你所编写的代码(或更可能:表面下的图书馆之一)要调用的方法

org.apache.commons.beanutils.PropertyUtilsBean.addBeanIntrospector(BeanIntrospector[]); 

但事情是:在运行,类PropertyUtilsBean的文件不包含该方法。

因此:您必须退后一步并理解堆栈中的组件,并查看它们在Apache commons库上的版本要求。

当你看到javadoc的时候,你会得到更多的想法method;因为它说:因为:1.9那里。

换句话说:这个方法被加入了Apache commons 1.9;所以你的一堆预计至少就是版本的公域;但是执行整个事件的JVM中的类路径...具有较旧的版本。

所以:检查Apache的公共类路径;并且很可能你只需更新到较新版本的Apache公共版即可。 (是的,也许这意味着更多的“硬”调试工作;至少你的构建设置包括更新版本的Apache公共版)。

相关问题