1.<a id="logonout" href="main!logout.action" οnclick="return confirm('确认注销吗?')"><img src="images/head-m.gif" border="0" /> </a>
在a标签中同时存在href和onclick属性可以这么解决。
2.@Autowired 与 @Resource的区别
* @Autowired与@Resource都可以用来装配bean. 都可以写在字段上,或写在setter方法上。
* @Autowired默认按类型装配(这个注解是属于spring的),默认情况下必须要求依赖对象必须存在,如果要允许null值,可以设置它的required属性为false,如: @Autowired(required=false) ,如果我们想使用名称装配可以结合@Qualifier注解进行使用,如下:
Java代码
@Autowired() @Qualifier("baseDao")
private BaseDao baseDao;
* @Resource(这个注解属于J2EE的),默认安照名称进行装配,名称可以通过name属性进行指定,如果没有指定name属性,当注解写在字段上时,默认取字段名进行按照名称查找,如果注解写在setter方法上默认取属性名进行装配。当找不到与名称匹配的bean时才按照类型进行装配。但是需要注意的是,如果name属性一旦指定,就只会按照名称进行装配。
Java代码:按指定名称注入
@Resource(name="baseDao")
private BaseDao baseDao;
例如在BaseService里抽取了很多共性的方法
public class BaseService<T, E extends IBaseDao<T>> implements IBaseService<T> {
protected Class<T> clz = GenericUtil.getSuperClassGenericType(getClass());
protected E genericDao;
public void add(T entity) {
genericDao.addEntity(entity);
}
public void delete(Serializable id) {
genericDao.deleteEntity(id);
}
public T get(Serializable id) {
return genericDao.getEntity(id);
}
public void update(T entity) {
genericDao.updateEntity(entity);
}
@Autowired //如果这里用@Resource的话会出异常,异常提示有多个dao不知道用哪一个。原因:@Resource写在方法上时没有写出name属性时,是按set后的首字母小写的名称去查找的(genericDao)genericDao因为是向上抽取定义的,它代表所有的Dao,所以异常提示有多个dao不知道用哪一个
若找不到才按类型(但是这里其实按名称是找到了的,而且不止一个)。而@Autowired直接按类型查找
public void setGenericDao(E genericDao) {
this.genericDao = genericDao;
}
public List getByAll() {
String hql = "from "+clz.getSimpleName()+" obj";
return genericDao.getByHQL(hql, null, null, null);
}
}
3.HQL语句也是面向对象的
"from Product obj where obj.supplier.id=?"
这样表示Product类下的Supplier类下的id属性(supplier是Product类中代表Supplier类的属性名)
4.在Action里获取HttpServletSeesion的方法
ServletActionContext.getRequest().getSession().getAttribute("userName");