一、訪問不了static下的靜態(tài)資源
這是因?yàn)閟truts2在web.xml中配置核心攔截器的時候把所有請求都攔截了,這也就包括靜態(tài)資源咬荷。
static/css/index.css
幸乒。
<constant name="struts.action.excludePattern" value="/static/.*?" />
二、struts2.5最新jar包版本配置搭建
struts2常用jar包就這幾個唇牧,直接官網(wǎng)找最新的下載罕扎。
web.xml文件
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0">
<display-name>SSHDemo02</display-name>
<filter>
<filter-name>struts2</filter-name>
<filter-class>org.apache.struts2.dispatcher.filter.StrutsPrepareAndExecuteFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
struts.xml文件
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.5//EN"
"http://struts.apache.org/dtds/struts-2.5.dtd">
<struts>
<!--開啟action動態(tài)訪問 -->
<constant name="struts.enable.DynamicMethodInvocation" value="true" />
<!-- 不攔截對static文件夾下的請求 -->
<constant name="struts.action.excludePattern" value="/static/.*?" />
<package name="default" extends="struts-default" namespace="/" strict-method-invocation="false">
<!-- 定義各個action配置 -->
......
</package>
</struts>
三、切記丐重,hql語句針對的實(shí)體類對象腔召,而不是表結(jié)構(gòu)
四、使用hibernate在插入數(shù)據(jù)時報(bào)錯:attempt to create saveOrUpdate event with null entity
此時要檢查你的實(shí)體類對象是否注入了扮惦,即是否為空對象臀蛛,如果是空對象自然就無法插入了。可在調(diào)用session.save(users)插入數(shù)據(jù)之前打印下users對象浊仆,看是否為空客峭。我遇到的是修改了User實(shí)體類的名字,然后沒有生成重新getter和setter方法導(dǎo)致屬性沒注入進(jìn)去users成為空對象抡柿。
五舔琅、引入struts2的日歷控件datetimepicker,出現(xiàn)九月開始之后的月份就亂碼
解決的辦法沙绝,是打開dojo-plugin.jar
包里dojo-zh.js
和dojo-zh-cn.js
文件搏明,修改之后再保存為UTF-8格式的文件:https://blog.csdn.net/cswhale/article/details/7907107
六鼠锈、hibernate進(jìn)行分頁查詢時報(bào)錯:ERROR: 只進(jìn)結(jié)果集不支持請求的操作闪檬。
出現(xiàn)這種問題是由于在hibernate-cfg.xml配置文件中沒有配置結(jié)果集是否可以滾動,加上如下這句即可
<!-- 配置結(jié)果集是否可滾動购笆,分頁一定要加上這配置 -->
<property name="jdbc.use_scrollable_resultset">false</property>
如果是用spring整合hibernate的話粗悯,就在spring-cfg.xml配置文件中這樣配置
<prop key="hibernate.jdbc.use_scrollable_resultset">false</prop>
七、報(bào)錯:java.lang.IllegalArgumentException: attempt to create saveOrUpdate event with null entity
出現(xiàn)這種情況的往往是表單提交數(shù)據(jù)的name屬性和提交到的action里的實(shí)體類對象名稱不一致同欠。造成action里實(shí)體類對象為空样傍,所以事務(wù)操作失敗。解決方法就是表單的name屬性值里的實(shí)體類對象數(shù)據(jù)要和action里的實(shí)體類對象名稱一致铺遂,如下2圖對應(yīng)起來衫哥。八、struts攔截器只能攔截action襟锐,卻不能攔截jsp頁面撤逢,所以不能阻止未登錄用戶非法訪問jsp頁面
但是有這方面的需求的話,我們可以通過過濾器來實(shí)現(xiàn)粮坞。如下:
自定義過濾器LoginFilter.java
package com.ssh.common;
import java.io.IOException;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
//struts2的攔截器只能攔截action而不能攔截jsp頁面蚊荣,所以使用過濾器進(jìn)行過濾攔截
public class LoginFilter implements Filter {
private static final long serialVersionUID = 1L;
@Override
public void destroy() {
// TODO Auto-generated method stub
}
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
throws IOException, ServletException {
//轉(zhuǎn)化為HttpServlet的請求響應(yīng)對象
HttpServletRequest req = (HttpServletRequest)request;
HttpServletResponse res = (HttpServletResponse)response;
//獲取訪問路徑地址
String uri = req.getRequestURI();
//System.out.println(uri);
//String的endsWith()用來測試字符串是否以指定的后綴結(jié)尾
if(uri.endsWith("main.jsp")){
chain.doFilter(req,res);
return; //這里的return一定要加上,否則會不斷死循環(huán)請求重定向
}
//獲取session存的值
String userName = (String)req.getSession().getAttribute("userName");
if(userName==null){
System.out.println("未登錄用戶被攔截在登錄注冊頁面");
res.sendRedirect("main.jsp");
}
//放行
chain.doFilter(req,res);
}
@Override
public void init(FilterConfig filterConfig) throws ServletException {
// TODO Auto-generated method stub
System.out.println("跟隨tomcat啟動而自動運(yùn)行");
}
}
配置文件web.xml
配置一下
<!-- 攔截未登錄用戶非法訪問jsp頁面 -->
<filter>
<filter-name>LoginFilter</filter-name>
<filter-class>com.ssh.common.LoginFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>LoginFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
經(jīng)過以上兩步就可以實(shí)現(xiàn)未登錄用戶非法訪問jsp啦~
還有另一種阻止非法訪問jsp頁面的方式莫杈,就是把禁止直接被訪問的jsp頁面放在
WEB-INF
目錄下互例,此目錄下的資源是受保護(hù)的,這樣別人也不能直接通過url地址來訪問此目錄下jsp頁面筝闹,不過我在做不同jsp頁面跳轉(zhuǎn)到此目錄下的jsp頁面也由此而被阻止媳叨,試了網(wǎng)上的解決方案暫時還沒解決我的問題。
九关顷、報(bào)錯信息:java.lang.IllegalArgumentException: attempt to create create event with null entity
出現(xiàn)這錯誤就是指創(chuàng)建空值糊秆,即某個地方的傳參出現(xiàn)錯誤。定位代碼處如下:我數(shù)據(jù)庫表主鍵是varchar類型解寝,在程序中傳過來的id也應(yīng)該是String類型扩然,(錯誤是因?yàn)槲覀鬟^來的id聲明成int類型),還有注意:session.get(xxx.class,id)這個方法來獲取對象數(shù)據(jù)是只使用主鍵屬性的聋伦,其余屬性不行夫偶。