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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? databaseproxyservlet.java

?? J2ME MIDP_Example_Applications
?? JAVA
字號:
// Copyright 2003 Nokia Corporation.
//
// THIS SOURCE CODE IS PROVIDED 'AS IS', WITH NO WARRANTIES WHATSOEVER,
// EXPRESS OR IMPLIED, INCLUDING ANY WARRANTY OF MERCHANTABILITY, FITNESS
// FOR ANY PARTICULAR PURPOSE, OR ARISING FROM A COURSE OF DEALING, USAGE
// OR TRADE PRACTICE, RELATING TO THE SOURCE CODE OR ANY WARRANTY OTHERWISE
// ARISING OUT OF ANY PROPOSAL, SPECIFICATION, OR SAMPLE AND WITH NO
// OBLIGATION OF NOKIA TO PROVIDE THE LICENSEE WITH ANY MAINTENANCE OR
// SUPPORT. FURTHERMORE, NOKIA MAKES NO WARRANTY THAT EXERCISE OF THE
// RIGHTS GRANTED HEREUNDER DOES NOT INFRINGE OR MAY NOT CAUSE INFRINGEMENT
// OF ANY PATENT OR OTHER INTELLECTUAL PROPERTY RIGHTS OWNED OR CONTROLLED
// BY THIRD PARTIES
//
// Furthermore, information provided in this source code is preliminary,
// and may be changed substantially prior to final release. Nokia Corporation
// retains the right to make changes to this source code at
// any time, without notice. This source code is provided for informational
// purposes only.
//
// Nokia and Nokia Connecting People are registered trademarks of Nokia
// Corporation.
// Java and all Java-based marks are trademarks or registered trademarks of
// Sun Microsystems, Inc.
// Other product and company names mentioned herein may be trademarks or
// trade names of their respective owners.
//
// A non-exclusive, non-transferable, worldwide, limited license is hereby
// granted to the Licensee to download, print, reproduce and modify the
// source code. The licensee has the right to market, sell, distribute and
// make available the source code in original or modified form only when
// incorporated into the programs developed by the Licensee. No other
// license, express or implied, by estoppel or otherwise, to any other
// intellectual property rights is granted herein.
package databaseproxy;

import java.io.*;
import java.net.*;
import java.sql.*;
import java.util.*;
import javax.servlet.*;
import javax.servlet.http.*;

public class DatabaseProxyServlet
   extends HttpServlet
{
  private String jdbcDriver = null;
  private String jdbcUrl = null;
  private String jdbcUsername = null;
  private String jdbcPassword = null;
  private String errorMsg = null;


  public void init()
  {
    jdbcDriver = getInitParameter("jdbc.driver");
    jdbcUrl = getInitParameter("jdbc.url");
    jdbcUsername = getInitParameter("jdbc.username");
    jdbcPassword = getInitParameter("jdbc.password");
    Connection c = null;
    if (jdbcDriver != null)
    {
      try
      {
        Class driverClass = Class.forName(jdbcDriver);
        if (driverClass.isAssignableFrom(Driver.class))
        {
          DriverManager.registerDriver(
            (Driver)driverClass.newInstance());
        }
      }
      catch (ClassNotFoundException e)
      {
        errorMsg = "Driver " + jdbcDriver + " not found ";
      }
      catch (ClassCastException e)
      {
        errorMsg = "Driver class " + jdbcDriver +
          " not a valid driver ";
      }
      catch (InstantiationException e)
      {
        errorMsg = "Driver class " + jdbcDriver +
          " could not be instantiated";
      }
      catch (IllegalAccessException e)
      {
        errorMsg = "Driver class " + jdbcDriver + 
          " could not be accesed";
      }
      catch (SQLException e)
      {
        errorMsg = "Exception when initializing driver "
                           + e.getMessage();
      }
    }
  }


  protected void doPost(HttpServletRequest req,
                        HttpServletResponse resp)
    throws ServletException, java.io.IOException
  {
    // check if the JDBC driver could be loaded
    if (errorMsg == null)
    {
      System.err.println("error msg was not null");
      // check that at least query and type are always present
      if (req.getParameter("query") != null)
      {
        String query = req.getParameter("query").toLowerCase();
        int maxrows = Integer.MAX_VALUE;
        try
        {
          if (req.getParameter("maxrows") != null)
          {
            maxrows = Integer.parseInt(req.getParameter("maxrows"));
          }
        }
        catch (NumberFormatException e)
        {
          // ignore. Not an appropriate number
        }
        Connection c = null;
        PreparedStatement s = null;
        StringBuffer response = null;
        try
        {
          // this should probably be implemented using a connection pool
          c = DriverManager.getConnection(jdbcUrl,
                                          jdbcUsername,
                                          jdbcPassword);
          s = c.prepareStatement(query);
          // check if max rows was set
          if (maxrows > 0)
          {
            s.setMaxRows(maxrows);
          }
         
          // parse parameters
          int counter = 1;
          do
          {
            // read parameters
            String value = req.getParameter("value" + counter);
            String type = req.getParameter("type" + counter);
            if (value == null || type == null)
            {
              break;
            }
            
            int typeNumber = -1;
            try
            {
              typeNumber = Integer.parseInt(type);
            }
            catch (NumberFormatException e)
            {
              // not possible to parse the type number
              resp.sendError(HttpServletResponse.SC_BAD_REQUEST,
                             "parameter type" + counter
                             + " not understood");
              return;
            }
            if (!setStatementParameter(s, counter, value, typeNumber))
            {
              // the parameter type is not supported
              resp.sendError(HttpServletResponse.SC_BAD_REQUEST,
                            "parameter type " + counter
                            + " not supported");
              return;
            }
            counter++;
          } while (true);
          
          // check query type
          if (query.startsWith("insert"))
          {
            int result = s.executeUpdate();
            response = new StringBuffer("OK\nINSERT\n").append(result);
          }
          else if (query.startsWith("delete"))
          {
            int result = s.executeUpdate();
            response = new StringBuffer("OK\nDELETE\n").append(result);
          }
          else if (query.startsWith("update"))
          {
            int result = s.executeUpdate();
            response = new StringBuffer("OK\nDELETE\n").append(result);
          }
          else if (query.startsWith("select"))
          {
            ResultSet rs = s.executeQuery();
            response = new StringBuffer("OK\nSELECT\n");
            ResultSetMetaData queryMetadata = rs.getMetaData();
            
            // write column names
            int columnCount = queryMetadata.getColumnCount();
            for (int i = 1; i <= columnCount; i++)
            {
              response.append(queryMetadata.getColumnName(i));
              if (i < columnCount)
              {
                response.append(",");
              }
            }
            response.append("\n");
            
            // write column types
            for (int i = 1; i <= columnCount; i++)
            {
              response.append(queryMetadata.getColumnType(i));
              if (i < columnCount)
              {
                response.append(",");
              }
            }
            response.append("\n");
            
            // write the content
            int rowCount = 0;
            while (rs.next() && rowCount < maxrows)
            {
              for (int i = 1; i <= columnCount; i++)
              {
                if (rs.wasNull())
                {
                  // put a special marker since %0 cannot be produced
                  // in UTF-8 encoding
                  response.append("%0");
                }
                else
                {
                  response.append(URLEncoder.encode(
                    new String(rs.getString(i).getBytes(), "UTF-8")));
                }
                if (i < columnCount)
                {
                  response.append(",");
                }
              }
              response.append("\n");
              rowCount++;
            }
          }
          else
          {
            // respond an error
            response = new StringBuffer("ERROR\n")
                          .append("query type not supported");
          }
        }
        catch (SQLException e)
        {
          // print the error message
          response = new StringBuffer("ERROR\n")
                          .append(e.getMessage());
        }
        finally
        {
          try
          {
            if (c != null)
            {
              c.close();
            }
          }
          catch (SQLException e)
          {
            System.err.println("Exception closing DB connection "
                               + e.getMessage());
          }
        }
        resp.setContentType("text/plain");
        PrintStream out = new PrintStream(resp.getOutputStream());
        out.print(response.toString());
      }
      else
      {
        // respond an error
        resp.sendError(HttpServletResponse.SC_BAD_REQUEST,
                      "parameter query missing");
      }
    }
    else
    {
      // respond a loading message error
      resp.sendError(HttpServletResponse.SC_BAD_REQUEST,
                    errorMsg);
    }
  }


  // parses and set the value of a paramter
  private boolean setStatementParameter(PreparedStatement s,
                                        int index,
                                        String value,
                                        int type)
    throws SQLException
  {
    try
    {
      switch (type)
      {
        case Types.CHAR:
        case Types.VARCHAR:
            s.setString(index, value);
            break;
        case Types.BIGINT:
            s.setLong(index,
            Long.parseLong(value));
            break;
        case Types.TINYINT:
        case Types.SMALLINT:
            s.setShort(index,
            Short.parseShort(value));
            break;
        case Types.BIT:
            s.setBoolean(index,
            Boolean.valueOf(value).booleanValue());
            break;
        case Types.INTEGER:
            s.setInt(index,
            Integer.parseInt(value));
            break;
        default:
            return false;
      }
    }
    catch (NumberFormatException e)
    {
      return false;
    }
    // unsupported types return false
    return true;
  }

}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产成人av影院| 国产凹凸在线观看一区二区| 视频一区视频二区中文| 美女在线一区二区| 成人影视亚洲图片在线| 一本色道久久加勒比精品| 欧美一区二区免费观在线| 欧美精品一区二| 中文字幕精品三区| 亚洲成人综合视频| 成人激情电影免费在线观看| 91精品国产综合久久久久久漫画 | 日本一区免费视频| 亚洲一区二区三区美女| 美日韩一区二区三区| 色综合久久66| 精品国产91乱码一区二区三区| 欧美极品xxx| 蜜臀av性久久久久蜜臀aⅴ流畅| jizzjizzjizz欧美| 精品日产卡一卡二卡麻豆| 一个色综合av| av男人天堂一区| 26uuu欧美| 乱一区二区av| 欧美日本高清视频在线观看| 亚洲色图欧美偷拍| 国产成人精品网址| 久久日韩精品一区二区五区| 视频一区视频二区在线观看| 日本高清无吗v一区| 一区二区三区中文免费| 成人app下载| 最新久久zyz资源站| 成人动漫精品一区二区| 亚洲精品高清视频在线观看| 成人在线综合网站| 亚洲精品国产第一综合99久久| 99久久免费国产| 亚洲图片你懂的| 欧美色大人视频| 亚洲裸体xxx| 91福利在线观看| 亚洲动漫第一页| 精品国产亚洲一区二区三区在线观看| 青青草精品视频| 欧美国产日韩一二三区| 一本色道久久综合亚洲aⅴ蜜桃| 最近日韩中文字幕| 欧美三级中文字| 久久精品国产亚洲5555| 国产精品久久久久影视| 欧美视频在线一区二区三区 | 91蜜桃视频在线| 麻豆91精品视频| 日本一区二区免费在线| 一本在线高清不卡dvd| 日韩av一级电影| 国产精品久久久久毛片软件| 欧美视频完全免费看| 美洲天堂一区二卡三卡四卡视频| 国产精品视频第一区| 欧美一区二区三区在线视频| 国产夫妻精品视频| 五月婷婷激情综合| 亚洲美女免费视频| 久久综合一区二区| 欧美日本视频在线| 91福利在线看| 91老司机福利 在线| 国产精品羞羞答答xxdd| 久久精品国产一区二区| 天天综合天天做天天综合| 亚洲免费观看视频| 椎名由奈av一区二区三区| 国产精品女主播在线观看| 欧美成人乱码一区二区三区| 欧美日本乱大交xxxxx| 91久久国产最好的精华液| 91免费看片在线观看| 国产精品一区二区在线观看网站 | 欧美吞精做爰啪啪高潮| 欧美日韩一区高清| 91毛片在线观看| 色先锋久久av资源部| 欧美在线|欧美| 欧美成人精精品一区二区频| 欧美电影精品一区二区| 26uuu成人网一区二区三区| 久久综合色8888| 亚洲精品成人在线| 午夜精品影院在线观看| 免费成人在线视频观看| 国产很黄免费观看久久| 成人av小说网| 欧美性做爰猛烈叫床潮| 日韩精品一区二区三区三区免费| 欧美精品一区男女天堂| 国产精品久久久久久久久快鸭| 日本一区二区免费在线观看视频 | 北条麻妃一区二区三区| 日本精品裸体写真集在线观看| 日韩欧美一区二区免费| 国产精品―色哟哟| 日韩成人免费在线| 91小宝寻花一区二区三区| 日韩三级高清在线| 国产精品国产三级国产| 久久精品国产久精国产| 一本到三区不卡视频| 亚洲二区在线视频| 成人激情视频网站| 精品99999| 轻轻草成人在线| 欧美日韩精品一区二区在线播放| 26uuu欧美| 国产成人免费高清| 久久久91精品国产一区二区三区| 亚洲国产毛片aaaaa无费看 | 中文字幕av资源一区| 免费观看日韩电影| 欧美日韩www| 亚洲成人动漫一区| 欧美自拍偷拍午夜视频| 国产欧美日韩综合| 99久久久精品| 一区二区三区久久久| 色av综合在线| 日产欧产美韩系列久久99| 日韩色视频在线观看| 久久99精品国产91久久来源| 欧美成人一级视频| 国产在线视视频有精品| 久久精品一区四区| 国产成人午夜电影网| 国产精品福利影院| 在线亚洲人成电影网站色www| 亚洲一级电影视频| 欧美日韩美少妇| 久久99九九99精品| 国产精品久久久久精k8| 欧美性视频一区二区三区| 日韩福利电影在线观看| 久久综合久久综合久久| 激情五月婷婷综合网| 成人免费在线视频观看| 欧美色精品天天在线观看视频| 看电影不卡的网站| 亚洲美女免费视频| 国产欧美日韩一区二区三区在线观看| 成人91在线观看| 国产在线日韩欧美| 亚洲va国产va欧美va观看| 国产日韩欧美a| 欧美猛男gaygay网站| 国产成人精品亚洲午夜麻豆| 日韩电影在线观看网站| 亚洲精品免费在线观看| 中文字幕av一区二区三区高| 欧美一区二区三区的| 在线观看91精品国产入口| 成人永久看片免费视频天堂| 午夜精品福利久久久| 亚洲日本va在线观看| 久久久91精品国产一区二区精品| 日韩美女在线视频| 日韩亚洲欧美高清| 91久久一区二区| 色综合欧美在线| 91女厕偷拍女厕偷拍高清| 波多野结衣中文字幕一区| 丁香五精品蜜臀久久久久99网站| 狠狠狠色丁香婷婷综合久久五月| 日韩成人免费看| 国内成人免费视频| 国产电影一区二区三区| 成人美女视频在线看| 成人免费三级在线| 93久久精品日日躁夜夜躁欧美| 91免费在线看| 精品对白一区国产伦| 国产精品美女www爽爽爽| 中文字幕欧美激情一区| 亚洲九九爱视频| 婷婷丁香久久五月婷婷| 麻豆国产欧美一区二区三区| 国产精品中文字幕欧美| 懂色一区二区三区免费观看| 成人av午夜电影| 欧美日韩精品一区视频| 欧美精品一区二区在线播放| 亚洲免费观看在线视频| 日韩激情av在线| 波多野洁衣一区| 久久精品一级爱片| 欧美bbbbb| 色综合久久中文综合久久97| 日韩欧美成人午夜| 午夜精品久久久久久久99水蜜桃| 成人一区二区三区中文字幕|