亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專(zhuān)輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? tcpserverthread.java

?? 非常棒的java數(shù)據(jù)庫(kù)
?? JAVA
字號(hào):
/*
 * Copyright 2004-2008 H2 Group. Licensed under the H2 License, Version 1.0
 * (http://h2database.com/html/license.html).
 * Initial Developer: H2 Group
 */
package org.h2.server;

import java.io.IOException;
import java.io.PrintWriter;
import java.io.StringWriter;
import java.net.Socket;
import java.sql.SQLException;

import org.h2.command.Command;
import org.h2.constant.ErrorCode;
import org.h2.constant.SysProperties;
import org.h2.engine.ConnectionInfo;
import org.h2.engine.Constants;
import org.h2.engine.Engine;
import org.h2.engine.Session;
import org.h2.engine.SessionRemote;
import org.h2.expression.Parameter;
import org.h2.jdbc.JdbcSQLException;
import org.h2.message.Message;
import org.h2.result.LocalResult;
import org.h2.result.ResultColumn;
import org.h2.util.ObjectArray;
import org.h2.util.SmallMap;
import org.h2.value.Transfer;
import org.h2.value.Value;

/**
 * One server thread is opened per client connection.
 */
public class TcpServerThread implements Runnable {
    private TcpServer server;
    private Session session;
    private boolean stop;
    private Thread thread;
    private Transfer transfer;
    private Command commit;
    private SmallMap cache = new SmallMap(SysProperties.SERVER_CACHED_OBJECTS);
    private int id;

    public TcpServerThread(Socket socket, TcpServer server, int id) {
        this.server = server;
        this.id = id;
        transfer = new Transfer(null);
        transfer.setSocket(socket);
    }

    private void log(String s) {
        server.log(this + " " + s);
    }

    public void run() {
        try {
            transfer.init();
            log("Connect");
            // TODO server: should support a list of allowed databases and a
            // list of allowed clients
            try {
                int version = transfer.readInt();
                if (!server.allow(transfer.getSocket())) {
                    throw Message.getSQLException(ErrorCode.REMOTE_CONNECTION_NOT_ALLOWED);
                }
                if (version != Constants.TCP_DRIVER_VERSION) {
                    throw Message.getSQLException(ErrorCode.DRIVER_VERSION_ERROR_2, new String[] { "" + version,
                            "" + Constants.TCP_DRIVER_VERSION });
                }
                String db = transfer.readString();
                String originalURL = transfer.readString();
                String baseDir = server.getBaseDir();
                if (baseDir == null) {
                    baseDir = SysProperties.getBaseDir();
                }
                ConnectionInfo ci = new ConnectionInfo(db);
                if (baseDir != null) {
                    ci.setBaseDir(baseDir);
                }
                if (server.getIfExists()) {
                    ci.setProperty("IFEXISTS", "TRUE");
                }
                ci.setOriginalURL(originalURL);
                ci.setUserName(transfer.readString());
                ci.setUserPasswordHash(transfer.readBytes());
                ci.setFilePasswordHash(transfer.readBytes());
                int len = transfer.readInt();
                for (int i = 0; i < len; i++) {
                    ci.setProperty(transfer.readString(), transfer.readString());
                }
                Engine engine = Engine.getInstance();
                session = engine.getSession(ci);
                transfer.setSession(session);
                transfer.writeInt(SessionRemote.STATUS_OK).flush();
                server.addConnection(id, originalURL, ci.getUserName());
                log("Connected");
            } catch (Throwable e) {
                sendError(e);
                stop = true;
            }
            while (!stop) {
                try {
                    process();
                } catch (Throwable e) {
                    sendError(e);
                }
            }
            log("Disconnect");
        } catch (Throwable e) {
            server.logError(e);
        } finally {
            close();
        }
    }

    private void closeSession() {
        if (session != null) {
            try {
                Command rollback = session.prepareLocal("ROLLBACK");
                rollback.executeUpdate();
                session.close();
                server.removeConnection(id);
            } catch (Exception e) {
                server.logError(e);
            } finally {
                session = null;
            }
        }
    }

    public void close() {
        try {
            stop = true;
            closeSession();
            transfer.close();
            log("Close");
        } catch (Exception e) {
            server.logError(e);
        }
        server.remove(this);
    }

    private void sendError(Throwable e) {
        try {
            SQLException s = Message.convert(e);
            StringWriter writer = new StringWriter();
            e.printStackTrace(new PrintWriter(writer));
            String trace = writer.toString();
            String message;
            String sql;
            if (e instanceof JdbcSQLException) {
                JdbcSQLException j = (JdbcSQLException) e;
                message = j.getOriginalMessage();
                sql = j.getSQL();
            } else {
                message = e.getMessage();
                sql = null;
            }
            transfer.writeInt(SessionRemote.STATUS_ERROR).writeString(s.getSQLState()).writeString(message)
                    .writeString(sql).writeInt(s.getErrorCode()).writeString(trace).flush();
        } catch (IOException e2) {
            server.logError(e2);
            // if writing the error does not work, close the connection
            stop = true;
        }
    }

    private void setParameters(Command command) throws IOException, SQLException {
        int len = transfer.readInt();
        ObjectArray params = command.getParameters();
        for (int i = 0; i < len; i++) {
            Parameter p = (Parameter) params.get(i);
            p.setValue(transfer.readValue());
        }
    }

    private void process() throws IOException, SQLException {
        int operation = transfer.readInt();
        switch (operation) {
        case SessionRemote.SESSION_PREPARE: {
            int id = transfer.readInt();
            String sql = transfer.readString();
            Command command = session.prepareLocal(sql);
            boolean readonly = command.isReadOnly();
            cache.addObject(id, command);
            boolean isQuery = command.isQuery();
            int paramCount = command.getParameters().size();
            transfer.writeInt(SessionRemote.STATUS_OK).writeBoolean(isQuery).writeBoolean(readonly)
                    .writeInt(paramCount).flush();
            break;
        }
        case SessionRemote.SESSION_CLOSE: {
            closeSession();
            transfer.writeInt(SessionRemote.STATUS_OK).flush();
            close();
            break;
        }
        case SessionRemote.COMMAND_COMMIT: {
            if (commit == null) {
                commit = session.prepareLocal("COMMIT");
            }
            commit.executeUpdate();
            transfer.writeInt(SessionRemote.STATUS_OK).flush();
            break;
        }
        case SessionRemote.COMMAND_GET_META_DATA: {
            int id = transfer.readInt();
            int objectId = transfer.readInt();
            Command command = (Command) cache.getObject(id, false);
            LocalResult result = command.getMetaDataLocal();
            cache.addObject(objectId, result);
            int columnCount = result.getVisibleColumnCount();
            transfer.writeInt(SessionRemote.STATUS_OK).writeInt(columnCount).writeInt(0);
            for (int i = 0; i < columnCount; i++) {
                ResultColumn.writeColumn(transfer, result, i);
            }
            transfer.flush();
            break;
        }
        case SessionRemote.COMMAND_EXECUTE_QUERY: {
            int id = transfer.readInt();
            int objectId = transfer.readInt();
            int maxRows = transfer.readInt();
            int fetchSize = transfer.readInt();
            Command command = (Command) cache.getObject(id, false);
            setParameters(command);
            LocalResult result = command.executeQueryLocal(maxRows);
            cache.addObject(objectId, result);
            int columnCount = result.getVisibleColumnCount();
            transfer.writeInt(SessionRemote.STATUS_OK).writeInt(columnCount);
            int rowCount = result.getRowCount();
            transfer.writeInt(rowCount);
            for (int i = 0; i < columnCount; i++) {
                ResultColumn.writeColumn(transfer, result, i);
            }
            int fetch = Math.min(rowCount, fetchSize);
            for (int i = 0; i < fetch; i++) {
                sendRow(result);
            }
            transfer.flush();
            break;
        }
        case SessionRemote.COMMAND_EXECUTE_UPDATE: {
            int id = transfer.readInt();
            Command command = (Command) cache.getObject(id, false);
            setParameters(command);
            int updateCount = command.executeUpdate();
            int status = SessionRemote.STATUS_OK;
            if (session.isClosed()) {
                status = SessionRemote.STATUS_CLOSED;
            }
            transfer.writeInt(status).writeInt(updateCount).writeBoolean(session.getAutoCommit());
            transfer.flush();
            break;
        }
        case SessionRemote.COMMAND_CLOSE: {
            int id = transfer.readInt();
            Command command = (Command) cache.getObject(id, true);
            if (command != null) {
                command.close();
                cache.freeObject(id);
            }
            break;
        }
        case SessionRemote.RESULT_FETCH_ROWS: {
            int id = transfer.readInt();
            int count = transfer.readInt();
            LocalResult result = (LocalResult) cache.getObject(id, false);
            transfer.writeInt(SessionRemote.STATUS_OK);
            for (int i = 0; i < count; i++) {
                sendRow(result);
            }
            transfer.flush();
            break;
        }
        case SessionRemote.RESULT_RESET: {
            int id = transfer.readInt();
            LocalResult result = (LocalResult) cache.getObject(id, false);
            result.reset();
            break;
        }
        case SessionRemote.RESULT_CLOSE: {
            int id = transfer.readInt();
            LocalResult result = (LocalResult) cache.getObject(id, true);
            if (result != null) {
                result.close();
                cache.freeObject(id);
            }
            break;
        }
        case SessionRemote.CHANGE_ID: {
            int oldId = transfer.readInt();
            int newId = transfer.readInt();
            Object obj = cache.getObject(oldId, false);
            cache.freeObject(oldId);
            cache.addObject(newId, obj);
            break;
        }
        default:
            server.logInternalError("Unknown operation: " + operation);
            server.log("Unknown operation: " + operation);
            closeSession();
            close();
        }
    }

    private void sendRow(LocalResult result) throws IOException, SQLException {
        if (result.next()) {
            transfer.writeBoolean(true);
            Value[] v = result.currentRow();
            for (int i = 0; i < result.getVisibleColumnCount(); i++) {
                transfer.writeValue(v[i]);
            }
        } else {
            transfer.writeBoolean(false);
        }
    }

    public void setThread(Thread thread) {
        this.thread = thread;
    }

    public Thread getThread() {
        return thread;
    }

}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
在线视频一区二区三| 欧美国产日本韩| 欧美日本乱大交xxxxx| 日本精品一区二区三区四区的功能| 欧美一级片在线| 欧美亚洲综合在线| 欧美午夜电影在线播放| 欧美亚日韩国产aⅴ精品中极品| 蜜桃av一区二区三区| 日韩精品免费视频人成| 日韩电影免费在线看| 麻豆国产精品官网| 精品一区二区在线观看| 国产精品一色哟哟哟| 粉嫩13p一区二区三区| jlzzjlzz国产精品久久| 色噜噜狠狠色综合中国| 精品视频999| 日韩精品自拍偷拍| 久久久www成人免费无遮挡大片| 色先锋资源久久综合| 精品视频资源站| 亚洲欧美电影院| 一区二区三区欧美视频| 午夜精品爽啪视频| 日本女人一区二区三区| 韩国三级在线一区| 成人av免费观看| 欧美综合亚洲图片综合区| 欧美一区三区二区| 久久久精品tv| 一区二区三区日韩欧美精品| 丝袜美腿亚洲色图| 国产一区二区三区黄视频 | 久久精品亚洲麻豆av一区二区| 一本大道久久a久久精二百| 欧美羞羞免费网站| 欧美v日韩v国产v| 亚洲欧洲日产国码二区| 亚洲永久免费视频| 国产一区二区三区免费播放| av一二三不卡影片| 91精品国产一区二区三区蜜臀| 91国偷自产一区二区三区成为亚洲经典| 国产米奇在线777精品观看| yourporn久久国产精品| 538prom精品视频线放| 欧美韩国日本不卡| 日日摸夜夜添夜夜添精品视频| 一区二区三区在线看| 麻豆精品一区二区| 99视频在线精品| 日韩欧美亚洲国产另类| 亚洲欧美日韩国产另类专区| 蜜桃av噜噜一区| 91视频一区二区三区| 日韩一区二区三区在线视频| 最近中文字幕一区二区三区| 精品在线播放免费| 欧美视频一区二区在线观看| 久久精品免费看| 日本精品一区二区三区高清 | 久久久亚洲欧洲日产国码αv| 精品精品欲导航| 夜夜嗨av一区二区三区中文字幕| 亚洲女厕所小便bbb| 国产又黄又大久久| 欧美二区乱c少妇| 亚洲欧美一区二区不卡| 国产伦精一区二区三区| 欧美三级中文字| 亚洲欧美怡红院| 国产一区二区三区在线观看免费| 国产高清精品在线| 日韩免费成人网| 午夜伊人狠狠久久| 在线视频综合导航| 亚洲美女屁股眼交3| 国产成人免费在线观看不卡| 日韩女优毛片在线| 日韩成人免费电影| 欧美视频一区二区| 一区二区三区在线高清| 成人精品国产免费网站| 久久久国产精华| 国内久久精品视频| 欧美大度的电影原声| 日韩高清在线一区| 欧美在线观看视频一区二区三区 | 中文字幕av资源一区| 麻豆精品一区二区三区| 欧美日高清视频| 亚洲国产欧美一区二区三区丁香婷| 蜜桃视频一区二区三区 | 精品国产一区二区在线观看| 亚瑟在线精品视频| 欧美日韩专区在线| 亚洲国产视频在线| 欧美日韩日日夜夜| 午夜精品久久久久久久久久| 日韩一区中文字幕| 成人网在线免费视频| 亚洲国产高清不卡| 成人福利电影精品一区二区在线观看 | 久久99精品国产91久久来源| 日韩欧美国产三级| 精品夜夜嗨av一区二区三区| 日韩欧美国产高清| 国模大尺度一区二区三区| 精品福利视频一区二区三区| 久久99在线观看| 久久综合色8888| 国产主播一区二区| 国产日韩欧美一区二区三区综合| 亚洲国产精品久久人人爱蜜臀| 国产乱码字幕精品高清av | 最新日韩av在线| 91网站在线播放| 亚洲国产欧美一区二区三区丁香婷| 国产一区二区电影| 欧美激情一区二区三区在线| 99久久99久久精品免费看蜜桃 | 久久久久国产免费免费| 国产成人综合亚洲91猫咪| 中文字幕精品在线不卡| 99久久综合国产精品| 亚洲一二三区视频在线观看| 欧美私人免费视频| 免费成人性网站| 久久久国产午夜精品| 91蜜桃网址入口| 日韩中文字幕av电影| 久久人人爽人人爽| 99久久er热在这里只有精品15| 国产午夜精品一区二区| 色综合久久久久| 午夜精品一区二区三区电影天堂 | 99在线精品观看| 亚洲一区二区三区四区在线观看| 成人短视频下载| 亚洲综合一区二区精品导航| 欧美一区二区三区婷婷月色 | 色综合天天综合网天天看片| 亚洲国产精品久久人人爱蜜臀| 99re热视频这里只精品| 首页亚洲欧美制服丝腿| 久久蜜桃av一区二区天堂| av在线播放不卡| 日本美女一区二区| 国产精品久久久久久亚洲伦| 5858s免费视频成人| 国产99久久久国产精品潘金网站| 久久精品一区二区三区四区| 色婷婷综合中文久久一本| 久久国产精品免费| 亚洲欧美国产77777| 日韩欧美国产一区二区三区| 91在线云播放| 美女视频第一区二区三区免费观看网站| 欧美日韩色一区| 国产高清成人在线| 日韩精品高清不卡| 中文字幕亚洲综合久久菠萝蜜| jizz一区二区| 久久丁香综合五月国产三级网站| 欧美一区二区黄| 91免费版在线| 国产高清不卡二三区| 三级欧美在线一区| 国产精品家庭影院| 精品久久国产字幕高潮| 欧美日韩一级视频| 99这里只有精品| 国产美女视频91| 蜜臀av一区二区在线免费观看 | 国产精品免费看片| 日韩精品影音先锋| 欧美日韩mp4| 欧美性大战久久| 成人午夜视频免费看| 精品一区二区综合| 日本不卡123| 午夜电影网亚洲视频| 亚洲乱码国产乱码精品精小说| 欧美日韩一区不卡| 91极品视觉盛宴| 99国产精品久| 国产盗摄一区二区| 国产一区欧美二区| 亚洲欧美影音先锋| 日韩一区二区在线免费观看| 国产精品成人网| 色综合咪咪久久| 国产91在线看| 国产精品正在播放| 国产一区二区三区高清播放| 麻豆免费精品视频| 久久狠狠亚洲综合| 麻豆国产欧美一区二区三区| 美女视频黄a大片欧美|