落雨

解决java写入xml报错org.w3c.dom.DOMException:DOM002 Illeg

Exception is -- > org.w3c.dom.DOMException: DOM002 Illegal character 字符不被允许

org.w3c.dom.DOMException: DOM002 Illegal character

        at org.apache.xerces.dom.DocumentImpl.createAttribute(DocumentImpl.java:466)

        at org.apache.xerces.dom.ElementImpl.setAttribute(ElementImpl.java:449)

        at WriteXML.main(WriteXML.java:33)


说明你的xml节点可能有空格/分号/逗号/单引号了 

错误:【Element wfmNode = doc.createElement("wfm-node';/' ");】

正确:【Element wfmNode = doc.createElement("wfm-node");】

xml规范中不允许出现空格的!


实例代码:

for(int i=0;i<bindWfmNodes.size();i++){

BindWfmNodeModel wfmB = (BindWfmNodeModel)bindWfmNodes.get(i); 

Element wfmNode = doc.createElement("wfm-node");

wfmNodes.appendChild(wfmNode);

//wfm-node-activityId

Element wfmActivityId = doc

.createElement("wfm-node-activityId");

wfmActivityId.appendChild(doc

.createTextNode(wfmB.getWfmActivityId()));

//wfm-node-name

Element wfmFieldName = doc.createElement("wfm-field-name");

wfmFieldName.appendChild(doc

.createTextNode(wfmB.getName()));


//wfm-node-fieldBindKey

Element wfmBindFieldKey = doc.createElement("wfm-bind-field-key");

wfmBindFieldKey.appendChild(doc.createTextNode(wfmB.getBindFieldKey()));

wfmNode.appendChild(wfmActivityId);

wfmNode.appendChild(wfmFieldName);

wfmNode.appendChild(wfmBindFieldKey);

}

form.appendChild(wfmNodes);


落雨

2015年2月2日18:25:32

QQ 394263788

Eclipse plugin插件开发 NoClassDefFoundError

Eclipse的每一个plugin都有属于自己的类加载器,这是OSGI架构的基础,每一个plugin项目都是一个bundle,独立运行在各自的运行环境里面,这就造成了开发时和运行时的不同。


Eclipse插件开发,切记不要随便引入别的plugin工程到自己的classPath中,正确的做法应该是引用插件依赖。下面就分几种情况来讲一下这个Eclipse插件项目运行时报错:NoClassDefFoundError。


首先引用http://www.blogjava.net/Jeffery001/archive/2008/10/14/234166.html所说的三种情况,最后我谈下我出现的第四种情况,就是前三种解决办法都不生效的时候,看下第4种。


Eclipse插件开发对于Jar包的引用主要有三种原因:

1. 插件引用第三方包(普通的jar包或者类文件,不是插件)。

a)开发环境引用配置,在prject -> properties -> Java build path中设置。

b)运行环境引用配置,在plugin manifest编辑器的Runtime选项卡下的classpath中添加tset.jar包的引用(在MANIFEST.MF中表现为Bundle-ClassPath: lib/test.jar, 在plugin.xml表现为<runtime>节下的引用

  i.  类文件在lib目录下,如下的设置导出lib目录下所有目录:

        <runtime>

            <library name="lib/">

             <export name="*"/>

            </library>

        </runtime>

 ii.  test.jar在lib目录下:

        <runtime>

            <library name="lib/test.jar">

             <export name="*"/>

            </library>

        </runtime>

 iii.  实际上上面的设置可以简化为:

        <runtime>

            <library name="lib/"/>

        </runtime>

    或者

        <runtime>

            <library name="lib/test.jar"/>

        </runtime>

       默认即导出lib目录下的所有包和jar下的所有包

       实际上,执行b)项设置后,会自动执行a)项设置,使开发环境和运行环境同时有效。

2. 插件B引用插件工程A(非Eclipse插件,而是自己另外一个插件项目中的类)

a)首先必须将A中的B需要的类暴露(export)出来

i.如果有MANIFEST.MF文件,则表现为plugin manifest编辑器中runtime节的exported packages,通过这里添加需要export的包。在manifest.mf文件中是Export-Package: com.bbebfe

ii.如果只有plugin.xml,则表现为plugin manifest编辑器中runtime节的library visibility。在plugin.xml文件中表现为

    <runtime>

       <library>

              <export name=”com.bbebfe.*”/>

       ...

b)在B插件工程的plugin manifest编辑器中的dependencies选项卡中添加对A插件的引用(这要求运行对话框中的plugins列表的workspace plugins中必须包含A插件)。

c)如果B工程是一个RCP工程,则必须在product编辑器的configuration选项卡中包含A插件工程。

3. 插件B引用Eclipse插件A的类。

a)Eclipse插件中的类都是Exported,因此这步省略。

b)在B插件工程的plugin manifest编辑器中的dependencies选项卡中添加对A插件的引用(这要求preferences -> plugin development -> target目标平台必须包含A插件,且运行对话框的plugins列表中的target platform中必须选中A插件)。

 

总结:如果B插件引用的A也是一个插件,则A必须出现在B插件的plugin dependencies引用中,而不是其他地方,否则肯定会出现运行时NoClassDefFoundError问题(因此必须在plugin manifest编辑器的dependencies选项卡下进行设置)。而且只需要在这里设置的设置对开发环境和运行环境同时有效)

 

注意:还有一种情况就是开发环境没有某个包或者插件,而只在运行环境(target)中存在,此时就必须设置正确的target,然后按照正常程序添加插件引用,但此时已经不能在plugin manifest的dependencies选项卡中设置(因为在开发环境找不到这个plugin),而必须在plugin.xml或MANIFEST.MF文件中手工设置。plugin只要target中存在该插件,则开发和运行也不会有问题。


ok 下面我说下第四种情况,这个比较特殊,目前百度上也没有搜到类似的解决办法,我是自己瞎试出来的。

4.我按照上述三种办法进行尝试解决的时候,出现一个问题,首先我的Eclipse插件项目没有MANIFEST.MF文件,而且plugin.xml中已经将所有的包暴漏出来了,但是Eclipse插件运行时候还是报错了,找不到类,那么我就开始思考是不是Eclipse插件运行时环境有缓存没有清掉,我重新clean了一次工程,rebuild了一下class文件,但是依然报错,我就开始翻阅Eclipse运行时的文件夹,一般在:F:\wfmSourceWorkSpa\tools_v3_ch\.metadata\.plugins\org.eclipse.pde.core\你的插件项目名 下,我在org.eclipse.osgi找到了一个文件,叫xxx.mf,我打开瞅了一眼,果然没错,我的包少暴漏了一个,于是我干掉了org.eclipse.osgi和org.eclipse.update这2个文件夹,然后重新debug我的工程,代码顺利过去。


落雨

2015年2月2日15:37:05

QQ 394263788

http://ae6623.cn

java 正则匹配空格字符串 正则表达式截取字符串

java 正则匹配空格字符串 正则表达式截取字符串

需求:从一堆sql中取出某些特定字符串:

比如配置的sql语句为:"company_code = @cc and project_id = @pid ; update t set a = @aa,b=@bb,c=@cd,ttt=@ttt;update t2 set d=@bb";

我要拿出所有的以@开头的作为变量,并且去重,则如下玩:

ps:其中正则匹配空格是 “\s+”


1

【算法】1、约瑟夫环

有n 个人围城一圈每次从1数起数到3就把那个人提出圈子,最后只保留一个人。

输入: 输入人数字符串
输出:把最后一个人所保留位置返回出来。
比如你输入11 的话即有11个人 [1,2,3,4,5,6,7,8,9,10,11] 。返回的是7


解题:


1

将java类的泛型集合转换成json对象

一般用extjs开发传输都是用json比较多,这个将来大家也许会用到。。。

ConvertJsonUtils.java

package com.sunweb.util.jsonfactory;

import java.util.List;

import com.sunweb.util.jsonfactory.jsontools.JSONArray;
import com.sunweb.util.jsonfactory.jsontools.JSONException;
import com.sunweb.util.jsonfactory.jsontools.JSONObject;

/**
* @title 公共json数据格式转换
* @author 贺彬
*/
public class ConvertJsonUtils {

    public ConvertJsonUtils() {
        super();
    }

    /**
     * 功能:将泛型集合转换成分页json数据
     *
     * @param list
     *            泛型集合
     * @param countList
     *            数据集合的总行数
     * @return 分页json数据
     */
    public static String ConvertListToPageJson(List<?> list, int countList) {
        // 新建一个json数组
        JSONArray jsonArray = new JSONArray();
        // 新建一个json对象
        JSONObject jsonObject = null;
        // 遍历泛型集合
        for (Object object : list) {
            jsonObject = new JSONObject(object);
            jsonArray.put(jsonObject);
        }
        // 转换数据格式
        String json = jsonArray.toString();
        // 拼接字符串
        StringBuffer sb = new StringBuffer();
        sb.append("{\"totalCount\":");
        sb.append(countList);
        sb.append(",\"rows\":");
        sb.append(json);
        sb.append("}");
        String jsonString = sb.toString();
        return jsonString;
    }
    /**
     * 功能:将泛型集合转换成分页json数据
     *
     * @param list
     *            泛型集合
     * @param countList
     *            数据集合的总行数
     * @return 分页json数据
     */
    public static String ConvertListToPageJson(List<?> list){
        // 新建一个json数组
        JSONArray jsonArray = new JSONArray();
        // 新建一个json对象
        JSONObject jsonObject = null;
        // 遍历泛型集合
        for (Object object : list) {
            jsonObject = new JSONObject(object);
            jsonArray.put(jsonObject);
        }
        // 转换数据格式
        String json = jsonArray.toString();
        // 拼接字符串
        JSONObject jn = new JSONObject();
        try {
            jn.put("records", jsonArray);
        } catch (JSONException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        return jn.toString();
    }

}

Test.java

package com.sunweb.util.jsonfactory;

import java.util.ArrayList;
import java.util.List;

public class Test {

    /**
     * @param args
     */
    public static void main(String[] args) {
        List<Student> list = new ArrayList<Student>();  //创建一个泛型的list集合
        Student stu = null;
        for(int i=0;i<20;i++){
            stu = new Student();
            stu.setId(i);
            stu.setName("贺兵"+i);
            //模拟有20个对象的list集合
            list.add(stu);
        }
       //现在将集合转成json不分页
       String json1 = ConvertJsonUtils.ConvertListToPageJson(list);
        System.out.println(json1);
        //分页,总数20条
       String json2 = ConvertJsonUtils.ConvertListToPageJson(list, 20);
        System.out.println(json2);
    }

Student.java

package com.sunweb.util.jsonfactory;

public class Student {
    private int id;
    private String name;
    public int getId() {
        return id;
    }
    public void setId(int id) {
        this.id = id;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
}
http://outofmemory.cn/code-snippet/4036/jiang-java-class-generic-set-turn-huancheng-json-object

java多线程下载和断点续传

java多线程下载和断点续传,示例代码只实现了多线程,断点只做了介绍。但是实际测试结果不是很理想,不知道是哪里出了问题。所以贴上来请高手修正。

[Java]代码

import java.io.File;
import java.io.IOException;
import java.io.RandomAccessFile;
import java.net.HttpURLConnection;
import java.net.URL;

public class DownloadFile {

    /**
     * @param args
     */
    static int len;//线程平均下载文件长度
    static int bn ;//每个线程写入文件的字节数
    static int tn; //线程数
    static String urlt;//下载地址
    static String fileName;
    static RandomAccessFile osf; //文件操作
    public static void main(String[] args) {
        // TODO Auto-generated method stub

        try {
            urlt = "http://im.baidu.com/download/BaiduHi_4.2_Beta.exe";
            fileName = "C:\\" + urlt.split("//")[1].split("/")[urlt.split("//")[1].split("/").length-1];
            System.out.println(fileName);
            URL url = new URL(urlt);
            HttpURLConnection http = (HttpURLConnection) url.openConnection();

            /**
             * 此处设定5个线程下载一个文件tn = 5;
             * 判断平均每个线程需下载文件长度:
             */
            System.out.println("file size:" + http.getContentLength());
            tn = 3;        
            len = http.getContentLength() / tn ;//舍去余数(余数自动舍去)计算每个线程应下载平均长度,最后一个线程再加上余数,则是整个文件的长度,
            File f = new File(fileName);
            if (f.exists()){
                f.delete();
                osf = new RandomAccessFile(f, "rw");
                osf.seek(http.getContentLength()-1);
                osf.write(0);
            }else{
                osf = new RandomAccessFile(f, "rw");
                osf.seek(http.getContentLength()-1);
                osf.write(0);
            }
            System.out.println("temp 文件长度:" + f.length());
            Thread t;//下载子线程,
            for (int j = 0; j < tn; j++) {
                if(j == tn - 1){//如果最后一个线程则加上余数长度字节
                    bn = len + (http.getContentLength() % tn);
                }else{
                    bn = len;
                }
                System.out.println("t"+ j + "线程下载长度:" + bn + "起始字节:" + len*j);
                t = new DT(
                        j,
                        urlt,
                        fileName,
                        len*j,
                        bn

                );
                t.start();
            }

        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }

}

import java.io.File;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;
import java.io.RandomAccessFile;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.URL;
import java.util.Date;

public class DT extends Thread {

    String urlt;
    int startl;
    int end;
    String fileName;
    RandomAccessFile osf;
    public DT(int i ,String url,String fileName,int start,int end){
        this.setName("t"+i); //子线程名称
        this.urlt = url; //下载地址
        this.fileName = fileName;
        this.startl = start; //子线程读取/写入起始字节
        this.end = end;//子线程写入结束字节长度
    }
    public void run(){
            try {
                osf = new RandomAccessFile(fileName, "rw");
                URL url = new URL(urlt);
                HttpURLConnection http2 = (HttpURLConnection) url.openConnection();
                http2.setRequestProperty("User-Agent","NetFox");

                /*
                 * 断点续传和多线程下载的关键代码关键位置:即设置断点
                 * http2.setRequestProperty("RANGE", "bytes="+startl+"-");//设置断点位置,向服务器请求从文件的哪个字节开始读取。
                 * osf.seek(startl);//设置本地文件从哪个字节开始写入
                 * 如果是单线程,则首先要判断下载文件是否已经存在 及DownloadFile.java 里的 fileName = "C:\\eclipse.zip";
                 * 如果存在则开始断点续传,方法同多线程:
                 * 因为断点续传是从上次传输中断的字节开始,则首先要得到上次中断的位置,既是文件长度(针对单线程)f.length()
                 * 然后设置HTTP请求头属性RANGE,该属性告知服务器从哪个自己开始读取文件。
                 * 设置本地文件写入起始字节,及接从上次传输断点继续写入(断点续传)
                 * osf.seek(offset) 该方法设定从offset后一个字节开始写入文件
                 * 注意:多线程不能用文件长度做为写文件起始字节,需有配置文件记录上次读写的位置,迅雷下载既是使用该种方法。
                 *
                 */
                http2.setRequestProperty("RANGE", "bytes="+startl+"-");//设置断点位置,向服务器请求从文件的哪个字节开始读取。
                osf.seek(startl);//设置本地文件从哪个字节开始写入

                InputStream input = http2.getInputStream();
                byte b[] = new byte[1024];//设置缓冲池,每次只读1024字节
                Date d = new Date();//子线程开始下载时间
                int l;//计算子线程读取和写入的文件长度,当长度大于每个子线程平均下载长度则终止线程
                int i;
                l = 0;
                System.out.println(this.getName() + " 开始下载。。。");
                while ( (i = input.read(b,0,1024)) != -1 && l < end){   //线程下载字节长度控制误差小于缓冲池大小,本示例为缓冲池1024字节
                    osf.write(b, 0, i);
                    b = new byte[1024];//重新赋值,避免重新读入旧内容
                    l += i;        
                }
                Date d2 = new Date();//子线程结束下载时间
                System.out.println(this.getName() + " 线程耗时: " + (d2.getTime() - d.getTime())/1000 + " 秒,实际共下载:" + l + "字节");//子线程下载耗时(秒)
            } catch (FileNotFoundException e1) {
                // TODO Auto-generated catch block
                e1.printStackTrace();
            } catch (MalformedURLException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            } catch (IOException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
    }
}
http://outofmemory.cn/code-snippet/3888/java-many-xiancheng-xiazai-breakpoint-xuchuan