- 浏览: 406688 次
- 性别:
- 来自: 天津
文章分类
最新评论
-
junchao_qin:
[img][flash=200,200][url][img]引 ...
MyEclipse中使用VSS插件 -
tigerwood008:
IE11不好用!!
js弹出窗口 + 获取上传文件全路径 -
TheMatrix:
$.ajaxSetup({async : false});这种 ...
jquery 中的post和get方法如何同步 -
多多成长记:
Blazeds与java通信 -
ZED.CWT:
[align=ceiinter][/align]
java中利用JFrame创建窗体 【转】
用到的js插件:
验证表单:formvalidator4.1.1(http://www.cnblogs.com/wzmaodong/archive/2008/01/11/1034901.html,http://www.yhuan.com/forum.php)
可视化编辑器:ckeditor_3.6.2(http://ckeditor.com/)
文件管理器:CKfinder(http://ckfinder.com/)
表格排序、分页、查询:DataTables-1.7.5(http://www.datatables.net/)
已解决问题:
1.
java.lang.reflect.InvocationTargetException java.lang.NoSuchMethodError: antlr.collections.AST.getLine()I
解决方法:
antrl-2.7.6.jar和antrl-2.7.2.jar冲突,删除antrl-2.7.2.jar
antrl-2.7.2.jar版本太低,换成更新点的jar包,比如:antlr-2.7.6.jar,问题即可解决。
2.
当页面由几个frame组成时,session的获取问题
如a.jsp通过bAction跳转到c.jsp,其中c.jsp由top.jsp, right.jsp, left.jsp组成,在bAction里设置session值
HttpServletRequest request = ServletActionContext.getRequest(); request.getSession().setAttribute("user",user);
在c.jsp中的top.jsp里获取
错误方法:当不是frame组成的页面时,可行
<% User user = (User) request.getSession().getAttribute("user"); %> <%=user.getUsername()%>
解决方法:
<% User user = (User) session.getAttribute("user"); %> <%=user.getUsername()%>
究其原因是作用域问题,request<session
3.
用MyEclipse写jsp时出现some characters acnnot be mapped using "ISO-8859-1"错误
解决方法:jsp页首添加
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
4.
struts2中超链接提交表单,其中seachForm为form 的name
<a href="#
"onclick="javascript:searchForm.submit();">
注意a href=“#”而不是a href = “”
另外select里注意select里判断语句
<select style="width: 120px" name="graduateOrNot">
<option value="none" <s:if test="graduateOrNot.equals('none')">selected</s:if>>所有校友</option>
<option value="yes" <s:if test="graduateOrNot.equals('yes')">selected</s:if>>已毕业</option>
<option value="no" <s:if test="graduateOrNot.equals('no')">selected</s:if>>在读学生</option>
</select>
5.
js动态修改table内容
<html> <head> <script type="text/javascript"> function test(){ var objRows = document.getElementById("test").rows; alert("length " + objRows.length); var objCells; for(var i = 0; i < objRows.length; i ++){ objCells = objRows[i].cells; objCells[1].innerHTML = "<input type='text' value='" + objCells[1].innerHTML + "'/>" + "test"; //objCells[1].innerHTML = "test" + objCells[1].innerHTML; } } </script> </head> <body> <table id="test" border="1"> <tr> <td>第一列</td><td id="sec">第二列</td> </tr> <tr> <td>2第一列</td><td id="sec">2第二列</td> </tr> </table> <input type="button" value="test" onclick="test()"></input> </body> </html>
6.
js转义字符 “\"
var temp = "<a href=\"test.jsp\">test.jsp</a>";
7.
js动态修改表格为编辑状态后,点击保存,参数无法传入action
可能与页面的预处理有关。
解决方法:<form放的位置不对
8.
表格跨列
<td colspan="2"></td>
跨行
<tr rowspan="3"></tr>
9.
jsp显示日期格式
原显示: 12-2-27 21:16:03.000
<s:property value="postTime"/>
采用:2012-02-27 21:16:03
<s:date name="postTime" format="yyyy-MM-dd HH:mm:ss" />
10.
时间戳问题
在mysql里设计表中messageNewsAlum里的postTime字段类型为timestamp,在mysql里写插入语句,
可自动插入postTime,但问题是日期正确,小时分钟错误
另外,hibernate配置文件里.hbm.xml映射类型虽然为timestamp,但是java类里写插入语句的时候,
不能自动插入postTime,报空指针。
原:
<property name="postTime" type="java.sql.Timestamp"> <column name="postTime" length="19" not-null="true" /> </property>
后改为:http://blog.csdn.net/daryl715/article/details/1931658
<!-- timestamp标签必须跟在id标签后面 -->
<timestamp name="postTime" column="postTime"></timestamp>
这样的话,该字段在插入时自动插入当前系统时间,更新时也会将postTime更新为当前时间
若不想更新的话,解决方法:使其既不能插入也不能更新,只能使用数据库中的默认值CURRENT_TIMESTAMP
<property name="postTime" type="java.sql.Timestamp" insert="false" update="false"> <column name="postTime" length="19" not-null="true" /> </property>
另外,对于mysql数据库的navicat客户端,默认填写CURRENT_TIMESTAMP,不勾选“刷新当前时间戳记时”
sql语句
更新:
`postTime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
不更新:
`postTime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP
11.
数据库表中某个字段设置了默认值,如messageNewsAlum表中parent字段默认设为-1
但是在java类中插入该表内容,却不设置parent值的时候,会报parent不能为空的错误
解决方法:http://hi.baidu.com/laihua2006/blog/item/241a2939dc2f39e3b211c7a2.html
.hbm.xml中添加dynamic-insert="true" dynamic-update="true"
<class name="org.com.entity.MessageNewsAlum" table="messagenewsalum" catalog="alumnus" dynamic-insert="true" dynamic-update="true">
但是问题仍然没解决,则采用如下方法:
解决方法一:
将该字段的 not-null属性设置为false,因为有默认值所以总也不会出现null的情况,所以可以设为false
方法二:http://www.blogjava.net/keweibo/articles/353872.html
添加 insert="false" update="true"即插入语句的时候不对数据库的该字段进行操作,也就保留了默认值
而更新的时候却可以改变改字段的值
<property name="parent" type="java.lang.Integer" insert="false" update="true"> <column name="parent" not-null="true" /> </property>
12.
mysql创建表时,默认使用ENGINE=MyISAM,但是这样不能创建触发器,只有改成ENGINE=InnoDB才可
如何在创建表的时候,默认使用ENGINE=InnoDB呢?
13.
合并两个表的记录,需要有相同字段,采用union为提取不重复值,若允许重复则用union all
select userIdFK, title,postTime from topic union select userIdFK, title,postTime from reply order by postTime
14.
对于从两个或多个表查询出来的List,可以建javaBean,还可以创建视图
mysql中点击创建视图:输入sql:
select m.messageNewsAlumId,m.userIdFK,m.postTime,m.title,m.content,m.state where m.type='message' from messageNewsAlum as m union select r.replyId, r.userIdFK, r.postTime,r.title,r.content,r.state from messageReply as r order by postTime desc
点击保存,注意不要写上create view as,因为mysql已经自动给加上了
然后在eclipse里写hibernate映射文件如TopicReplyView.java,TopicReplyViewId.java,TopicReplyView.hbm.xml
TopicReplyView.java
package org.com.entity; /** * Topicreplyview entity. @author MyEclipse Persistence Tools */ public class TopicReplyView implements java.io.Serializable { // Fields private TopicReplyViewId id; // Constructors /** default constructor */ public TopicReplyView() { } /** full constructor */ public TopicReplyView(TopicReplyViewId id) { this.id = id; } // Property accessors public TopicReplyViewId getId() { return this.id; } public void setId(TopicReplyViewId id) { this.id = id; } }
TopicReplyViewId.java
package org.com.entity; import java.sql.Timestamp; /** * TopicreplyviewId entity. @author MyEclipse Persistence Tools */ public class TopicReplyViewId implements java.io.Serializable { // Fields private Integer messageNewsAlumId; //private Integer userIdFk; private User user; private Timestamp postTime; private String title; private String content; private Integer state; // Constructors /** default constructor */ public TopicReplyViewId() { } /** full constructor */ public TopicReplyViewId(Integer messageNewsAlumId, User user, //Integer userIdFk, Timestamp postTime, String title, String content, Integer state) { this.messageNewsAlumId = messageNewsAlumId; //this.userIdFk = userIdFk; this.user = user; this.postTime = postTime; this.title = title; this.content = content; this.state = state; } // Property accessors public Integer getMessageNewsAlumId() { return this.messageNewsAlumId; } public void setMessageNewsAlumId(Integer messageNewsAlumId) { this.messageNewsAlumId = messageNewsAlumId; } /* public Integer getUserIdFk() { return this.userIdFk; } public void setUserIdFk(Integer userIdFk) { this.userIdFk = userIdFk; } */ public User getUser() { return user; } public void setUser(User user) { this.user = user; } public Timestamp getPostTime() { return this.postTime; } public void setPostTime(Timestamp postTime) { this.postTime = postTime; } public String getTitle() { return this.title; } public void setTitle(String title) { this.title = title; } public String getContent() { return this.content; } public void setContent(String content) { this.content = content; } public Integer getState() { return this.state; } public void setState(Integer state) { this.state = state; } public boolean equals(Object other) { if ((this == other)) return true; if ((other == null)) return false; if (!(other instanceof TopicReplyViewId)) return false; TopicReplyViewId castOther = (TopicReplyViewId) other; return ((this.getMessageNewsAlumId() == castOther .getMessageNewsAlumId()) || (this.getMessageNewsAlumId() != null && castOther.getMessageNewsAlumId() != null && this .getMessageNewsAlumId() .equals(castOther.getMessageNewsAlumId()))) // && ((this.getUserIdFk() == castOther.getUserIdFk()) || (this // .getUserIdFk() != null // && castOther.getUserIdFk() != null && this // .getUserIdFk().equals(castOther.getUserIdFk()))) && ((this.getUser() == castOther.getUser()) || (this .getUser() != null && castOther.getUser() != null && this .getUser().equals(castOther.getUser()))) && ((this.getPostTime() == castOther.getPostTime()) || (this .getPostTime() != null && castOther.getPostTime() != null && this .getPostTime().equals(castOther.getPostTime()))) && ((this.getTitle() == castOther.getTitle()) || (this .getTitle() != null && castOther.getTitle() != null && this.getTitle() .equals(castOther.getTitle()))) && ((this.getContent() == castOther.getContent()) || (this .getContent() != null && castOther.getContent() != null && this.getContent() .equals(castOther.getContent()))) && ((this.getState() == castOther.getState()) || (this .getState() != null && castOther.getState() != null && this.getState() .equals(castOther.getState()))); } public int hashCode() { int result = 17; result = 37 * result + (getMessageNewsAlumId() == null ? 0 : this .getMessageNewsAlumId().hashCode()); // result = 37 * result // + (getUserIdFk() == null ? 0 : this.getUserIdFk().hashCode()); result = 37 * result + (getUser() == null ? 0 : this.getUser().hashCode()); result = 37 * result + (getPostTime() == null ? 0 : this.getPostTime().hashCode()); result = 37 * result + (getTitle() == null ? 0 : this.getTitle().hashCode()); result = 37 * result + (getContent() == null ? 0 : this.getContent().hashCode()); result = 37 * result + (getState() == null ? 0 : this.getState().hashCode()); return result; } }
TopicReplyView.hbm.xml
<?xml version="1.0" encoding="utf-8"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <!-- Mapping file autogenerated by MyEclipse Persistence Tools --> <hibernate-mapping> <class name="org.com.entity.TopicReplyView" table="topicReplyView" catalog="alumnus"> <composite-id name="id" class="org.com.entity.TopicReplyViewId"> <key-property name="messageNewsAlumId" type="java.lang.Integer"> <column name="messageNewsAlumId" /> </key-property> <!-- <key-property name="userIdFk" type="java.lang.Integer"> <column name="userIdFK" /> </key-property> --> <key-many-to-one name="user" class="org.com.entity.User"> <column name="userIdFK" not-null="true" /> </key-many-to-one> <key-property name="postTime" type="java.sql.Timestamp"> <column name="postTime" length="19" /> </key-property> <key-property name="title" type="java.lang.String"> <column name="title" length="50" /> </key-property> <key-property name="content" type="java.lang.String"> <column name="content" /> </key-property> <key-property name="state" type="java.lang.Integer"> <column name="state" /> </key-property> </composite-id> </class> </hibernate-mapping>
15.
两表联合的情况下,如何知道记录来自哪个表,添加一个字段表明来自哪个表
修改select语句,增加一个字段,类似如下:
select 'A ' as 表名,... from tableA
union
select 'B ' as 表名,... from tableB
16.
struts2标签在jsp中显示index
<s:iterator value="mnaList" status="sta"> <tr> <td height="20"> <s:property value="#sta.index+1"/> </td> </tr> </s:iterator>
17.
jsp页面显示<s:property时未显示正确值:ognl.NoConversionPossible
解决方法:添加lazy="false" http://hi.baidu.com/yby0260/blog/item/f5b53ade3d68581f62279848.html
<key-many-to-one name="user" class="org.com.entity.User" lazy="false"> <column name="userIdFK" not-null="true" /> </key-many-to-one>
18.
struts2 标签 输出html代码解决方式【转】
有时候用<s:property 输出一些带有html字符的控制字符串,本意是想让它可以解析成一些功能文字,比如超链接。可是,struts会把它原样输出,这时候只需要:
HTML标签会原样输出,因为struts标签会对html进行自动的编码,并且此标签有内置属性escape。此属性默认值是true,就是它控制着是否自动编码,所以加入escape="false"就OK了
例如
<s:property value="服务器传回来的HTML字符串" escape="false"/>
19.
action调用action
参考:http://liminhappygirl.iteye.com/blog/1290340;http://blog.csdn.net/alyssa_qian/article/details/5649300
方法一:redirectAction
<result name="saveMRInfo" type="redirectAction"> <param name="actionName">messageNewsAlumAction!searchMRepInfo</param> <param name="id">${id}</param> <param name="tableName">${tableName}</param> </result>
方法二:redirect:多个参数时,需要使用"&"代替"&"
<result name="saveMRInfo" type="redirect"> messageNewsAlumAction!searchMRepInfo?id=${id}&tableName=${tableName} </result>
方法三:chain
<action name="isBankUserExist" class="com.dreamer.firstbank.action.BankUserExistAction" method="isBankUserExist"> <result name="success" type="chain">createAccount</result> </action> <action name="createAccount" class="com.dreamer.firstbank.action.CreateAccountAction" method="createAccount"> <result name="success">/staff/kaihu3.jsp</result> </action>
20.
弹出提示窗口
<script type="text/javascript"> function deleteMRInfo(){ if (confirm("删除是不可恢复的,你确认要删除吗?")){ return true; }else{ return false; } } </script>
<a href="#" onclick="javascript:return deleteMRInfo();">删除</a>
21.
Eclipse 保存文件时自动格式化代码http://xieyanhua.iteye.com/blog/1447616
22.
mysql中UNSIGNED(未签署) 修饰符规定字段只保存正值
23.
Resource is out of sync with the file system: '/emsp_oam08/WebContent/images/Thumbs.db'
http://hi.baidu.com/lynsahuang/blog/item/a3ecdd9819b7840f6f068cec.html
是文件系统不同步的问题,需要手动刷新一下资源管理器
应该按一下F5,就好了
Thumbs.db在存在大量图片的文件夹下才会产生,有时病毒也会产生,删除没有影响。
24.
jsp中用request.getParameter("")取中文时得到乱码,解决方法:
String author = new String(request.getParameter("author").getBytes("ISO8859-1"),"UTF-8");
25.
回车自动提交表单问题
http://www.blueidea.com/articleimg/2009/02/6390/submit1.html
26.
页面在两秒后跳转到index.jsp
<meta http-equiv= "refresh" content= "2;url= ../index.jsp"/>
27.
只执行action不跳转页面,使用<s:action="" executeResult="false"></s:action>貌似解决不了
笨方法 index.jsp里使用27中的方法跳转到action
<meta http-equiv= "refresh" content= "0;url= indexAction!init.action"/>
action再转到index1.jsp,这样index.jsp相当于没用了
28.
跳转页面
var url = "profileAction!addAlumBath.action?filePath=" + path; location.href= url;
29.
mysql中timestamp的时间比系统时间早8小时,即时区问题,解决方法:
show variables like '%time_zone';//查询mysql的时区设置 system_time zone | | time_zone |UTC| select now();//mysql的当前时间 set time_zone = system;//将UTC设置为system,即可得到正确时间
问题是select now();显示时间正确,而插入数据时timestamp的时间仍然不对
解决方法:修改配置文件my.ini
E:\Program Files\xampp\xampp\mysql\bin
将default-time-zone = "UTC"改为:
default-time-zone = "+8:00"
暂时未解决问题:
1. 数据库表设计的有问题:
(1)如两条jobInfo的profileId可能相同,两条profile的userId可能相同
(2)数据库表中username可以相同,只能通过前台判断不安全。。
unique
http://www.iteye.com/problems/48403
2.jsp页面中java代码片段<%%>内的值如何与前台传来的<s:property里的值进行比较
3.如何利用hibernate自动生成数据库表
如何在创建表的时候,默认使用ENGINE=InnoDB呢?
4.可视化HTML编辑器CKEditor:http://ckeditor.com/
5.cookies记住密码
6.CKfinder??上传图片时,浏览服务器有问题
相关推荐
下面将详细讨论在SSH整合过程中可能遇到的问题及其解决方案。 1. **依赖冲突**:由于Struts、Spring和Hibernate各自有自己的库依赖,整合时可能会出现版本冲突。解决方法是确保所有库的版本兼容,或者使用Maven或...
在IT领域,特别是软件开发与数据库交互的过程中,SSH框架(Struts+Spring+Hibernate)是极为常见的一种技术栈。在上述场景中,遇到的问题主要集中在如何利用Hibernate进行基于名称的查询以及基于名称的删除操作。这...
在IT开发过程中,集成不同的框架是一项常见的任务,例如SSH(Struts2、Hibernate、Spring)的整合。然而,这样的整合可能会遇到各种问题,其中之一就是中文乱码问题。本篇文章主要探讨了在MyEclipse 5.5环境下进行...
可以使用一些工具来辅助诊断SSH连接问题,例如`ssh -v`(详细模式)可显示连接过程中的详细信息,帮助找出问题所在。 5. **源码调试**: 对于更深入的问题,你可能需要查看SSH的源码进行调试,理解其工作原理。...
4. `_UpgradeReport_Files` - 可能包含升级报告的文件夹,用于查看升级过程中遇到的问题和解决办法。 5. `ConsoleApplication1` - 一个简单的控制台应用程序示例,可能展示了如何使用SharpSSH。 6. `CVS` - 可能是...
在开发过程中,开发者可能会遇到的问题有配置连接参数、处理异常、调试网络延迟、优化性能等。通过SSH.NET-develop提供的示例代码,开发者可以学习如何正确使用库中的类和方法来解决这些问题。同时,了解SSH协议的...
### SSH整合过程中遇到的问题及解决方案 #### 一、问题概述 在进行SSH(Spring+Hibernate+Struts)框架整合的过程中,开发人员可能会遇到多种技术挑战与兼容性问题。特别是当涉及到Spring与Hibernate在AOP(面向切...
在描述中提到了一个博客链接,这可能是一个开发者分享的关于如何解决SSH2整合过程中遇到的问题的教程。在实际开发中,开发者可能会遇到连接超时、认证失败、权限不足等各种问题,这些问题通常需要对SSH协议和相关库...
在描述中提到的“一个小问题没解决”,可能指的是在上述流程中的某个环节遇到了困难,比如连接问题、认证问题、命令执行错误或文件传输问题。解决这类问题通常需要检查配置参数、网络状况、权限设置以及代码实现是否...
通过深入研究这些资料,你可以掌握SSH2框架的基本用法,了解如何在实际项目中整合这三个框架,以及如何解决开发过程中遇到的问题。这将有助于提升你的Java Web开发技能,使你能够更好地应对复杂的企业级项目需求。...
SharpSSH是C#编程语言中实现的一个开源SSH(Secure Shell)客户端组件,它为.NET开发者提供了在Windows环境中安全地执行远程命令、传输文件以及建立安全隧道的能力。SSH是一种网络协议,用于加密网络通信,确保数据...
"删除功能有问题还没解决"暗示了在开发过程中遇到的挑战。这可能是由于事务管理不当导致的数据不一致,或者是未正确处理并发删除导致的冲突。在SSH框架中,这些问题通常通过配置事务边界和使用乐观锁或悲观锁来解决...
这个"SSH项目源码及心得体会"的资源对于初学者来说尤其宝贵,因为它不仅包含了实际项目的源代码,还记录了开发者在整合和使用SSH框架过程中的心得与经验。 Struts2是MVC(Model-View-Controller)架构模式的一种...
SSH框架虽然强大,但也需要注意其复杂性,尤其是整合过程中可能遇到的配置问题。随着Java社区的发展,Spring Boot等更现代的框架逐渐取代SSH,但SSH仍然是理解和学习企业级Java开发的重要途径。
3. **常见问题解答**:整理归纳实践中遇到的典型错误及其解决方案,帮助初学者避免踩坑。 4. **优化建议**:针对某些复杂场景给出更高效或更合理的实现方式,提升代码质量和性能表现。 #### 五、学习方法推荐 - **...
8. **错误处理**:在开发过程中,可能会遇到各种错误,如网络连接问题、权限问题、文件路径问题等。因此,编写健壮的错误处理代码是必不可少的。 9. **调试与优化**:当遇到问题时,学会使用日志记录和调试工具来...
面试中可能会遇到的问题包括: - 描述Struts2的工作原理,尤其是Action和Result的概念。 - 解释Struts2的拦截器链是如何工作的。 - Struts2中的OGNL表达式如何使用,以及它在框架中的角色。 - 比较Struts1和...
7. **错误处理和调试**: 在整合过程中,可能会遇到连接问题、认证失败、权限错误等,因此理解和处理这些错误是成功整合的关键。日志记录和适当的错误处理机制可以帮助定位和解决问题。 总的来说,SSH2与Spring ...
综合来看,SSH学习笔记不仅涉及了SSH框架的基础知识,还包括了如何在项目中应用这些框架,并对在实际开发过程中可能遇到的问题提供了解决方案。这为想要深入学习和掌握SSH框架的开发者提供了宝贵的参考。通过这些...