配置web.xml中的 Invalid content was found starting with element 'init-param'.错误

在搭建SpringMVC框架的过程中,配置DispatcherServlet时遇到Invalid content was found starting with element 'init-param'错误。该错误通常发生在web.xml文件的配置不正确时,可能是由于元素放置顺序或格式有误导致。

今天在搭建springmvc框架时,需要配置web.xml中的DispatcherServlet

初始化代码如下

<servlet>
      <servlet-name>chapter</servlet-name>
      <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
      <load-on-startup>1</load-on-startup>
      <init-param>
         <param-name>contextConfigLocation</param-name>
         <param-value>/WEB-INF/config/spring/chapter-servlet.xml</param-value>
      </init-param>
  </servlet>
  <servlet-mapping>
      <servlet-name>chapter</servlet-name>
      <url-pattern>/</url-pattern>
  </servlet-mapping>


其中的

<init-param>
         <param-name>contextConfigLocation</param-name>
         <param-value>/WEB-INF/config/spring/chapter-servlet.xml</param-value>
      </init-param>
负责初始化配置文件, 默认为/WEB-INF/$servlet-name$-servlet.xml

没想到打上去之后出现

 Invalid content was found starting with element 'init-param'. One of 
 '{"http://java.sun.com/xml/ns/javaee":enabled, "http://java.sun.com/xml/ns/javaee":async-
 supported, "http://java.sun.com/xml/ns/javaee":run-as, "http://java.sun.com/xml/ns/
 javaee":security-role-ref, "http://java.sun.com/xml/ns/javaee":multipart-config}' is expected.

错误,错误原因为
根元素<web-app>中的模式文件不对,
javaee只支持单个的config,要换成 j2ee


即将模式文件

"http://java.sun.com/xml/ns/javaee" 
改成

"http://java.sun.com/xml/ns/j2ee"

亲测不报错



package com.depower.inter.database; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.IOException; import java.io.Reader; import java.util.HashMap; import java.util.InvalidPropertiesFormatException; import java.util.List; import java.util.Properties; import org.apache.ibatis.exceptions.PersistenceException; import org.apache.ibatis.io.Resources; import org.apache.ibatis.session.SqlSession; import org.apache.ibatis.session.SqlSessionFactory; import org.apache.ibatis.session.SqlSessionFactoryBuilder; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import com.depower.inter.bean.DatasourceBean; import com.depower.inter.tools.CypterFile; import com.depower.inter.tools.Utility; public class ConnectionFactory { private static Logger log = LogManager.getLogger(ConnectionFactory.class.getName()); private static SqlSessionFactory sessionFactory[]; private static HashMap<String, SqlSessionFactory> hm = new HashMap<String, SqlSessionFactory>(); /** * 建立数据池 * * @param datasource */ public static void build(List<DatasourceBean> datasource) { if (datasource == null || datasource.size() == 0) { String errReason = "DB connection init error:not configured connection, program will exit"; log.fatal(errReason); System.exit(-1); } int count = datasource.size(); ConnectionFactory.sessionFactory = new SqlSessionFactory[count]; String tmpstr = "SYSINFO Create connection:%s - Object hashCode:%s"; Properties prop = new Properties(); for (int i = 0; i < count; i++) { try { prop = getProperties(datasource.get(i).getProperties()); log.info("SYSINFO Load DB config:" + new File(datasource.get(i).getDatabaseConfig()).getAbsolutePath()); Reader reader = Resources.getResourceAsReader(datasource.get(i).getDatabaseConfig()); SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder(); ConnectionFactory.sessionFactory[i] = builder.build(reader, prop); hm.put(datasource.get(i).getAlias(), ConnectionFactory.sessionFactory[i]); ConnectionFactory.log .info(String.format(tmpstr, datasource.get(i).getAlias(), ConnectionFactory.sessionFactory[i].hashCode())); } catch (IOException e) { String errReason = "creat DB connection error:" + e.getLocalizedMessage() + ", program will exit"; log.fatal(errReason, e); System.exit(-1); } } testConnection(); } /** * @Description:创建数据库连接后,测试连接是否可用,如不可用,循环等待,以防止服务器重启时该系统早于数据库启动 */ private static void testConnection() { SqlSession session = null; while (true) { try { for (String key : hm.keySet()) { session = getSession(key); session.selectOne("testConnection"); if (session != null) { session.close(); } } } catch (PersistenceException e) { log.error("SYSINFO test DB connection fail, try again...", e); Utility.delay(15); continue; } break; } log.info("SYSINFO test DB connection successful"); } /** * 取得指定的数据池 * * @param alias * @return * @throws PooledNotFoundException */ public static SqlSession getSession(String alias) { if (hm.get(alias) != null) { return hm.get(alias).openSession(); } else { String errReason = "DB Source: " + alias + " not found,system will exit..."; log.error(errReason); return null; } } /* * 数据池配置参数文件 * * @param filename * * @return * * @throws InvalidPropertiesFormatException * * @throws FileNotFoundException * * @throws IOException */ private static Properties getProperties(String filename) throws InvalidPropertiesFormatException, FileNotFoundException, IOException { Properties prop = new Properties(); log.info("SYSINFO Load DB config:" + new File(filename).getAbsolutePath()); prop.loadFromXML(new FileInputStream(new File(filename))); // 表示内容有加密 if (prop.get("encrypt").equals("1")) { CypterFile cf = new CypterFile(); try { prop = cf.decryptFile(new File(filename)); } catch (Exception e) { String errReason = String.format("Parse DB config <%s> error:%s, program will exit", filename, e.getLocalizedMessage()); log.fatal(errReason, e); System.exit(-1); } } return prop; } } 分析该代码,原本只有mysql连接,现在整合tdengine rs连接的时候,执行prop = getProperties(datasource.get(i).getProperties());报错
最新发布
09-30
在 Android 构建过程中,出现类似 `cvc-complex-type.2.4.a: Invalid content was found starting with element 'base-extension'. One of '{layoutlib}' is expected` 的错误,通常表明构建配置文件(如 `build.gradle` 或某些 XML 配置文件)中存在格式或结构上的问题。此类错误多由 Gradle 插件版本与项目配置不兼容引起,尤其是在升级 Android Gradle 插件(AGP)后未同步调整相关配置项时更为常见[^5]。 一种典型情况是,在使用新版 Gradle 插件时,其对应的 DSL(领域特定语言)结构发生了变更,导致原本合法的配置结构不再被接受。例如,某些插件可能引入了新的命名空间要求或元素顺序限制,若原有 XML 文件中包含非法顺序或未知标签,则会触发类似 `Invalid content was found starting with element` 的验证错误[^1]。 为了解决这一问题,建议采取以下措施: - **确保 Gradle 与 AGP 版本匹配**:Gradle 和 Android Gradle 插件之间存在版本对应关系,应根据官方文档选择兼容的版本组合。例如,若项目原使用较旧版本插件(如 3.x),而手动升级至 7.x 或更高版本,需同步修改 `build.gradle` 中的相关语法和结构以适配新版本规范[^5]。 - **更新 build.gradle 配置结构**:对于使用 `base-extension` 等新引入 DSL 元素的情况,应检查模块级 `build.gradle` 文件是否符合当前 AGP 版本的要求。例如,部分新版本插件要求将自定义扩展属性置于特定命名空间下,否则会被解析器视为非法内容[^2]。 - **清理并重新同步项目**:在修改版本号或配置文件后,执行 `./gradlew clean` 和 `Sync Project with Gradle Files` 可有效清除缓存残留,避免因历史配置冲突引发解析错误- **启用 --stacktrace 或 --info 模式辅助排查**:通过添加 `--stacktrace` 参数运行 Gradle 构建命令,可以获取更详细的错误堆栈信息,有助于定位具体出错的配置文件位置及上下文[^5]。 ### 示例配置修正 ```groovy // 旧版配置(适用于 AGP 3.x) android { compileSdkVersion 28 defaultConfig { applicationId "com.example.app" minSdkVersion 21 targetSdkVersion 28 versionCode 1 versionName "1.0" } } ``` ```groovy // 新版配置(适用于 AGP 7.x) plugins { id 'com.android.application' version '7.4.0' apply false } android { namespace 'com.example.app' compileSdk 34 defaultConfig { applicationId "com.example.app" minSdk 24 targetSdk 34 versionCode 1 versionName "1.0" } } ``` 上述示例展示了从 AGP 3.x 升级到 7.x 后所需的主要配置变化,包括新增的 `namespace` 属性和简化后的 `compileSdk` 写法。
评论 2
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值