问题场景: 在使用表单向Action传递数据的时候, 遇到了这个问题, 导致了空指针异常.

问题描述:

10:14:56.622 [http-nio-8080-exec-45] ERROR com.opensymphony.xwork2.interceptor.ParametersInterceptor - Developer Notification (set struts.devMode to false to disable this message):
Unexpected Exception caught setting 'password' on 'class com.bj186.crm.web.action.UserAction: Error setting expression 'password' with value ['123456', ]
10:14:56.648 [http-nio-8080-exec-45] ERROR com.opensymphony.xwork2.interceptor.ParametersInterceptor - Developer Notification (set struts.devMode to false to disable this message):
Unexpected Exception caught setting 'submit' on 'class com.bj186.crm.web.action.UserAction: Error setting expression 'submit' with value ['', ]
10:14:56.649 [http-nio-8080-exec-45] ERROR com.opensymphony.xwork2.interceptor.ParametersInterceptor - Developer Notification (set struts.devMode to false to disable this message):
Unexpected Exception caught setting 'username' on 'class com.bj186.crm.web.action.UserAction: Error setting expression 'username' with value ['艾格尼丝', ]
java.lang.NullPointerException
at com.bj186.crm.web.action.UserAction.login(UserAction.java:70)
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 ognl.OgnlRuntime.invokeMethod(OgnlRuntime.java:902)
at ognl.OgnlRuntime.callAppropriateMethod(OgnlRuntime.java:1547)
at ognl.ObjectMethodAccessor.callMethod(ObjectMethodAccessor.java:68)

问题分析: 这个问题非常隐蔽, 是Struts2在接受值的时候, 不能正确的接收. 问题的根本原因在于没有创建接收数据的对象

解决思路: 在Action中把需要接收数据的类的对象new出来

private User user = new User();

并且设置它的getter和setter方法

然后这个问题就解决了!!!

附Struts2的UserAction.java的代码

package com.bj186.crm.web.action;

import com.bj186.crm.entity.User;
import com.bj186.crm.service.UserService;
import com.opensymphony.xwork2.Action;
import com.opensymphony.xwork2.ActionContext;
import com.opensymphony.xwork2.ActionSupport;
import com.opensymphony.xwork2.ModelDriven;
import com.opensymphony.xwork2.util.ValueStack;
import org.apache.struts2.ServletActionContext;
import org.springframework.web.context.WebApplicationContext;
import org.springframework.web.context.support.WebApplicationContextUtils; import javax.servlet.ServletContext;
import java.util.Arrays;
import java.util.List; public class UserAction extends ActionSupport implements ModelDriven<User> {
private User user = new User();
private UserService userService;
private ValueStack valueStack; //测试添加上User的get和set方法
public void setUser(User user) {
//ServletActionContext.getRequest().getParameter("username")
this.user = user;
} public User getUser() {
return user;
} public void setUserService(UserService userService) {
this.userService = userService;
} public UserAction() {
//1.获取ServletContext
ServletContext servletContext = ServletActionContext.getServletContext();
//2.通过整合包中的工具类, 从servletContext的作用域上获取目标--Spring的容器WebApplicationContext
WebApplicationContext webApplicationContext = WebApplicationContextUtils.getWebApplicationContext(servletContext);
//3.从Spring的容器中获取对象
userService = webApplicationContext.getBean("userService", UserService.class);
System.out.println("userService:"+userService);
//4.获取值栈
ActionContext context = ActionContext.getContext();
valueStack = context.getValueStack();
} public String execute() {
System.out.println("正在UserAction的execute()方法中!");
return Action.SUCCESS;
} /**
* 添加用户
* @return 字符串状态
*/
public String register() {
User user = (User) valueStack.findValue("user");
userService.register(user);
return Action.SUCCESS;
} /**
* 用户登录
* @return
*/
public String login() {
String username = user.getUsername();
String password = user.getPassword();
boolean isLogin = userService.verifyLogin(username,password);
return isLogin? Action.SUCCESS: Action.NONE;
} /**
* 删除用户
* @return 字符串状态
*/
public String deleteUser(Integer uid) {
userService.deleteUser(uid);
return Action.SUCCESS;
} /**
* 修改用户
* @return 字符串状态
*/
public String updateUser() {
User user = (User)valueStack.findValue("user");
userService.updateUser(user);
return Action.SUCCESS;
} /**
* 查询用户
* @return 字符串状态
*/
public String getUserById(Integer uid) {
User user = userService.selectUserById(uid);
System.out.println("查询出来的用户是: " + user);
return Action.SUCCESS;
} /**
* 显示用户页面
* @return
*/
public String showAllUsers() {
System.out.println("显示所有的用户");
return Action.SUCCESS;
} /**
* 查询出所有的用户
* @return
*/
public String selectAllUsers() {
List<User> userList = userService.selectAllUsers();
valueStack.set("userList",userList);
System.out.println("查到的用户个数为: " + userList.size());
return Action.SUCCESS;
} @Override
public User getModel() {
return user;
}
}

前端页面的index.jsp代码

<%-- Created by IntelliJ IDEA. --%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>用户管理系统首页</title>
</head>
<body>
<h2 style="color:red;">欢迎光临!</h2>
<form action="<%=request.getContextPath()%>/user_login.action" method="post">
<input name="username" type="text"><br/>
<input name="password" type="password"><br/>
<button name="submit" type="submit">登录</button>
</form>
</body>
</html>

Unexpected Exception caught setting 'username' on 'class com.bj186.crm.web.action.UserAction: Error setting expression 'username' with value ['艾格尼丝', ]的更多相关文章

  1. hibernate 异常:Unexpected Exception caught setting

    异常信息:Unexpected Exception caught setting 'outHeight' on 'class com.srpm.core.project.seismicFortific ...

  2. 五)使用 easyui-tabs 遭遇错误 Unexpected Exception caught setting '_' on

    十月 10, 2015 3:08:35 下午 com.opensymphony.xwork2.interceptor.ParametersInterceptor error 严重: Developer ...

  3. Unexpected exception 'Cannot run program ... error=2, No such file or directory' ... adb'

    Eclipse ADT Unexpected exception 'Cannot run program' up vote 8 down vote favorite 4 I have installe ...

  4. myEclipse Could not create the view: An unexpected exception was thrown.

    myEclipse 非正常关闭,打开后 service Explorer or Package Explorer 视图显示不出来.报“Could not create the view: An une ...

  5. (转)Could not create the view: An unexpected exception was thrown. 电脑突然断电,myeclipse非正常关闭,出现错误

    问题:电脑突然断电,myeclipse非正常关闭,“Package Explorer”非正常显示,出现错误“Could not create the view: An unexpected excep ...

  6. Could not create the view: An unexpected exception was thrown 异常处理

    MyEclipse 打开后有时候莫名的在server窗口里抛出"Could not create the view: An unexpected exception was thrown&q ...

  7. Could not create the view: An unexpected exception was thrown. 电脑突然断电,myeclipse非正常关闭,出现错误

    电脑突然断电,myeclipse非正常关闭,“Package Explorer”非正常显示,出现错误“Could not create the view: An unexpected exceptio ...

  8. Could not create the view: An unexpected exception was thrown.问题解决

    Could not create the view: An unexpected exception was thrown.问题解决 今天打开Myeclipse10的时候,发现server窗口出现一堆 ...

  9. An unexpected exception occurred while creating a change object. see the error log for more details

    今天再给Android项目工程中的包重命名时出现了这个错误(之前重命名的时候就没有出现,郁闷): An unexpected exception occurred while creating a c ...

随机推荐

  1. 008--linux 基础之网络配置和ssh服务

    一.linux网络配置 ifconfig eno16777736 192.168.19.48/24   |   eno16777736(网卡名)   192.168.19.48/24(临时IP地址) ...

  2. bzoj 1082: [SCOI2005]栅栏【二分+dfs】

    二分答案,dfs判断是否可行,当b[k]==b[k-1]时可以剪枝也就是后移枚举位置 #include<iostream> #include<cstdio> #include& ...

  3. easyUI Uncaught TypeError: Cannot read property 'length' of undefined

    dataGrid json 封装数据格式为 List<Object> 格式

  4. 用jQuery获取到一个类名获取到的是一个数组 ,如果对数组中的每个进行相应的操作可以这样进行

    $(".userImg").each(function(){ $(this).click(function(){ var imgid = $(this).attr("id ...

  5. 简单实现人工智能:百度aip+tuling123

    目录结构: app.py # -*- coding: utf-8 -*- # __author: ward # data: 2018/12/21 # @File: app from flask imp ...

  6. ssh配置详解及公私钥批量分发

    第一:ssh配置文件详解 第二:ssh公私密钥的生成 第三:ssh公钥分发之一:ssh自带工具ssh-copy-id工具分发 第四:ssh公钥分发之二:编写sshpass脚本批量分发 第五:ssh公钥 ...

  7. Math Show CodeForces - 846B

    题目 题意: 有n个任务,每个任务有k个子任务,有m的时间来完成任务.每个任务的第i个子任务需要时间都是ti.完成一个子任务获得一分,完成一个大任务的所有子任务额外得一分.问如何在时间不超过m的情况下 ...

  8. 【solr filter 介绍--转】http://blog.csdn.net/jiangchao858/article/details/54989025

    Solr的Analyzer分析器.Tokenizer分词器.Filter过滤器的区别/联系 Analyzer负责把文本字段转成token stream,然后自己处理.或调用Tokenzier和Filt ...

  9. [转]C#综合揭秘——细说多线程(下)

    引言 本文主要从线程的基础用法,CLR线程池当中工作者线程与I/O线程的开发,并行操作PLINQ等多个方面介绍多线程的开发. 其中委托的BeginInvoke方法以及回调函数最为常用. 而 I/O线程 ...

  10. logging日志过滤和日志文件自动截取

    1.日志过滤 import logging class IgnoreFilter(logging.Filter): def filter(self,record): return "girl ...