java 把数据放入session时为啥会 报null异常?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java 把数据放入session时为啥会 报null异常?相关的知识,希望对你有一定的参考价值。

为什么会报空指针异常?HttpSession session=ServletActionContext.getRequest().getSession();
ServletActionContext.getRequest().getSession().setAttribute("dvUser", dvUsers);
java.lang.NullPointerException
at org.apache.struts2.ServletActionContext.getRequest(ServletActionContext.java:112)
at cn.rf.hz.socket.controller.HandleLogi.processingLogic(HandleLogi.java:90)
at cn.rf.hz.socket.listener.PooledConnectionHandler.handleConnection(PooledConnectionHandler.java:97)
at cn.rf.hz.socket.listener.PooledConnectionHandler.run(PooledConnectionHandler.java:192)
at java.lang.Thread.run(Thread.java:662)

参考技术A 放的位置不对,ServletActionContext.getRequest()不能放在类下面,只能放具体的处理方法内,如登陆方法login之类中。

使用楼上的方法也可以ActionContext.getContext().getSession()追问

怎么解决啊?

追答

你的ServletActionContext.getRequest()放哪儿?或者把你的代码贴出来

把他移动到实际页面对应调用的方法中就可以了

参考技术B 你获取的session的方式不对 在action中有可以用
Map<String,Object> session = ActionContext.getContext().getSession(); 获取session
在action中session是Map<String,Object> 类型的追问

在action中获取是对的,我现在的问题不是在action中存取session的问题,而是在别的地方存放另一个session时报错,

追答

把异常贴出来看看

参考技术C 你先确定有没有收到值!

使用jdbc连接mysql为啥报错?

当我用JDBC连接MySql数据库时,编译报了如下错误:
错误1:
Loading class `com.mysql.jdbc.Driver'. This is deprecated. The new driver class is `com.mysql.cj.jdbc.Driver'. The driver is automatically registered via the SPI and manual loading of the driver class is generally unnecessary.
这要求我们注册驱动时,把Class.forName("com.mysql.jdbc.Driver");改成 Class.forName("com.mysql.cj.jdbc.Driver");

当我信息满满的修改之后重新编译时,再次出现了错误:
错误2:
Fri Feb 22 08:55:38 CST 2019 WARN: Establishing SSL connection without server's identity verification is not recommended. According to MySQL 5.5.45+, 5.6.26+ and 5.7.6+ requirements SSL connection must be established by default if explicit option isn't set. For compliance with existing applications not using SSL the verifyServerCertificate property is set to 'false'. You need either to explicitly disable SSL by setting useSSL=false, or set useSSL=true and provide truststore for server certificate verification.
这要求我们在设置url参数时,将useSSL=false,修改后 jdbc:mysql://localhost:3306/ds3?useSSL=false

当我修改后,本以为这下应该没问题了,没想到,再一次出现了问题
错误3:
Exception in thread "main" java.sql.SQLException: The server time zone value 'Öйú±ê׼ʱ¼ä' is unrecognized or represents more than one time zone. You must configure either the server or JDBC driver (via the serverTimezone configuration property) to use a more specifc time zone value if you want to utilize time zone support.
这要求我们修改时区,修改成jdbc:mysql://localhost:3306/ds3?useSSL=false&serverTimezone=UTC

终于,不在报错误了。
错误4:当我们配置xml文件时,要把&转为其本身的转义字符
配置properties文件的urlurl=jdbc:mysql:///ds3?useSSL=false&serverTimezone=UTC配置xml文件的url<property name="url">jdbc:mysql://localhost:3306/ds3?useSSL=false&serverTimezone=UTC</property>
参考技术A

你为什么不指定连接的数据库地址和端口,这样怎么连

以上是关于java 把数据放入session时为啥会 报null异常?的主要内容,如果未能解决你的问题,请参考以下文章

HashMap为啥会死锁

为啥我使用<c:forEach>显示数据时,页面第一次数据不出来,刷新一次数据才会出来

asp.net 中切换页面时 为啥session会丢失

为啥在 Go 中将指针放入 interface 会导致反射丢失类型的名称?

为啥浏览器会共享session啊!

为啥浏览器会共享session啊!