专注于 JAVA WEB开发
2010-04-28IT技术

没有评论
233 views

thickbox IE 不居中的问题

thickbox 3 是一个Jquery的插件,可以实现popup的效果,很漂亮,可是在IE下始终有一些兼容性的问题。

对于IE6或IE7下popup后不居中,可以通过修改下面的thickbox.js中的tb_position()方法,修改为如下内容即可

?View Code JAVASCRIPT
function tb_position() {
	$("#TB_window").css({marginLeft:"-" + parseInt((TB_WIDTH / 2), 10) + "px", width:TB_WIDTH + "px"});
	var version = $.browser.version;
	if (version instanceof Object) {
		version = version.number();
	}
	var isIE=!!window.ActiveXObject;
	var isIE6=isIE&&!window.XMLHttpRequest;
	if (!($.browser.msie && version < 7) || (isIE && !isIE6) ) { // take away IE6
		$("#TB_window").css({marginTop:"-" + parseInt((TB_HEIGHT / 2), 10) + "px"});
	}
}

另外对于IE下,CSS文件的重复引入也会引起问题。

2010-04-28IT技术

没有评论
212 views

JAVA XML 解析

解析一段xml

<employees total="2">
	<employee>
		<name>hitangjun</name>
		<phones>
			<phone>123456789</phone>
			<phone>012345688</phone>
		</phones>
	</employee>
	<employee>
		<name>hitangjun</name>
        <phones>
          <phone>188456789</phone>
          <phone>392347777</phone>
        </phones>
	</employee>
</employees>

代码如下,注释很详细

import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.IOException;
import java.io.StringReader;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.xml.sax.InputSource;
 
/**
 * Parse Xml service demo.
 * @author tangjun
 * @since 2010-4-28
 */
public class ParseXml {
 
    /**
     * 解析XML文件的内容,并打印每一个节点的信息,你也可以将他设置到一个bean里进行返回。
     * @param xmlContent
     * @author tangjun
     */
    @SuppressWarnings("unchecked")
    private static void parseXML(String xmlContent) {
        //创建一个新字符串 reader。其源为一个字符串的字符流
        StringReader stringReader = new StringReader(xmlContent);
        try {
            //定义工厂,从 XML 文档获取生成 DOM 对象树的解析器
            DocumentBuilderFactory docBuilderFactory = DocumentBuilderFactory
                    .newInstance();
            //从 XML 文档获取 DOM 文档实例
            DocumentBuilder docBuilder = docBuilderFactory.newDocumentBuilder();
            //构建输入流
            InputSource inputSource = new InputSource(stringReader);
            //给定 InputStream 的内容解析为一个 XML 文档,并且返回一个新的 Document 对象
            Document doc = docBuilder.parse(inputSource);
            //直接访问文档的文档元素的子节点
            doc.getDocumentElement().normalize();
 
            //按文档顺序返回包含在文档中且具有"employee"的所有 Element 的 NodeList
            NodeList listOfResults = doc.getElementsByTagName("employee");
 
            for (int s = 0; s < listOfResults.getLength(); s++) {
                Node resultNode = listOfResults.item(s);
                //如果该节点为 Element
                if (resultNode.getNodeType() == Node.ELEMENT_NODE) {
                    System.out.println("\nemployee " + s);
                    Element resultElement = (Element) resultNode;
 
                    // name tag
                    String name = "";
                    NodeList nameList = resultElement
                            .getElementsByTagName("name");
                    if (nameList.getLength() > 0) {
                        Element nameElement = (Element) nameList.item(0);
 
                        //获取包含此节点的所有子节点的 NodeList
                        NodeList textNameList = nameElement.getChildNodes();
                        if (textNameList.getLength() > 0) {
                            name = (textNameList.item(0)).getNodeValue()
                                    .trim();
                            System.out.println("name: " + name);
                        }
                    }
 
                    // phones tag
                    NodeList phonesList = resultElement
                            .getElementsByTagName("phones");
                    if (phonesList.getLength() > 0) {
                        Element phonesElement = (Element) phonesList
                                .item(0);
                        NodeList listOfCategories = phonesElement
                                .getElementsByTagName("phone");
                        for (int i = 0; i < listOfCategories.getLength(); i++) {
                            Element categoryElement = (Element) listOfCategories
                                    .item(i);
                            NodeList textCategoryList = categoryElement
                                    .getChildNodes();
                            String phone = (textCategoryList.item(0))
                                    .getNodeValue().trim();
 
                            //输出,或者设置到bean属性
                            System.out.println("phone: " + phone);
                            //phoneList.add(phone);
                        }
                        //bean.setPhoneList(phoneList);
                    }
                }
            }
            String totalCount = doc.getDocumentElement().getAttribute("total");
            System.out.println("\n总记录数 total: " + totalCount);
        } catch (Exception err) {
            err.printStackTrace();
        } finally {
            stringReader.close();
        }
    }
 
 
    /**
     * 读取并返回文件内容
     * @throws FileNotFoundException
     * @throws IOException
     */
    private static String readFile(String filePath){
        // 建立对象fr
        FileReader fr = null;
        try {
            fr = new FileReader(filePath);
            // 建立可容纳1024个字符的数组
            char data[] = new char[1024];
            //试图将字符读入指定的字符缓冲区。
            int num = fr.read(data);
            // 将字符列表转换成字符串
            String str = new String(data, 0, num);
            // 输出在控制台
           // System.out.println("Characters read= " + num);
            //System.out.println(str);
            return str;
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }finally{
            try {
                //关闭输入流
                if(null != fr){
                    fr.close();
                }
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
        return null;
    }
 
    public static void main(String[] args) {
        //打印当前定位的目录,以便解析文件找不到的原因
       // System.out.println(System.getProperty("user.dir"));
        //开始解析,test.xml user.dir下
        ParseXml.parseXML(readFile("test.xml"));
    }
}
2010-04-24IT技术

没有评论
296 views

linux mysql 自动备份

目标:
使用cron自动执行mysql备份命令备份mysql数据库

步骤:
1. shell脚本 mysqlbackup.sh

#!/bin/bash
#定义变量,注意等号前后无空格
BACKUP_DIR="/root/mysqlbackup"
DATE=$(/bin/date +%Y%m%d%H%M%S)
FILE_NAME="testdb_$DATE.sql.gz";
 
echo "starting backup database"
 
#使用mysqldump命令备份我的mysql数据库,并通过gzip进行压缩
exec /usr/bin/mysqldump -uroot -proot --default-character-set=utf8 --opt --extended-insert=false --triggers -R --hex-blob -x test_database | gzip > $BACKUP_DIR/$FILE_NAME
 
echo "end backup database"

2. 赋予执行权限

chmod a+x ./mysqlbackup.sh

3. 使用crontab -e命令编辑自己的crontab任务

0 16 * * * /root/mysqlbackup.sh

上面表示每天的16点整自动执行mysqlbackup.sh

相关知识:
1. mysql备份命令

/usr/bin/mysqldump -uMysql账户 -pMysql密码 --default-character-set=utf8 --opt --extended-insert=false --triggers -R --hex-blob -x 数据库名

例如

/usr/bin/mysqldump -uroot -proot --default-character-set=utf8 --opt --extended-insert=false --triggers -R --hex-blob -x test_database

2. 关于date的格式

>> date --help                                                                                           
用法:date [选项]... [+格式]                                                                             
 或:date [-u|--utc|--universal] [MMDDhhmm[[CC]YY][.ss]]                                                 
以给定的格式显示当前时间,或是设置系统日期。                                                             
 
  -d,--date=字符串              显示指定字符串所描述的时间,而非当前时间
  -f,--file=日期文件            类似--date,从日期文件中按行读入时间描述
  -r, --reference=文件          显示文件指定文件的最后修改时间         
  -R, --rfc-2822                以RFC 2822格式输出日期和时间           
                                例如:2006年8月7日,星期一 12:34:56 -0600
      --rfc-3339=TIMESPEC       以RFC 3339 格式输出日期和时间。         
                                TIMESPEC=`date',`seconds',或 `ns'     
                                表示日期和时间的显示精度。               
                                日期和时间单元由单个的空格分开:         
                                2006-08-07 12:34:56-06:00               
  -s, --set=字符串              设置指定字符串来分开时间                 
  -u, --utc, --universal        输出或者设置协调的通用时间               
      --help            显示此帮助信息并退出                             
      --version         显示版本信息并退出                               
 
给定的格式FORMAT 控制着输出,解释序列如下:
 
  %%    一个文字的 %
  %a    当前locale 的星期名缩写(例如: 日,代表星期日)
  %A    当前locale 的星期名全称 (如:星期日)         
  %b    当前locale 的月名缩写 (如:一,代表一月)     
  %B    当前locale 的月名全称 (如:一月)             
  %c    当前locale 的日期和时间 (如:2005年3月3日 星期四 23:05:25)
  %C    世纪;比如 %Y,通常为省略当前年份的后两位数字(例如:20)   
  %d    按月计的日期(例如:01)                                   
  %D    按月计的日期;等于%m/%d/%y                               
  %e    按月计的日期,添加空格,等于%_d                           
  %F    完整日期格式,等价于 %Y-%m-%d                             
  %g    ISO-8601 格式年份的最后两位 (参见%G)                     
  %G    ISO-8601 格式年份 (参见%V),一般只和 %V 结合使用         
  %h    等于%b                                                   
  %H    小时(00-23)                                               
  %I    小时(00-12)                                               
  %c    按年计的日期(001-366)                                     
  %k    时(0-23)                                                 
  %l    时(1-12)                                                 
  %m    月份(01-12)                                               
  %M    分(00-59)                                                 
  %n    换行                                                     
  %N    纳秒(000000000-999999999)                                 
  %p    当前locale 下的"上午"或者"下午",未知时输出为空           
  %P    与%p 类似,但是输出小写字母                               
  %r    当前locale 下的 12 小时时钟时间 (如:11:11:04 下午)       
  %R    24 小时时间的时和分,等价于 %H:%M                         
  %s    自UTC 时间 1970-01-01 00:00:00 以来所经过的秒数           
  %S    秒(00-60)                                                 
  %t    输出制表符 Tab                                           
  %T    时间,等于%H:%M:%S                                       
  %u    星期,1 代表星期一                                       
  %U    一年中的第几周,以周日为每星期第一天(00-53)
  %V    ISO-8601 格式规范下的一年中第几周,以周一为每星期第一天(01-53)
  %w    一星期中的第几日(0-6),0 代表周一
  %W    一年中的第几周,以周一为每星期第一天(00-53)
  %x    当前locale 下的日期描述 (如:12/31/99)
  %X    当前locale 下的时间描述 (如:23:13:48)
  %y    年份最后两位数位 (00-99)
  %Y    年份
  %z +hhmm              数字时区(例如,-0400)
  %:z +hh:mm            数字时区(例如,-04:00)
  %::z +hh:mm:ss        数字时区(例如,-04:00:00)
  %:::z                 数字时区带有必要的精度 (例如,-04,+05:30)
  %Z                    按字母表排序的时区缩写 (例如,EDT)
 
默认情况下,日期的数字区域以0 填充。
以下可选标记可以跟在"%"后:
 
  - (连字符)不填充该域
  _ (下划线)以空格填充
  0 (数字0)以0 填充
  ^ 如果可能,使用大写字母
  # 如果可能,使用相反的大小写
 
在任何标记之后还允许一个可选的域宽度指定,它是一个十进制数字。
作为一个可选的修饰声明,它可以是E,在可能的情况下使用本地环境关联的
表示方式;或者是O,在可能的情况下使用本地环境关联的数字符号。
 
请向bug- coreutils@gnu.org 报告date 的错误
GNU coreutils 项目主页:<http ://www.gnu.org/software/coreutils/>
GNU 软件一般性帮助:<http ://www.gnu.org/gethelp/>
请向<http ://translationproject.org/team/zh_CN.html> 报告date 的翻译错误</http>

3. cron 配置计划任务的书写格式

分钟 小时 日 月 周 [用户名] 命令

说明:

第一段应该定义的是:分钟,表示每个小时的第几分钟来执行。范围是从0-59
第二段应该定义的是:小时,表示从第几个小时来执行,范围是从0-23
第三段应该定义的是:日期,表示从每个月的第几天执行,范围从1-31
第四段应该定义的是:月,表示每年的第几个月来执行,范围从1-12
第五段应该定义的是:周,表示每周的第几天执行,范围从0-6,其中 0表示星期日。
每六段应该定义的是:用户名,也就是执行程序要通过哪个用户来执行,这个一般可以省略;
第七段应该定义的是:执行的命令和参数。

via[mysql自动备份,cron,cron服务]

2010-04-21懒得分类

没有评论
287 views

J2ME代码优化

位运算代替除和乘

switch 代替 if else

局部变量代替全局变量

循环的控制,长度的计算,–代替++

String的创建不要用new

StringBuffer的append

空字符串 s.length == 0

“,” ‘, ‘ 字符串和字符的使用

异常处理,优先使用if判断null

类中类谨慎使用

连接的关闭

分清构造函数和startApp的功能,在构造函数创建对象

pauseApp之后StartApp会再次运行,pause时可以释放一些资源.

destroyApp的时候释放所有资源

2010-02-25建站手记

没有评论
401 views

启用新域名HITANGJUN.COM

因未知原因,启用新域名HITANGJUN.COM
原tj4c.com将在4月2号之后废弃,所有内容将迁移到http://blog.hitangjun.com/ 下
所有FEDD都已更新您可以订阅

http://feeds2.feedburner.com/tj4c

http://feed.feedsky.com/tj4c

http://hitangjun.com/的内容暂时还没想好要做什么

你还可以在以下站点跟踪我的最新信息

https://twitter.com/tangjun

http://www.google.com/reader/shared/tangjun1225

返回顶部