首先:在Action中接受传参时,出现乱码,怎么解决,且不是actionform所能涉及到的。
window.self.location = "teammgr.do?teamcommand=list&gameid="+ document.teamForm.gameid.options[document.teamForm.gameid.selectedIndex].value+"&school="+document.teamForm.school.options[document.teamForm.school.selectedIndex].value;
时,出现乱码,怎么解决?
一般常用
String school=team.getSchool();
school=new String(school.getBytes("ISO8859_1"),"gbk");
///
s.getBytes()
这个方法是以系统的默认编码,来进行这个转换操作。而在不同的计算机上,这个值可能被设置为不同。比如,我的座机xp,默认编码就是gbk。而我的一个服务器,默认编码就是utf-8。为了确保你的程序更加可移植,你得认真考虑是否使用s.getBytes()。我建议你明确地指定编码方式进行转换。
mysql不支持unicode,所以比较麻烦。将connectionString设置成encoding为gb2312
String connectionString="jdbc:mysql://localhost/test?useUnicode=true&characterEncoding=gb2312"
在oracle 中,在把汉字字符串插入数据库前做如下转换操作:
String(str.getBytes("ISO8859_1","gb2312"))
在JAVA源文件-->JAVAC-->Class-->Java-->getBytes()-->new String()-->显示的过程中,每一步都有编码的转换过程,这个过程总是存在的,只是有的时候用默认的参数进行。
///
需要说明的是,JAVAC是以系统默认编码读入源文件,然后按UNICODE进行编码的。在JAVA运行的时候,JAVA也是采用UNICODE编码的,并且默认输入和输出的都是操作系统的默认编码,也就是说在new String(bytes,[encode])中,系统认为输入的是编码为encode的字节流,换句话说,如果按encode来翻译bytes才能得到正确的结果,这个结果最后要在JAVA中保存,它还是要从这个encode转换成Unicode,也就是说有bytes-->encode字符-->Unicode字符的转换;而在String.getBytes([encode])中,系统要做一个Unicode字符-->encode字符-->bytes的转换。
实验测试:
'中文'.getBytes()=[B@cf2c80
'中文'.getBytes('GB2312')=[B@19f953d
'中文'.getBytes('ISO8859_1')=[B@e48e1b
new String('中文'.getBytes())=中文
new String('中文'.getBytes(),'GB2312')=中文
new String('中文'.getBytes(),'ISO8859_1')=????
new String('中文'.getBytes('GB2312'))=中文
new String('中文'.getBytes('GB2312'),'GB2312')=中文
new String('中文'.getBytes('GB2312'),'ISO8859_1')=????
new String('中文'.getBytes('ISO8859_1'))=??
new String('中文'.getBytes('ISO8859_1'),'GB2312')=??
new String('中文'.getBytes('ISO8859_1'),'ISO8859_1')=??
new String(str.getBytes(“ISO-8859-1″),”GBK”)为什么
Tomcat默认全部都是用ISO-8859-1编码,不管你页面用什么显示,Tomcat最终还是会替你将所有字符转做ISO-8859-1.那么,当在另目标页面再用GBK翻译时就会将本来错的编码翻译成GBK的编码,这时的文字会乱码.
所以需要先将得到”字符”(不管是什么)都先用字节数组表示,且使用ISO-8859-1进行翻译,得到一个在ISO-8859-1编码环境下的字节数组.例如:AB表示成[64,65].然后再用GBK编码这个数组,并翻译成一个字符串.
那么我们可以得到一个编码转换的过程
假设:GBK码(“你”)->URLencode后变成->(%3F%2F)->Tomcat自动替你转一次ISO- 8859-1->得到( 23 43 68 23 42 68 每一个符号表示为ISO-8859-1中的一个编码)->接收页面—>再转一次为ISO-8859-1的Byte数组 [23,43,68,23,42,68]—>用GBK再转为可读的文字—>(%3F%2F”—->转为(“你”)
StringBuffer是可变的,String是不可变的。前者效率更高,前者赋值用append()而后者是可以直接用字符串赋值,也可以new。
actionForm 不仅仅采集表单上的数据,而且还会采集url中的相应的信息数据。用到struts开发时,在写Action类时,一般要继承父类DispatchAction,这样就会减少Action的类。
像在登陆界面,有好多验证,输入信息时,点击登录按钮,一般会弹出JavaScript框,显示一些登录是否成功的信息。然后自动进入下一个页面,若成功页面,若失败页面。
这怎么实现呢?
如果有用到struts时,Action
if(!yzm.equals(request.getSession().getAttribute("rand"))){
request.setAttribute("mes", "验证码输入错误!");
request.setAttribute("url", "login.jsp");
}
if("1".equals(utype)){
request.setAttribute("url", "admin/index.html");
}
else{
request.setAttribute("url", "User/UserIndex.jsp");
}
转向的页面的:
<c:if test="${empty url}">
<c:set var="url" value="login.jsp"></c:set>
</c:if>
<c:if test="${!empty mes}">
<script>alert('${mes}');</script>
</c:if>
<script> window.location.href="${url}"; ;</script>
下面讲一下过滤器的利用:
怎么利用过滤器呢?
首先,用户和管理员登陆成功后,会在session中记录相应得用户名,用户类型,这里主要识别用户的类型,同时为了过滤器的设置做准备。
所有过滤器都必须实现javax.servlet.Filter
这个接口包含三个方法,分别为doFilter、init和destroy
针对管理员的操作的过滤器。
public class CheckAdmin implements javax.servlet.Filter
///
public void destroy() {
config = null;
}
public void init(FilterConfig filterconfig) throws ServletException {
// 从部署描述符中获取登录页面和首页的URI
config = filterconfig;
}
public void doFilter(ServletRequest request, ServletResponse response,
FilterChain chain) {
HttpServletRequest req = (HttpServletRequest) request;
HttpServletResponse rpo = (HttpServletResponse) response;
javax.servlet.http.HttpSession session = req.getSession();
String username = (String) session.getAttribute("uname");
String utype = (String) session.getAttribute("utype");
try {
if ( username == null||utype==null||username.equals("")||!utype.equals("1")) {
rpo.sendRedirect("../login.jsp");
//System.out.print(home_page + logon_page);
return;
}
else {
chain.doFilter(request, response);
}
} catch (Exception e) {
e.printStackTrace();
}
}
对应的web.xml文件的配置:
<filter>
<filter-name>checkAdmin</filter-name>
<filter-class>com.utils.CheckAdmin</filter-class>
</filter>
<filter-mapping>
<filter-name>checkAdmin</filter-name>
<url-pattern>/admin/*</url-pattern>
</filter-mapping>
凡是访问文件夹admin里面的文件都会接受过滤器的审核。
1. <bean:resouce>标签:如果需要将文件内容作为一个变量放入到内存中时,可以使用<bean:resource>标记,标记有两个必须属性:id(变量名)和name(文件路径);
如果你选择input属性,并提供值,id参数将指向一个InputStream对象,而不是包含文件不是包含内容的字符串.
--------------------------------------------------------------------------------
2. <bean:inlcude>标签:与<jsp:include>标记基本相同,都是把被包含的文件先执行,再包含;
区别在于: <jsp:include>直接把包含的文件显示到页面上,<bean:include>标记是把内容保存到一个局部变量中,然后再处理。
<bean:include>常用属性为 id和forward、page、href三者之一。
使用这个标记可以包含外部服务器的获取XML到本地处理。
例如: <bean:include id="dotareplay" page="/index.do?action=dotareplay" />
<bean:write name="dotareplay" filter="false" /> //这里是显示输出的必须有,且上面的id值要和下面的name相同。
从一个页面弹出固定大小的窗口,怎么实现呢?
首先在触发事件的页面加入
<script type="text/javascript">
function openbag(url) {
// alert(url);
window.open(url,"","height=520,width=520,left=190,top=10,resizable=yes,scrollbars=yes,status=no,toolbar=no,menubar=no,location=no");
}
</script>、
在连接的地方,加入
<a href='#' οnclick="openbag('../admin/videomgr.do?method=showHero')" title='查看列表'>查看名称</a></td>
连接显示的字段是:查看名称