【java-bug】Exception occurred during processing request:

本文介绍Struts2框架中模型驱动的正确实现方法,包括实现ModelDriven接口、提供get和set方法及getModel方法等步骤,并给出了具体的代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

出现这个错误我的是由于在使用struts2框架 时候使用模型驱动封装页面传来的参数时,没有给对象生成get set方法,给忘记了,还要实现getModel方法,返回对象,并且struts.xml中配置的action方法一定要存在于Action中

模型驱动封装参数正确的Action如下:

package cn.itheima.param;  
  
import java.util.Date;  
import java.util.Map;  
  
import com.opensymphony.xwork2.ActionContext;  
import com.opensymphony.xwork2.ActionSupport;  
//struts2如何获得参数  
//属性驱动获得参数  
import com.opensymphony.xwork2.ModelDriven;  
  
import cn.itheima.domain.User;  
//3.模型驱动  
//缺陷:只能返回一个对象  
//1->实现接口  
public class DemoAction1 extends ActionSupport implements ModelDriven<User>{  
    /* 
     * 页面设置<input type='text' name='name'/> 页面跟以前一样 
     * */  
    private User user=new User();//3->准备一个user对象 需要创建出对象来  
    public User getUser() {  
        return user;  
    }  
    public void setUser(User user) {  
        this.user = user;  
    }  
    public String execute() throws Exception {  
          
        return SUCCESS;  
    }  
      
    //2->实现方法返回对象  
    @Override  
    public User getModel() {  
        // TODO Auto-generated method stub  
        return user;  
    }  
      
}  

配置struts.xml (注意包名和方法名)

<package name="crm" namespace="/" extends="struts-default">
		<action name="CustomerAction_*" class="cn.itheima.web.action.CustomerAction" method="{1}">
			<result name="list" type="dispatcher">/jsp/customer/list.jsp</result>
			<result name="toList" type="redirectAction">
				<param name="actionName">CustomerAction_list</param>
				<param name="namespace">/</param>
			</result>
		</action>
		
		<action name="UserAction_*" class="cn.itheima.web.action.UserAction" method="{1}">
			<result name="toHome" type="redirect">/index.htm</result>
		</action>
	</package>

<think>我们正在解决用户的问题:Java中因db.properties配置导致的NullPointerException异常。根据引用[1]和[2],NullPointerException可能由db.properties配置错误引起,导致数据源配置失败,进而引起MyBatis或Servlet的NullPointerException。解决思路:1.检查db.properties文件是否存在,位置是否正确。2.检查db.properties中的键名是否与代码中读取的键名一致。3.检查数据库连接参数(URL、用户名、密码)是否正确,特别是URL的格式和参数。4.确保数据库驱动类名正确,且驱动JAR已添加到项目。5.检查MyBatis配置文件(如mybatis-config.xml)中是否正确引用了db.properties。下面给出详细步骤和代码示例。</think> 针对 `db.properties` 配置导致的 `NullPointerException`,结合引用中的关键报错信息 `openSessionFromDataSource` [^1] 和 `Request processing failed` [^2],以下是排查和解决方案: --- ### 🔍 问题根本原因(核心) `NullPointerException` **通常出现在两种场景**: 1. **配置文件未加载**:`db.properties` 路径错误或资源缺失 2. **配置项读取失败**:代码中读取的键名与配置文件的键名不一致 --- ### ✅ 解决方案(分步排查) #### 1️⃣ **检查配置文件位置和名称** ```bash 项目结构示例: src/ ├── main/ │ ├── resources/ │ │ ├── db.properties # ✅ 必须在此位置(标准Maven项目) │ │ ├── mybatis-config.xml ``` - **错误示例**:配置文件放在 `src/main/java` 下会导致无法加载[^2] #### 2️⃣ **检查 db.properties 内容完整性** ```properties # 必须包含以下关键项(键名必须完全匹配): driver=com.mysql.cj.jdbc.Driver url=jdbc:mysql://localhost:3306/your_db?useSSL=false&serverTimezone=UTC username=root password=123456 # ❌ 若此项缺失会导致数据源初始化失败[^1] ``` #### 3️⃣ **验证 MyBatis 配置引用(mybatis-config.xml)** ```xml <configuration> <properties resource="db.properties"/> <!-- resource路径必须正确 --> <environments default="development"> <environment id="development"> <transactionManager type="JDBC"/> <dataSource type="POOLED"> <property name="driver" value="${driver}"/> <!-- 键名必须一致 --> <property name="url" value="${url}"/> <property name="username" value="${username}"/> <property name="password" value="${password}"/> <!-- 缺少会导致NullPointer --> </dataSource> </environment> </environments> </configuration> ``` #### 4️⃣ **代码加载方式验证(Java示例)** ```java // 正确加载方式(Spring Boot) @Configuration public class DataSourceConfig { @Bean public DataSource dataSource( @Value("${driver}") String driver, // 键名必须对应 @Value("${url}") String url, @Value("${username}") String username, @Value("${password}") String password // ❌ 若password键名错误会抛NPE ) { // 初始化数据源 } } ``` #### 5️⃣ **服务器配置检查** 若使用WebLogic等服务器(如引用[^3]场景): ```bash # 检查驱动是否部署(关键) ./bsu.sh -view -status=applied -prod_dir=/path/to/wlserver ``` - 确认 `mysql-connector-java.jar` 已放入 `WEB-INF/lib` --- ### ⚠️ 高频错误点 | 错误场景 | 报错表现 | 解决方案 | |--------------------------|------------------------------------------|------------------------------| | 密码键名拼写错误 | `DefaultSqlSessionFactory.openSessionFromDataSource` 报空指针[^1] | 检查`password` vs `pwd` | | 时区参数缺失 | 连接超时后抛NPE | URL添加 `&serverTimezone=UTC` | | MyBatis未引入properties | `NullPointerException` 在数据源初始化阶段 | 添加 `<properties resource="db.properties"/>` | --- ### 📌 验证流程(快速测试) 1. 在单元测试中强制读取配置: ```java @Test public void testDbConfig() { String password = System.getProperty("password"); // 故意触发NPE // 改用此方式: String password = new PropertiesLoader("db.properties").getProperty("password"); } ``` 2. 若抛出 `java.io.FileNotFoundException` → 确认文件路径错误 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

阿来小同学

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值